2005-06-07 12:00:56 +04:00
|
|
|
# Minimal support for git commands on an hg repository
|
|
|
|
#
|
2006-08-12 23:30:02 +04:00
|
|
|
# Copyright 2005, 2006 Chris Mason <mason@suse.com>
|
2005-06-07 12:00:56 +04:00
|
|
|
#
|
|
|
|
# This software may be used and distributed according to the terms
|
|
|
|
# of the GNU General Public License, incorporated herein by reference.
|
|
|
|
|
2005-09-20 02:59:17 +04:00
|
|
|
import time, sys, signal, os
|
2005-09-14 04:33:10 +04:00
|
|
|
from mercurial import hg, mdiff, fancyopts, commands, ui, util
|
|
|
|
|
|
|
|
def dodiff(fp, ui, repo, node1, node2, files=None, match=util.always,
|
|
|
|
changes=None, text=False):
|
|
|
|
def date(c):
|
2005-09-24 06:38:21 +04:00
|
|
|
return time.asctime(time.gmtime(c[2][0]))
|
2005-09-14 04:33:10 +04:00
|
|
|
|
|
|
|
if not changes:
|
2006-01-12 15:35:09 +03:00
|
|
|
changes = repo.changes(node1, node2, files, match=match)
|
2006-01-12 15:58:36 +03:00
|
|
|
modified, added, removed, deleted, unknown = changes
|
2005-09-14 04:33:10 +04:00
|
|
|
if files:
|
2006-01-18 18:55:05 +03:00
|
|
|
modified, added, removed = map(lambda x: filterfiles(files, x),
|
2006-01-12 15:35:09 +03:00
|
|
|
(modified, added, removed))
|
2005-09-14 04:33:10 +04:00
|
|
|
|
2006-01-12 15:35:09 +03:00
|
|
|
if not modified and not added and not removed:
|
2005-09-14 04:33:10 +04:00
|
|
|
return
|
|
|
|
|
|
|
|
if node2:
|
|
|
|
change = repo.changelog.read(node2)
|
|
|
|
mmap2 = repo.manifest.read(change[0])
|
|
|
|
date2 = date(change)
|
|
|
|
def read(f):
|
|
|
|
return repo.file(f).read(mmap2[f])
|
|
|
|
else:
|
|
|
|
date2 = time.asctime()
|
|
|
|
if not node1:
|
|
|
|
node1 = repo.dirstate.parents()[0]
|
|
|
|
def read(f):
|
|
|
|
return repo.wfile(f).read()
|
|
|
|
|
|
|
|
change = repo.changelog.read(node1)
|
|
|
|
mmap = repo.manifest.read(change[0])
|
|
|
|
date1 = date(change)
|
|
|
|
|
2006-01-12 15:35:09 +03:00
|
|
|
for f in modified:
|
2005-09-14 04:33:10 +04:00
|
|
|
to = None
|
|
|
|
if f in mmap:
|
|
|
|
to = repo.file(f).read(mmap[f])
|
|
|
|
tn = read(f)
|
|
|
|
fp.write("diff --git a/%s b/%s\n" % (f, f))
|
|
|
|
fp.write(mdiff.unidiff(to, date1, tn, date2, f, None, text=text))
|
2006-01-12 15:35:09 +03:00
|
|
|
for f in added:
|
2005-09-14 04:33:10 +04:00
|
|
|
to = None
|
|
|
|
tn = read(f)
|
|
|
|
fp.write("diff --git /dev/null b/%s\n" % (f))
|
|
|
|
fp.write(mdiff.unidiff(to, date1, tn, date2, f, None, text=text))
|
2006-01-12 15:35:09 +03:00
|
|
|
for f in removed:
|
2005-09-14 04:33:10 +04:00
|
|
|
to = repo.file(f).read(mmap[f])
|
|
|
|
tn = None
|
|
|
|
fp.write("diff --git a/%s /dev/null\n" % (f))
|
|
|
|
fp.write(mdiff.unidiff(to, date1, tn, date2, f, None, text=text))
|
|
|
|
|
|
|
|
def difftree(ui, repo, node1=None, node2=None, **opts):
|
|
|
|
"""diff trees from two commits"""
|
|
|
|
def __difftree(repo, node1, node2):
|
2005-06-15 02:04:15 +04:00
|
|
|
def date(c):
|
2005-09-24 06:38:21 +04:00
|
|
|
return time.asctime(time.gmtime(c[2][0]))
|
2005-06-15 02:04:15 +04:00
|
|
|
|
|
|
|
if node2:
|
|
|
|
change = repo.changelog.read(node2)
|
|
|
|
mmap2 = repo.manifest.read(change[0])
|
2006-01-12 15:58:36 +03:00
|
|
|
modified, added, removed, deleted, unknown = repo.changes(node1, node2)
|
2005-06-15 02:04:15 +04:00
|
|
|
def read(f): return repo.file(f).read(mmap2[f])
|
|
|
|
date2 = date(change)
|
|
|
|
else:
|
|
|
|
date2 = time.asctime()
|
2006-01-12 15:58:36 +03:00
|
|
|
modified, added, removed, deleted, unknown = repo.changes(node1)
|
2005-06-15 02:04:15 +04:00
|
|
|
if not node1:
|
|
|
|
node1 = repo.dirstate.parents()[0]
|
|
|
|
def read(f): return file(os.path.join(repo.root, f)).read()
|
|
|
|
|
|
|
|
change = repo.changelog.read(node1)
|
|
|
|
mmap = repo.manifest.read(change[0])
|
|
|
|
date1 = date(change)
|
|
|
|
empty = "0" * 40;
|
|
|
|
|
2006-01-12 15:35:09 +03:00
|
|
|
for f in modified:
|
2005-06-15 02:04:15 +04:00
|
|
|
# TODO get file permissions
|
2005-09-21 09:56:19 +04:00
|
|
|
print ":100664 100664 %s %s M\t%s\t%s" % (hg.hex(mmap[f]),
|
2005-06-15 02:04:15 +04:00
|
|
|
hg.hex(mmap2[f]), f, f)
|
2006-01-12 15:35:09 +03:00
|
|
|
for f in added:
|
[PATCH] Using monotone-viz/git-viz with mercurial
-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA1
[PATCH] Using monotone-viz/git-viz with mercurial
From: Vincent Danjean <vdanjean.ml@free.fr>
monotone-viz is a small GTK+ application that visualizes monotone
ancestry graphs. Its home page is:
http://oandrieu.nerim.net/monotone-viz/
As monotone and git are similar, the author adapted the 0.9 version to
display git ancestry graphs and call it git-viz. I cannot see any link
from the homepage, but looking in the archive of git ML, it can be found
here:
http://oandrieu.nerim.net/monotone-viz/git-viz-0.1.tar.gz
I few days ago, I adapted it so that it works with the last versions
of git/cogito. Patches and package are available here:
http://dept-info.labri.fr/~danjean/deb.html#git-viz
Today, I patched hgit so that it respects the output of git-diff-tree,
I added git-{diff-tree,cat-file,rev-list,rev-tree} that call hgit (2
lines scripts), and added the script 'hg-viz'.
hg-viz create a .git directory and store the SHA1 of the tip in
.git/HEAD and then call my git-viz.
All these modifications are in the attached patch.
I try it in the mercurial repository. After applying the patch, you
just have to add the contrib directory in your PATH and call hg-viz.
An example of what we can see is on my web page (probably not for a
long time) : http://dept-info.labri.fr/~danjean/temp/hg-viz.png
Vincent
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.4.0 (GNU/Linux)
iD8DBQFCuM50ywK+sNU5EO8RAtlvAJ425JJI9chCdSi8D+R2Af/vJEOUpACffC9e
fxjJ3umBkffj5g86jWaRGZ0=
=LwA2
-----END PGP SIGNATURE-----
2005-06-22 06:35:32 +04:00
|
|
|
print ":000000 100664 %s %s N\t%s\t%s" % (empty, hg.hex(mmap2[f]), f, f)
|
2006-01-12 15:35:09 +03:00
|
|
|
for f in removed:
|
[PATCH] Using monotone-viz/git-viz with mercurial
-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA1
[PATCH] Using monotone-viz/git-viz with mercurial
From: Vincent Danjean <vdanjean.ml@free.fr>
monotone-viz is a small GTK+ application that visualizes monotone
ancestry graphs. Its home page is:
http://oandrieu.nerim.net/monotone-viz/
As monotone and git are similar, the author adapted the 0.9 version to
display git ancestry graphs and call it git-viz. I cannot see any link
from the homepage, but looking in the archive of git ML, it can be found
here:
http://oandrieu.nerim.net/monotone-viz/git-viz-0.1.tar.gz
I few days ago, I adapted it so that it works with the last versions
of git/cogito. Patches and package are available here:
http://dept-info.labri.fr/~danjean/deb.html#git-viz
Today, I patched hgit so that it respects the output of git-diff-tree,
I added git-{diff-tree,cat-file,rev-list,rev-tree} that call hgit (2
lines scripts), and added the script 'hg-viz'.
hg-viz create a .git directory and store the SHA1 of the tip in
.git/HEAD and then call my git-viz.
All these modifications are in the attached patch.
I try it in the mercurial repository. After applying the patch, you
just have to add the contrib directory in your PATH and call hg-viz.
An example of what we can see is on my web page (probably not for a
long time) : http://dept-info.labri.fr/~danjean/temp/hg-viz.png
Vincent
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.4.0 (GNU/Linux)
iD8DBQFCuM50ywK+sNU5EO8RAtlvAJ425JJI9chCdSi8D+R2Af/vJEOUpACffC9e
fxjJ3umBkffj5g86jWaRGZ0=
=LwA2
-----END PGP SIGNATURE-----
2005-06-22 06:35:32 +04:00
|
|
|
print ":100664 000000 %s %s D\t%s\t%s" % (hg.hex(mmap[f]), empty, f, f)
|
2005-06-07 12:00:56 +04:00
|
|
|
##
|
|
|
|
|
2005-09-14 04:33:10 +04:00
|
|
|
while True:
|
|
|
|
if opts['stdin']:
|
|
|
|
try:
|
|
|
|
line = raw_input().split(' ')
|
|
|
|
node1 = line[0]
|
|
|
|
if len(line) > 1:
|
|
|
|
node2 = line[1]
|
|
|
|
else:
|
|
|
|
node2 = None
|
|
|
|
except EOFError:
|
|
|
|
break
|
|
|
|
node1 = repo.lookup(node1)
|
|
|
|
if node2:
|
|
|
|
node2 = repo.lookup(node2)
|
|
|
|
else:
|
|
|
|
node2 = node1
|
|
|
|
node1 = repo.changelog.parents(node1)[0]
|
|
|
|
if opts['patch']:
|
|
|
|
if opts['pretty']:
|
|
|
|
catcommit(repo, node2, "")
|
|
|
|
dodiff(sys.stdout, ui, repo, node1, node2)
|
|
|
|
else:
|
|
|
|
__difftree(repo, node1, node2)
|
|
|
|
if not opts['stdin']:
|
|
|
|
break
|
2005-06-07 12:00:56 +04:00
|
|
|
|
2005-09-14 04:33:10 +04:00
|
|
|
def catcommit(repo, n, prefix, changes=None):
|
2005-06-07 12:00:56 +04:00
|
|
|
nlprefix = '\n' + prefix;
|
|
|
|
(p1, p2) = repo.changelog.parents(n)
|
|
|
|
(h, h1, h2) = map(hg.hex, (n, p1, p2))
|
|
|
|
(i1, i2) = map(repo.changelog.rev, (p1, p2))
|
2005-09-14 04:33:10 +04:00
|
|
|
if not changes:
|
|
|
|
changes = repo.changelog.read(n)
|
|
|
|
print "tree %s" % (hg.hex(changes[0]))
|
|
|
|
if i1 != -1: print "parent %s" % (h1)
|
|
|
|
if i2 != -1: print "parent %s" % (h2)
|
2005-09-24 06:38:21 +04:00
|
|
|
date_ar = changes[2]
|
2005-06-07 12:00:56 +04:00
|
|
|
date = int(float(date_ar[0]))
|
2005-09-14 04:33:10 +04:00
|
|
|
lines = changes[4].splitlines()
|
2006-06-30 23:35:22 +04:00
|
|
|
if lines and lines[-1].startswith('committer:'):
|
2005-09-14 04:33:10 +04:00
|
|
|
committer = lines[-1].split(': ')[1].rstrip()
|
|
|
|
else:
|
2006-03-15 05:19:16 +03:00
|
|
|
committer = changes[1]
|
2005-09-21 09:56:19 +04:00
|
|
|
|
2005-09-14 04:33:10 +04:00
|
|
|
print "author %s %s %s" % (changes[1], date, date_ar[1])
|
2006-03-15 05:19:16 +03:00
|
|
|
print "committer %s %s %s" % (committer, date, date_ar[1])
|
2005-09-14 04:33:10 +04:00
|
|
|
print ""
|
2005-06-07 12:00:56 +04:00
|
|
|
if prefix != "":
|
2005-06-15 02:04:15 +04:00
|
|
|
print "%s%s" % (prefix, changes[4].replace('\n', nlprefix).strip())
|
2005-06-07 12:00:56 +04:00
|
|
|
else:
|
2005-06-15 02:04:15 +04:00
|
|
|
print changes[4]
|
2005-09-14 04:33:10 +04:00
|
|
|
if prefix:
|
|
|
|
sys.stdout.write('\0')
|
2005-06-07 12:00:56 +04:00
|
|
|
|
2005-09-14 04:33:10 +04:00
|
|
|
def base(ui, repo, node1, node2):
|
|
|
|
"""Output common ancestor information"""
|
|
|
|
node1 = repo.lookup(node1)
|
|
|
|
node2 = repo.lookup(node2)
|
|
|
|
n = repo.changelog.ancestor(node1, node2)
|
|
|
|
print hg.hex(n)
|
2005-06-07 12:00:56 +04:00
|
|
|
|
2005-09-14 04:33:10 +04:00
|
|
|
def catfile(ui, repo, type=None, r=None, **opts):
|
|
|
|
"""cat a specific revision"""
|
2005-06-07 12:00:56 +04:00
|
|
|
# in stdin mode, every line except the commit is prefixed with two
|
|
|
|
# spaces. This way the our caller can find the commit without magic
|
|
|
|
# strings
|
|
|
|
#
|
|
|
|
prefix = ""
|
2005-09-14 04:33:10 +04:00
|
|
|
if opts['stdin']:
|
2005-06-15 02:04:15 +04:00
|
|
|
try:
|
|
|
|
(type, r) = raw_input().split(' ');
|
2005-09-14 04:33:10 +04:00
|
|
|
prefix = " "
|
2005-06-15 02:04:15 +04:00
|
|
|
except EOFError:
|
|
|
|
return
|
2005-06-07 12:00:56 +04:00
|
|
|
|
|
|
|
else:
|
2005-09-14 04:33:10 +04:00
|
|
|
if not type or not r:
|
|
|
|
ui.warn("cat-file: type or revision not supplied\n")
|
|
|
|
commands.help_(ui, 'cat-file')
|
2005-06-07 12:00:56 +04:00
|
|
|
|
|
|
|
while r:
|
2005-06-15 02:04:15 +04:00
|
|
|
if type != "commit":
|
|
|
|
sys.stderr.write("aborting hg cat-file only understands commits\n")
|
|
|
|
sys.exit(1);
|
2005-07-19 21:41:08 +04:00
|
|
|
n = repo.lookup(r)
|
2005-06-15 02:04:15 +04:00
|
|
|
catcommit(repo, n, prefix)
|
2005-09-14 04:33:10 +04:00
|
|
|
if opts['stdin']:
|
2005-06-15 02:04:15 +04:00
|
|
|
try:
|
|
|
|
(type, r) = raw_input().split(' ');
|
|
|
|
except EOFError:
|
|
|
|
break
|
|
|
|
else:
|
|
|
|
break
|
2005-06-07 12:00:56 +04:00
|
|
|
|
|
|
|
# git rev-tree is a confusing thing. You can supply a number of
|
|
|
|
# commit sha1s on the command line, and it walks the commit history
|
|
|
|
# telling you which commits are reachable from the supplied ones via
|
|
|
|
# a bitmask based on arg position.
|
|
|
|
# you can specify a commit to stop at by starting the sha1 with ^
|
2005-09-14 04:33:10 +04:00
|
|
|
def revtree(args, repo, full="tree", maxnr=0, parents=False):
|
|
|
|
def chlogwalk():
|
|
|
|
ch = repo.changelog
|
|
|
|
count = ch.count()
|
|
|
|
i = count
|
|
|
|
l = [0] * 100
|
|
|
|
chunk = 100
|
|
|
|
while True:
|
|
|
|
if chunk > i:
|
|
|
|
chunk = i
|
|
|
|
i = 0
|
|
|
|
else:
|
|
|
|
i -= chunk
|
|
|
|
|
|
|
|
for x in xrange(0, chunk):
|
|
|
|
if i + x >= count:
|
|
|
|
l[chunk - x:] = [0] * (chunk - x)
|
|
|
|
break
|
|
|
|
if full != None:
|
|
|
|
l[x] = ch.read(ch.node(i + x))
|
|
|
|
else:
|
|
|
|
l[x] = 1
|
|
|
|
for x in xrange(chunk-1, -1, -1):
|
|
|
|
if l[x] != 0:
|
|
|
|
yield (i + x, full != None and l[x] or None)
|
|
|
|
if i == 0:
|
|
|
|
break
|
2005-09-21 09:56:19 +04:00
|
|
|
|
2005-06-07 12:00:56 +04:00
|
|
|
# calculate and return the reachability bitmask for sha
|
|
|
|
def is_reachable(ar, reachable, sha):
|
2005-06-15 02:04:15 +04:00
|
|
|
if len(ar) == 0:
|
|
|
|
return 1
|
|
|
|
mask = 0
|
|
|
|
for i in range(len(ar)):
|
|
|
|
if sha in reachable[i]:
|
|
|
|
mask |= 1 << i
|
2005-06-07 12:00:56 +04:00
|
|
|
|
2005-06-15 02:04:15 +04:00
|
|
|
return mask
|
2005-06-07 12:00:56 +04:00
|
|
|
|
|
|
|
reachable = []
|
|
|
|
stop_sha1 = []
|
|
|
|
want_sha1 = []
|
2005-06-15 22:04:42 +04:00
|
|
|
count = 0
|
2005-06-07 12:00:56 +04:00
|
|
|
|
|
|
|
# figure out which commits they are asking for and which ones they
|
|
|
|
# want us to stop on
|
|
|
|
for i in range(len(args)):
|
2005-07-19 21:41:08 +04:00
|
|
|
if args[i].startswith('^'):
|
|
|
|
s = repo.lookup(args[i][1:])
|
|
|
|
stop_sha1.append(s)
|
2005-06-15 02:04:15 +04:00
|
|
|
want_sha1.append(s)
|
|
|
|
elif args[i] != 'HEAD':
|
2005-07-19 21:41:08 +04:00
|
|
|
want_sha1.append(repo.lookup(args[i]))
|
2005-06-15 22:04:42 +04:00
|
|
|
|
2005-06-07 12:00:56 +04:00
|
|
|
# calculate the graph for the supplied commits
|
|
|
|
for i in range(len(want_sha1)):
|
2005-06-15 02:04:15 +04:00
|
|
|
reachable.append({});
|
2005-07-19 21:41:08 +04:00
|
|
|
n = want_sha1[i];
|
2005-06-15 02:04:15 +04:00
|
|
|
visit = [n];
|
|
|
|
reachable[i][n] = 1
|
|
|
|
while visit:
|
|
|
|
n = visit.pop(0)
|
|
|
|
if n in stop_sha1:
|
2005-09-14 22:14:20 +04:00
|
|
|
continue
|
2005-06-15 02:04:15 +04:00
|
|
|
for p in repo.changelog.parents(n):
|
|
|
|
if p not in reachable[i]:
|
|
|
|
reachable[i][p] = 1
|
|
|
|
visit.append(p)
|
|
|
|
if p in stop_sha1:
|
2005-09-14 22:14:20 +04:00
|
|
|
continue
|
2005-06-15 22:04:42 +04:00
|
|
|
|
2005-06-07 12:00:56 +04:00
|
|
|
# walk the repository looking for commits that are in our
|
|
|
|
# reachability graph
|
2005-09-14 04:33:10 +04:00
|
|
|
#for i in range(repo.changelog.count()-1, -1, -1):
|
|
|
|
for i, changes in chlogwalk():
|
2005-06-15 02:04:15 +04:00
|
|
|
n = repo.changelog.node(i)
|
|
|
|
mask = is_reachable(want_sha1, reachable, n)
|
|
|
|
if mask:
|
2005-09-14 04:33:10 +04:00
|
|
|
parentstr = ""
|
|
|
|
if parents:
|
|
|
|
pp = repo.changelog.parents(n)
|
|
|
|
if pp[0] != hg.nullid:
|
|
|
|
parentstr += " " + hg.hex(pp[0])
|
|
|
|
if pp[1] != hg.nullid:
|
|
|
|
parentstr += " " + hg.hex(pp[1])
|
2005-06-15 22:04:42 +04:00
|
|
|
if not full:
|
2005-09-14 04:33:10 +04:00
|
|
|
print hg.hex(n) + parentstr
|
2005-06-15 22:04:42 +04:00
|
|
|
elif full is "commit":
|
2005-09-14 04:33:10 +04:00
|
|
|
print hg.hex(n) + parentstr
|
|
|
|
catcommit(repo, n, ' ', changes)
|
2005-06-15 22:04:42 +04:00
|
|
|
else:
|
|
|
|
(p1, p2) = repo.changelog.parents(n)
|
|
|
|
(h, h1, h2) = map(hg.hex, (n, p1, p2))
|
|
|
|
(i1, i2) = map(repo.changelog.rev, (p1, p2))
|
|
|
|
|
2005-09-24 06:38:21 +04:00
|
|
|
date = changes[2][0]
|
2005-06-15 22:04:42 +04:00
|
|
|
print "%s %s:%s" % (date, h, mask),
|
|
|
|
mask = is_reachable(want_sha1, reachable, p1)
|
|
|
|
if i1 != -1 and mask > 0:
|
|
|
|
print "%s:%s " % (h1, mask),
|
|
|
|
mask = is_reachable(want_sha1, reachable, p2)
|
|
|
|
if i2 != -1 and mask > 0:
|
|
|
|
print "%s:%s " % (h2, mask),
|
|
|
|
print ""
|
|
|
|
if maxnr and count >= maxnr:
|
|
|
|
break
|
|
|
|
count += 1
|
2005-06-07 12:00:56 +04:00
|
|
|
|
|
|
|
# git rev-list tries to order things by date, and has the ability to stop
|
|
|
|
# at a given commit without walking the whole repo. TODO add the stop
|
|
|
|
# parameter
|
2005-09-14 04:33:10 +04:00
|
|
|
def revlist(ui, repo, *revs, **opts):
|
|
|
|
"""print revisions"""
|
|
|
|
if opts['header']:
|
2005-06-15 22:04:42 +04:00
|
|
|
full = "commit"
|
|
|
|
else:
|
|
|
|
full = None
|
2005-09-14 04:33:10 +04:00
|
|
|
copy = [x for x in revs]
|
|
|
|
revtree(copy, repo, full, opts['max_count'], opts['parents'])
|
2005-06-07 12:00:56 +04:00
|
|
|
|
2005-09-20 02:59:17 +04:00
|
|
|
def view(ui, repo, *etc):
|
|
|
|
"start interactive history viewer"
|
|
|
|
os.chdir(repo.root)
|
2005-09-24 06:41:45 +04:00
|
|
|
os.system(ui.config("hgk", "path", "hgk") + " " + " ".join(etc))
|
2005-09-20 02:59:17 +04:00
|
|
|
|
2005-09-14 04:33:10 +04:00
|
|
|
cmdtable = {
|
2005-09-20 02:59:17 +04:00
|
|
|
"view": (view, [], 'hg view'),
|
|
|
|
"debug-diff-tree": (difftree, [('p', 'patch', None, 'generate patch'),
|
2005-09-14 04:33:10 +04:00
|
|
|
('r', 'recursive', None, 'recursive'),
|
|
|
|
('P', 'pretty', None, 'pretty'),
|
|
|
|
('s', 'stdin', None, 'stdin'),
|
|
|
|
('C', 'copy', None, 'detect copies'),
|
|
|
|
('S', 'search', "", 'search')],
|
|
|
|
"hg git-diff-tree [options] node1 node2"),
|
2005-09-20 02:59:17 +04:00
|
|
|
"debug-cat-file": (catfile, [('s', 'stdin', None, 'stdin')],
|
|
|
|
"hg debug-cat-file [options] type file"),
|
|
|
|
"debug-merge-base": (base, [], "hg debug-merge-base node node"),
|
|
|
|
"debug-rev-list": (revlist, [('H', 'header', None, 'header'),
|
2005-09-14 04:33:10 +04:00
|
|
|
('t', 'topo-order', None, 'topo-order'),
|
|
|
|
('p', 'parents', None, 'parents'),
|
|
|
|
('n', 'max-count', 0, 'max-count')],
|
2005-09-20 02:59:17 +04:00
|
|
|
"hg debug-rev-list [options] revs"),
|
2005-09-14 04:33:10 +04:00
|
|
|
}
|