diff options
author | Paul Eggert <eggert@cs.ucla.edu> | 2005-09-23 20:39:04 +0000 |
---|---|---|
committer | Paul Eggert <eggert@cs.ucla.edu> | 2005-09-23 20:39:04 +0000 |
commit | 63b77aac44f5ed542439f4d7c71fdd6625bcc0f6 (patch) | |
tree | 12ea052d36758dc359aee4c12c609513a43fe645 /src/install.c | |
parent | 35044438af981921afed8284bc8aea687bcba2d0 (diff) | |
download | coreutils-63b77aac44f5ed542439f4d7c71fdd6625bcc0f6.tar.xz |
(change_timestamps): First arg is source
struct stat, not file name. All uses changed.
(install_file_in_file): Stat the source file if necessary.
Don't try to change time stamps if copy_file did it.
Diffstat (limited to 'src/install.c')
-rw-r--r-- | src/install.c | 25 |
1 files changed, 12 insertions, 13 deletions
diff --git a/src/install.c b/src/install.c index 4925dc6f8..1bdb0a724 100644 --- a/src/install.c +++ b/src/install.c @@ -65,7 +65,7 @@ /* Number of bytes of a file to copy at a time. */ #define READ_SIZE (32 * 1024) -static bool change_timestamps (const char *from, const char *to); +static bool change_timestamps (struct stat const *from_sb, char const *to); static bool change_attributes (char const *name); static bool copy_file (const char *from, const char *to, const struct cp_options *x); @@ -439,14 +439,20 @@ static bool install_file_in_file (const char *from, const char *to, const struct cp_options *x) { + struct stat from_sb; + if (strip_files && x->preserve_timestamps && stat (from, &from_sb) != 0) + { + error (0, errno, _("cannot stat %s"), quote (from)); + return false; + } if (! copy_file (from, to, x)) return false; if (strip_files) strip (to); if (! change_attributes (to)) return false; - if (x->preserve_timestamps) - return change_timestamps (from, to); + if (strip_files && x->preserve_timestamps) + return change_timestamps (&from_sb, to); return true; } @@ -526,19 +532,12 @@ change_attributes (char const *name) Return true if successful. */ static bool -change_timestamps (const char *from, const char *to) +change_timestamps (struct stat const *from_sb, char const *to) { - struct stat stb; struct timespec timespec[2]; + timespec[0] = get_stat_atime (from_sb); + timespec[1] = get_stat_mtime (from_sb); - if (stat (from, &stb)) - { - error (0, errno, _("cannot obtain time stamps for %s"), quote (from)); - return false; - } - - timespec[0] = get_stat_atime (&stb); - timespec[1] = get_stat_mtime (&stb); if (utimens (to, timespec)) { error (0, errno, _("cannot set time stamps for %s"), quote (to)); |