# HG changeset patch # User Christian Ebert # Date 1316010621 -3600 # Node ID 0b32ba113ad24cb72a1fb5bcce44a9952151408e # Parent 6cabb1c47f214fc0dad30240bcf0823f4c5906db Preserve file mode when overwriting diff -r 6cabb1c47f21 -r 0b32ba113ad2 hgkw/keyword.py --- a/hgkw/keyword.py Tue Aug 09 12:54:11 2011 +0200 +++ b/hgkw/keyword.py Wed Sep 14 15:30:21 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,15 +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) - self.repo.wwrite(f, data, ctx.flags(f)) + fp = self.repo.wopener(f, "wb", atomictemp=True) + fp.write(data) + fp.close() if kwcmd: self.repo.dirstate.normal(f) elif self.record: diff -r 6cabb1c47f21 -r 0b32ba113ad2 tests/test-keyword.t --- a/tests/test-keyword.t Tue Aug 09 12:54:11 2011 +0200 +++ b/tests/test-keyword.t Wed Sep 14 15:30:21 2011 +0100 @@ -270,15 +270,20 @@ xxx $ ignore $Id$ -Check whether expansion is filewise +Check whether expansion is filewise and file mode is preserved $ echo '$Id$' > c $ echo 'tests for different changenodes' >> c + $ chmod 600 c + $ ls -l c | cut -b 1-10 + -rw------- commit file c $ hg commit -A -mcndiff -d '1 0' -u 'User Name ' adding c + $ ls -l c | cut -b 1-10 + -rw------- force expansion