# HG changeset patch # User Christian Ebert # Date 1315740039 -3600 # Node ID 6e069366e27ca9936c14b253c7d431733f791ad0 # Parent d23dfcbb88400803eba3c1f25e54f993cb0ecf14 keyword: use wopener(..., atomictemp=True) to overwrite diff -r d23dfcbb8840 -r 6e069366e27c hgext/keyword.py --- a/hgext/keyword.py Sat Sep 10 17:59:47 2011 -0500 +++ b/hgext/keyword.py Sun Sep 11 12:20:39 2011 +0100 @@ -257,7 +257,6 @@ msg = _('overwriting %s expanding keywords\n') else: msg = _('overwriting %s shrinking keywords\n') - lctx = ctx for f in candidates: if self.restrict: data = self.repo.file(f).read(mf[f]) @@ -267,18 +266,17 @@ continue if expand: if lookup: - lctx = self.linkctx(f, mf[f]) - data, found = self.substitute(data, f, lctx, re_kw.subn) + ctx = self.linkctx(f, mf[f]) + data, found = self.substitute(data, f, ctx, re_kw.subn) elif self.restrict: found = re_kw.search(data) else: data, found = _shrinktext(data, re_kw.subn) if found: self.ui.note(msg % f) - fpath = self.repo.wjoin(f) - mode = os.lstat(fpath).st_mode - self.repo.wwrite(f, data, ctx.flags(f)) - os.chmod(fpath, mode) + fp = self.repo.wopener(f, "wb", atomictemp=True) + fp.write(data) + fp.close() if kwcmd: self.repo.dirstate.normal(f) elif self.record: