From ca79528f5ed4faccce4cce3fec8963f64a7d6b41 Mon Sep 17 00:00:00 2001 From: Zac Medico Date: Fri, 27 Nov 2009 22:38:16 +0000 Subject: [PATCH] Fix logic from previous commit so it only applies when a 'newmtime' parameter has not been specified (this is always the case when called by portage). (trunk r14898) svn path=/main/branches/2.1.7/; revision=14903 --- pym/portage/__init__.py | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/pym/portage/__init__.py b/pym/portage/__init__.py index e22854996..e314654f4 100644 --- a/pym/portage/__init__.py +++ b/pym/portage/__init__.py @@ -7565,13 +7565,15 @@ def movefile(src, dest, newmtime=None, sstat=None, mysettings=None, try: if hardlinked: newmtime = long(os.stat(dest).st_mtime) - elif not renamefailed: - newmtime = long(sstat.st_mtime) else: if newmtime is not None: os.utime(dest, (newmtime, newmtime)) else: - os.utime(dest, (sstat.st_atime, sstat.st_mtime)) + if renamefailed: + # If rename succeeded then this is not necessary, since + # rename automatically preserves timestamps with complete + # precision. + os.utime(dest, (sstat.st_atime, sstat.st_mtime)) newmtime = long(sstat.st_mtime) except OSError: # The utime can fail here with EPERM even though the move succeeded. -- 2.26.2