dealing with a NULL struct utimbuf* argument, this utime replacement
could -- in unusual circumstances -- leak a file descriptor.
Include <unistd.h> and <errno.h>.
(utime_null): Be sure to close `fd' and to preserve errno.
# include <fcntl.h>
#endif
+#include <unistd.h>
+#include <errno.h>
+#ifndef errno
+extern int errno;
+#endif
+
#include "full-write.h"
#include "safe-read.h"
char c;
int status = 0;
struct stat st;
+ int saved_errno = 0;
fd = open (file, O_RDWR);
if (fd < 0
of patches, but that system doesn't use this code: it has utimes.
|| fsync (fd) < 0
*/
- || (st.st_size == 0 && ftruncate (fd, st.st_size) < 0)
- || close (fd) < 0)
- status = -1;
+ || (st.st_size == 0 && ftruncate (fd, st.st_size) < 0))
+ {
+ saved_errno = errno;
+ status = -1;
+ }
+
+ if (0 <= fd)
+ {
+ if (close (fd) < 0)
+ status = -1;
+
+ /* If there was a prior failure, use the saved errno value.
+ But if the only failure was in the close, don't change errno. */
+ if (saved_errno)
+ errno = saved_errno;
+ }
+
return status;
#endif
}