plan9port

fork of plan9port with libvec, libstr and libsdb
Log | Files | Refs | README | LICENSE

commit be856b940fb5abb22abe649256bb4283c07c3d85
parent 1619f52cbc2096dd2fc93b189890bc8fd0771681
Author: Russ Cox <rsc@swtch.com>
Date:   Thu, 18 Mar 2010 18:07:39 -0700

acme: attempt to fix Put mtime skew on NFS

R=r
http://codereview.appspot.com/583043

Diffstat:
Msrc/cmd/acme/exec.c | 13+++++++++++++
1 file changed, 13 insertions(+), 0 deletions(-)

diff --git a/src/cmd/acme/exec.c b/src/cmd/acme/exec.c @@ -687,6 +687,19 @@ putfile(File *f, int q0, int q1, Rune *namer, int nname) w->dirty = TRUE; f->unread = TRUE; }else{ + // In case the file is on NFS, reopen the fd + // before dirfstat to cause the attribute cache + // to be updated (otherwise the mtime in the + // dirfstat below will be stale and not match + // what NFS sees). The file is already written, + // so this should be a no-op when not on NFS. + // Opening for OWRITE (but no truncation) + // in case we don't have read permission. + // (The create above worked, so we probably + // still have write permission.) + close(fd); + fd = open(name, OWRITE); + d1 = dirfstat(fd); if(d1 != nil){ free(d);