##// END OF EJS Templates
identify: add template support...
Matt Harbison -
r33051:15a79ac8 default
parent child Browse files
Show More
@@ -2667,7 +2667,7 def help_(ui, name=None, **opts):
2667 ('b', 'branch', None, _('show branch')),
2667 ('b', 'branch', None, _('show branch')),
2668 ('t', 'tags', None, _('show tags')),
2668 ('t', 'tags', None, _('show tags')),
2669 ('B', 'bookmarks', None, _('show bookmarks')),
2669 ('B', 'bookmarks', None, _('show bookmarks')),
2670 ] + remoteopts,
2670 ] + remoteopts + formatteropts,
2671 _('[-nibtB] [-r REV] [SOURCE]'),
2671 _('[-nibtB] [-r REV] [SOURCE]'),
2672 optionalrepo=True)
2672 optionalrepo=True)
2673 def identify(ui, repo, source=None, rev=None,
2673 def identify(ui, repo, source=None, rev=None,
@@ -2726,6 +2726,9 def identify(ui, repo, source=None, rev=
2726 repo = peer.local()
2726 repo = peer.local()
2727 revs, checkout = hg.addbranchrevs(repo, peer, branches, None)
2727 revs, checkout = hg.addbranchrevs(repo, peer, branches, None)
2728
2728
2729 fm = ui.formatter('identify', opts)
2730 fm.startitem()
2731
2729 if not repo:
2732 if not repo:
2730 if num or branch or tags:
2733 if num or branch or tags:
2731 raise error.Abort(
2734 raise error.Abort(
@@ -2736,8 +2739,10 def identify(ui, repo, source=None, rev=
2736 rev = "tip"
2739 rev = "tip"
2737
2740
2738 remoterev = peer.lookup(rev)
2741 remoterev = peer.lookup(rev)
2742 hexrev = hexfunc(remoterev)
2739 if default or id:
2743 if default or id:
2740 output = [hexfunc(remoterev)]
2744 output = [hexrev]
2745 fm.data(id=hexrev)
2741
2746
2742 def getbms():
2747 def getbms():
2743 bms = []
2748 bms = []
@@ -2749,13 +2754,17 def identify(ui, repo, source=None, rev=
2749
2754
2750 return sorted(bms)
2755 return sorted(bms)
2751
2756
2757 bms = getbms()
2752 if bookmarks:
2758 if bookmarks:
2753 output.extend(getbms())
2759 output.extend(bms)
2754 elif default and not ui.quiet:
2760 elif default and not ui.quiet:
2755 # multiple bookmarks for a single parent separated by '/'
2761 # multiple bookmarks for a single parent separated by '/'
2756 bm = '/'.join(getbms())
2762 bm = '/'.join(bms)
2757 if bm:
2763 if bm:
2758 output.append(bm)
2764 output.append(bm)
2765
2766 fm.data(node=hex(remoterev))
2767 fm.data(bookmarks=fm.formatlist(bms, name='bookmark'))
2759 else:
2768 else:
2760 ctx = scmutil.revsingle(repo, rev, None)
2769 ctx = scmutil.revsingle(repo, rev, None)
2761
2770
@@ -2767,19 +2776,32 def identify(ui, repo, source=None, rev=
2767 taglist.extend(p.tags())
2776 taglist.extend(p.tags())
2768
2777
2769 changed = ""
2778 changed = ""
2770 if default or id or num:
2771 if (any(repo.status())
2779 if (any(repo.status())
2772 or any(ctx.sub(s).dirty() for s in ctx.substate)):
2780 or any(ctx.sub(s).dirty() for s in ctx.substate)):
2773 changed = '+'
2781 changed = '+'
2782 fm.data(changed=changed)
2783
2784 hexoutput = [hexfunc(p.node()) for p in parents]
2774 if default or id:
2785 if default or id:
2775 output = ["%s%s" %
2786 output = ["%s%s" % ('+'.join(hexoutput), changed)]
2776 ('+'.join([hexfunc(p.node()) for p in parents]), changed)]
2787 fm.data(id="%s%s" % ('+'.join(hexoutput), changed))
2788
2777 if num:
2789 if num:
2778 output.append("%s%s" %
2790 numoutput = ["%d" % p.rev() for p in parents]
2779 ('+'.join(["%d" % p.rev() for p in parents]), changed))
2791 output.append("%s%s" % ('+'.join(numoutput), changed))
2792
2793 for i, p in enumerate(parents):
2794 fn = fm.nested('p%d' % (i + 1))
2795 fn.startitem()
2796 fn.data(rev=p.rev())
2797 fn.data(node=p.hex())
2798 fn.end()
2780 else:
2799 else:
2800 hexoutput = hexfunc(ctx.node())
2781 if default or id:
2801 if default or id:
2782 output = [hexfunc(ctx.node())]
2802 output = [hexoutput]
2803 fm.data(id=hexoutput)
2804
2783 if num:
2805 if num:
2784 output.append(pycompat.bytestr(ctx.rev()))
2806 output.append(pycompat.bytestr(ctx.rev()))
2785 taglist = ctx.tags()
2807 taglist = ctx.tags()
@@ -2808,7 +2830,13 def identify(ui, repo, source=None, rev=
2808 if bookmarks:
2830 if bookmarks:
2809 output.extend(ctx.bookmarks())
2831 output.extend(ctx.bookmarks())
2810
2832
2811 ui.write("%s\n" % ' '.join(output))
2833 fm.data(node=ctx.hex())
2834 fm.data(branch=ctx.branch())
2835 fm.data(tags=fm.formatlist(taglist, name='tag', sep=':'))
2836 fm.data(bookmarks=fm.formatlist(ctx.bookmarks(), name='bookmark'))
2837
2838 fm.plain("%s\n" % ' '.join(output))
2839 fm.end()
2812
2840
2813 @command('import|patch',
2841 @command('import|patch',
2814 [('p', 'strip', 1,
2842 [('p', 'strip', 1,
@@ -295,7 +295,7 Show all commands + options
295 grep: print0, all, text, follow, ignore-case, files-with-matches, line-number, rev, user, date, template, include, exclude
295 grep: print0, all, text, follow, ignore-case, files-with-matches, line-number, rev, user, date, template, include, exclude
296 heads: rev, topo, active, closed, style, template
296 heads: rev, topo, active, closed, style, template
297 help: extension, command, keyword, system
297 help: extension, command, keyword, system
298 identify: rev, num, id, branch, tags, bookmarks, ssh, remotecmd, insecure
298 identify: rev, num, id, branch, tags, bookmarks, ssh, remotecmd, insecure, template
299 import: strip, base, edit, force, no-commit, bypass, partial, exact, prefix, import-branch, message, logfile, date, user, similarity
299 import: strip, base, edit, force, no-commit, bypass, partial, exact, prefix, import-branch, message, logfile, date, user, similarity
300 incoming: force, newest-first, bundle, rev, bookmarks, branch, patch, git, limit, no-merges, stat, graph, style, template, ssh, remotecmd, insecure, subrepos
300 incoming: force, newest-first, bundle, rev, bookmarks, branch, patch, git, limit, no-merges, stat, graph, style, template, ssh, remotecmd, insecure, subrepos
301 locate: rev, print0, fullpath, include, exclude
301 locate: rev, print0, fullpath, include, exclude
@@ -95,7 +95,7 pretxncommit and commit hooks can see bo
95 test generic hooks
95 test generic hooks
96
96
97 $ hg id
97 $ hg id
98 pre-identify hook: HG_ARGS=id HG_HOOKNAME=pre-identify HG_HOOKTYPE=pre-identify HG_OPTS={'bookmarks': None, 'branch': None, 'id': None, 'insecure': None, 'num': None, 'remotecmd': '', 'rev': '', 'ssh': '', 'tags': None} HG_PATS=[]
98 pre-identify hook: HG_ARGS=id HG_HOOKNAME=pre-identify HG_HOOKTYPE=pre-identify HG_OPTS={'bookmarks': None, 'branch': None, 'id': None, 'insecure': None, 'num': None, 'remotecmd': '', 'rev': '', 'ssh': '', 'tags': None, 'template': ''} HG_PATS=[]
99 abort: pre-identify hook exited with status 1
99 abort: pre-identify hook exited with status 1
100 [255]
100 [255]
101 $ hg cat b
101 $ hg cat b
@@ -43,12 +43,36 with options
43 cb9a9f314b8b
43 cb9a9f314b8b
44 $ hg id -n -t -b -i
44 $ hg id -n -t -b -i
45 cb9a9f314b8b 0 default tip
45 cb9a9f314b8b 0 default tip
46 $ hg id -Tjson
47 [
48 {
49 "bookmarks": [],
50 "branch": "default",
51 "changed": "",
52 "id": "cb9a9f314b8b",
53 "node": "ffffffffffffffffffffffffffffffffffffffff",
54 "p1": [{"node": "cb9a9f314b8b07ba71012fcdbc544b5a4d82ff5b", "rev": 0}],
55 "tags": ["tip"]
56 }
57 ]
46
58
47 with modifications
59 with modifications
48
60
49 $ echo b > a
61 $ echo b > a
50 $ hg id -n -t -b -i
62 $ hg id -n -t -b -i
51 cb9a9f314b8b+ 0+ default tip
63 cb9a9f314b8b+ 0+ default tip
64 $ hg id -Tjson
65 [
66 {
67 "bookmarks": [],
68 "branch": "default",
69 "changed": "+",
70 "id": "cb9a9f314b8b+",
71 "node": "ffffffffffffffffffffffffffffffffffffffff",
72 "p1": [{"node": "cb9a9f314b8b07ba71012fcdbc544b5a4d82ff5b", "rev": 0}],
73 "tags": ["tip"]
74 }
75 ]
52
76
53 other local repo
77 other local repo
54
78
@@ -49,6 +49,19 Should succeed:
49 $ hg merge 2
49 $ hg merge 2
50 0 files updated, 1 files merged, 0 files removed, 0 files unresolved
50 0 files updated, 1 files merged, 0 files removed, 0 files unresolved
51 (branch merge, don't forget to commit)
51 (branch merge, don't forget to commit)
52 $ hg id -Tjson
53 [
54 {
55 "bookmarks": [],
56 "branch": "default",
57 "changed": "+",
58 "id": "f25cbe84d8b3+2d95304fed5d+",
59 "node": "ffffffffffffffffffffffffffffffffffffffff",
60 "p1": [{"node": "f25cbe84d8b320e298e7703f18a25a3959518c23", "rev": 4}],
61 "p2": [{"node": "2d95304fed5d89bc9d70b2a0d02f0d567469c3ab", "rev": 2}],
62 "tags": ["tip"]
63 }
64 ]
52 $ hg commit -mm1
65 $ hg commit -mm1
53
66
54 Should succeed - 2 heads:
67 Should succeed - 2 heads:
@@ -65,6 +78,17 Should succeed - 2 heads:
65 (branch merge, don't forget to commit)
78 (branch merge, don't forget to commit)
66 $ hg commit -mm2
79 $ hg commit -mm2
67
80
81 $ hg id -r 1 -Tjson
82 [
83 {
84 "bookmarks": [],
85 "branch": "default",
86 "id": "1846eede8b68",
87 "node": "1846eede8b6886d8cc8a88c96a687b7fe8f3b9d1",
88 "tags": []
89 }
90 ]
91
68 Should fail because at tip:
92 Should fail because at tip:
69
93
70 $ hg merge
94 $ hg merge
General Comments 0
You need to be logged in to leave comments. Login now