[PATCH 2 of 5] keyword: support copy and rename
Christian Ebert
blacktrash at gmx.net
Fri Oct 1 16:35:21 UTC 2010
# HG changeset patch
# User Christian Ebert <blacktrash at gmx.net>
# Date 1285950917 -7200
# Node ID edf364870eb30b6f72cf01f0f90814409c314bf4
# Parent 6775ac840422e36decdcfe368b8bb0bef21be4c6
keyword: support copy and rename
When a file containing keywords is copied/renamed to a destintation
which is ignored by the extension, the destination is now overwritten
with the keywords unexpanded to avoid the danger of accidentally
storing expanded keywords in history.
Files copied/renamed from an ignored source to an ignored
destination are not touched.
Add tests covering both of the above cases, plus the corner case of
cp symlink foo; hg cp -A symlink foo (where foo becomes a regular file).
diff --git a/hgext/keyword.py b/hgext/keyword.py
--- a/hgext/keyword.py
+++ b/hgext/keyword.py
@@ -91,8 +91,8 @@
commands.optionalrepo += ' kwdemo'
# hg commands that do not act on keywords
-nokwcommands = ('add addremove annotate bundle copy export grep incoming init'
- ' log outgoing push rename tip verify convert email glog')
+nokwcommands = ('add addremove annotate bundle export grep incoming init log'
+ ' outgoing push tip verify convert email glog')
# hg commands that trigger expansion only when writing to working dir,
# not when reading filelog, and unexpand when reading from working dir
@@ -545,6 +545,29 @@
kwt.match = util.never
return orig(web, req, tmpl)
+ def kw_copy(orig, ui, repo, pats, opts, rename=False):
+ '''Wraps cmdutil.copy to prevent keyword expansion in a copy/rename
+ from a source configured for keyword expansion to a destination
+ ignored by the extension.
+ Note that the source may also be a symlink as:
+ hg cp sym x -> x is symlink
+ cp sym x; hg cp -A sym x -> x is file (maybe expanded keywords)
+ '''
+ orig(ui, repo, pats, opts, rename)
+ if opts.get('dry_run'):
+ return
+ wctx = repo[None]
+ nokwcopies = [f for f in repo.dirstate.copies()
+ if not kwt.match(f) and not 'l' in wctx.flags(f)]
+ for f in nokwcopies:
+ if kwt.match(repo.dirstate.copied(f)):
+ data = repo.wread(f)
+ if not util.binary(data):
+ data, found = _shrinktext(data, kwt.re_kw.subn)
+ if found:
+ ui.note(_('overwriting %s shrinking keywords\n') % f)
+ repo.wwrite(f, data, wctx.flags(f))
+
def kw_dorecord(orig, ui, repo, commitfunc, *pats, **opts):
'''Wraps record.dorecord expanding keywords after recording.'''
wlock = repo.wlock()
@@ -565,6 +588,7 @@
extensions.wrapfunction(patch.patchfile, '__init__', kwpatchfile_init)
extensions.wrapfunction(patch, 'diff', kw_diff)
+ extensions.wrapfunction(cmdutil, 'copy', kw_copy)
for c in 'annotate changeset rev filediff diff'.split():
extensions.wrapfunction(webcommands, c, kwweb_skip)
for name in recordextensions.split():
diff --git a/tests/test-keyword.t b/tests/test-keyword.t
--- a/tests/test-keyword.t
+++ b/tests/test-keyword.t
@@ -48,6 +48,7 @@
> [keyword]
> ** =
> b = ignore
+ > i = ignore
> [hooks]
> commit=
> commit.test=cp a hooktest
@@ -498,6 +499,38 @@
$ touch c
$ hg status
+Copy kwfile to keyword ignored file unexpanding keywords
+
+ $ hg --verbose copy a i
+ copying a to i
+ overwriting i shrinking keywords
+ $ head -n 1 i
+ expand $Id$
+ $ hg forget i
+ $ rm i
+
+Copy ignored file to ignored file: no overwriting
+
+ $ hg --verbose copy b i
+ copying b to i
+ $ hg forget i
+ $ rm i
+
+cp symlink (becomes regular file), and hg copy after
+
+ $ cp sym i
+ $ ls -l i
+ -rw-r--r-- * (glob)
+ $ head -1 i
+ expand $Id: a,v ef63ca68695b 1970/01/01 00:00:00 user $
+ $ hg copy --after --verbose sym i
+ copying sym to i
+ overwriting i shrinking keywords
+ $ head -1 i
+ expand $Id$
+ $ hg forget i
+ $ rm i
+
Test different options of hg kwfiles
$ hg kwfiles
@@ -541,6 +574,7 @@
** =
b = ignore
demo.txt =
+ i = ignore
[keywordmaps]
Xinfo = {author}: {desc}
$Xinfo: test: hg keyword configuration and expansion example $
More information about the Mercurial-devel
mailing list