X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Futime.c;h=9ddb8b86f83bd7b9e03b9bf59416c9a6a016e8bf;hb=952be23bc009785c91c76e8dbb29c73001e3267a;hp=557444c0d30d8b71b6f4482a17fce3cdfeb2d768;hpb=3e65438376f090a29ee885c8e94e248f819f8e2e;p=gnulib.git diff --git a/lib/utime.c b/lib/utime.c index 557444c0d..9ddb8b86f 100644 --- a/lib/utime.c +++ b/lib/utime.c @@ -1,8 +1,9 @@ -/* Copyright (C) 1998 Free Software Foundation, Inc. +/* Copyright (C) 1998, 2001, 2002, 2003, 2004, 2006 Free Software + Foundation, Inc. - This program is free software; you can redistribute it and/or modify it + This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the - Free Software Foundation; either version 2, or (at your option) any + Free Software Foundation; either version 3 of the License, or any later version. This program is distributed in the hope that it will be useful, @@ -11,14 +12,11 @@ GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software Foundation, - Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ + along with this program. If not, see . */ /* derived from a function in touch.c */ -#ifdef HAVE_CONFIG_H -# include -#endif +#include #undef utime #include @@ -27,6 +25,15 @@ # include #endif +#if !HAVE_UTIMES_NULL +# include +# include +#endif + +#include +#include + +#include "full-write.h" #include "safe-read.h" /* Some systems (even some that do have ) don't declare this @@ -39,6 +46,11 @@ struct utimbuf }; #endif +/* The results of open() in this file are not used with fchdir, + therefore save some unnecessary work in fchdir.c. */ +#undef open +#undef close + /* Emulate utime (file, NULL) for systems (like 4.3BSD) that do not interpret it to set the access and modification times of FILE to the current time. Return 0 if successful, -1 if not. */ @@ -52,21 +64,36 @@ utime_null (const char *file) int fd; char c; int status = 0; - struct stat sb; + struct stat st; + int saved_errno = 0; - fd = open (file, O_RDWR, 0666); + fd = open (file, O_RDWR); if (fd < 0 - || fstat (fd, &sb) < 0 - || safe_read (fd, &c, sizeof (char)) < 0 + || fstat (fd, &st) < 0 + || safe_read (fd, &c, sizeof c) == SAFE_READ_ERROR || lseek (fd, (off_t) 0, SEEK_SET) < 0 - || full_write (fd, &c, sizeof (char)) < 0 - /* Maybe do this -- it's necessary on SunOS4.1.3 with some combination + || full_write (fd, &c, sizeof c) != sizeof c + /* Maybe do this -- it's necessary on SunOS 4.1.3 with some combination of patches, but that system doesn't use this code: it has utimes. || fsync (fd) < 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 }