annotate: automatically populate fields referenced from template
authorYuya Nishihara <yuya@tcha.org>
Thu, 03 May 2018 12:04:36 +0900
changeset 38358 57dc72b56b6c
parent 38357 31ed65f9c5ad
child 38359 876352ea831e
annotate: automatically populate fields referenced from template If '{line_number}' is in the template, we'll probably need it. No --line-number option should be required in such cases.
mercurial/commands.py
tests/test-annotate.t
--- a/mercurial/commands.py	Thu May 03 12:10:47 2018 +0900
+++ b/mercurial/commands.py	Thu May 03 12:04:36 2018 +0900
@@ -359,11 +359,12 @@
     else:
         def makefunc(get, fmt):
             return get
+    datahint = rootfm.datahint()
     funcmap = [(makefunc(get, fmt), sep) for fn, sep, get, fmt in opmap
-               if opts.get(opnamemap.get(fn, fn))]
+               if opts.get(opnamemap.get(fn, fn)) or fn in datahint]
     funcmap[0] = (funcmap[0][0], '') # no separator in front of first column
     fields = ' '.join(fn for fn, sep, get, fmt in opmap
-                      if opts.get(opnamemap.get(fn, fn)))
+                      if opts.get(opnamemap.get(fn, fn)) or fn in datahint)
 
     def bad(x, y):
         raise error.Abort("%s: %s" % (x, y))
--- a/tests/test-annotate.t	Thu May 03 12:10:47 2018 +0900
+++ b/tests/test-annotate.t	Thu May 03 12:04:36 2018 +0900
@@ -76,6 +76,11 @@
   $ hg annotate -T'{lines % "{rev} {node|shortest}: {line}"}' a
   0 8435: a
 
+'{line_number}' field should be populated as necessary
+
+  $ hg annotate -T'{lines % "{rev}:{line_number}: {line}"}' a
+  0:1: a
+
   $ cat <<EOF >>a
   > a
   > a