##// END OF EJS Templates
debugindex: add --format flag to allow debugging parentdelta...
Matt Mackall -
r12893:15ca4bfe stable
parent child Browse files
Show More
@@ -1,4500 +1,4519
1 # commands.py - command processing for mercurial
1 # commands.py - command processing for mercurial
2 #
2 #
3 # Copyright 2005-2007 Matt Mackall <mpm@selenic.com>
3 # Copyright 2005-2007 Matt Mackall <mpm@selenic.com>
4 #
4 #
5 # This software may be used and distributed according to the terms of the
5 # This software may be used and distributed according to the terms of the
6 # GNU General Public License version 2 or any later version.
6 # GNU General Public License version 2 or any later version.
7
7
8 from node import hex, nullid, nullrev, short
8 from node import hex, nullid, nullrev, short
9 from lock import release
9 from lock import release
10 from i18n import _, gettext
10 from i18n import _, gettext
11 import os, re, sys, difflib, time, tempfile
11 import os, re, sys, difflib, time, tempfile
12 import hg, util, revlog, extensions, copies, error
12 import hg, util, revlog, extensions, copies, error
13 import patch, help, mdiff, url, encoding, templatekw, discovery
13 import patch, help, mdiff, url, encoding, templatekw, discovery
14 import archival, changegroup, cmdutil, sshserver, hbisect, hgweb, hgweb.server
14 import archival, changegroup, cmdutil, sshserver, hbisect, hgweb, hgweb.server
15 import merge as mergemod
15 import merge as mergemod
16 import minirst, revset
16 import minirst, revset
17 import dagparser
17 import dagparser
18
18
19 # Commands start here, listed alphabetically
19 # Commands start here, listed alphabetically
20
20
21 def add(ui, repo, *pats, **opts):
21 def add(ui, repo, *pats, **opts):
22 """add the specified files on the next commit
22 """add the specified files on the next commit
23
23
24 Schedule files to be version controlled and added to the
24 Schedule files to be version controlled and added to the
25 repository.
25 repository.
26
26
27 The files will be added to the repository at the next commit. To
27 The files will be added to the repository at the next commit. To
28 undo an add before that, see :hg:`forget`.
28 undo an add before that, see :hg:`forget`.
29
29
30 If no names are given, add all files to the repository.
30 If no names are given, add all files to the repository.
31
31
32 .. container:: verbose
32 .. container:: verbose
33
33
34 An example showing how new (unknown) files are added
34 An example showing how new (unknown) files are added
35 automatically by :hg:`add`::
35 automatically by :hg:`add`::
36
36
37 $ ls
37 $ ls
38 foo.c
38 foo.c
39 $ hg status
39 $ hg status
40 ? foo.c
40 ? foo.c
41 $ hg add
41 $ hg add
42 adding foo.c
42 adding foo.c
43 $ hg status
43 $ hg status
44 A foo.c
44 A foo.c
45
45
46 Returns 0 if all files are successfully added.
46 Returns 0 if all files are successfully added.
47 """
47 """
48
48
49 m = cmdutil.match(repo, pats, opts)
49 m = cmdutil.match(repo, pats, opts)
50 rejected = cmdutil.add(ui, repo, m, opts.get('dry_run'),
50 rejected = cmdutil.add(ui, repo, m, opts.get('dry_run'),
51 opts.get('subrepos'), prefix="")
51 opts.get('subrepos'), prefix="")
52 return rejected and 1 or 0
52 return rejected and 1 or 0
53
53
54 def addremove(ui, repo, *pats, **opts):
54 def addremove(ui, repo, *pats, **opts):
55 """add all new files, delete all missing files
55 """add all new files, delete all missing files
56
56
57 Add all new files and remove all missing files from the
57 Add all new files and remove all missing files from the
58 repository.
58 repository.
59
59
60 New files are ignored if they match any of the patterns in
60 New files are ignored if they match any of the patterns in
61 .hgignore. As with add, these changes take effect at the next
61 .hgignore. As with add, these changes take effect at the next
62 commit.
62 commit.
63
63
64 Use the -s/--similarity option to detect renamed files. With a
64 Use the -s/--similarity option to detect renamed files. With a
65 parameter greater than 0, this compares every removed file with
65 parameter greater than 0, this compares every removed file with
66 every added file and records those similar enough as renames. This
66 every added file and records those similar enough as renames. This
67 option takes a percentage between 0 (disabled) and 100 (files must
67 option takes a percentage between 0 (disabled) and 100 (files must
68 be identical) as its parameter. Detecting renamed files this way
68 be identical) as its parameter. Detecting renamed files this way
69 can be expensive. After using this option, :hg:`status -C` can be
69 can be expensive. After using this option, :hg:`status -C` can be
70 used to check which files were identified as moved or renamed.
70 used to check which files were identified as moved or renamed.
71
71
72 Returns 0 if all files are successfully added.
72 Returns 0 if all files are successfully added.
73 """
73 """
74 try:
74 try:
75 sim = float(opts.get('similarity') or 100)
75 sim = float(opts.get('similarity') or 100)
76 except ValueError:
76 except ValueError:
77 raise util.Abort(_('similarity must be a number'))
77 raise util.Abort(_('similarity must be a number'))
78 if sim < 0 or sim > 100:
78 if sim < 0 or sim > 100:
79 raise util.Abort(_('similarity must be between 0 and 100'))
79 raise util.Abort(_('similarity must be between 0 and 100'))
80 return cmdutil.addremove(repo, pats, opts, similarity=sim / 100.0)
80 return cmdutil.addremove(repo, pats, opts, similarity=sim / 100.0)
81
81
82 def annotate(ui, repo, *pats, **opts):
82 def annotate(ui, repo, *pats, **opts):
83 """show changeset information by line for each file
83 """show changeset information by line for each file
84
84
85 List changes in files, showing the revision id responsible for
85 List changes in files, showing the revision id responsible for
86 each line
86 each line
87
87
88 This command is useful for discovering when a change was made and
88 This command is useful for discovering when a change was made and
89 by whom.
89 by whom.
90
90
91 Without the -a/--text option, annotate will avoid processing files
91 Without the -a/--text option, annotate will avoid processing files
92 it detects as binary. With -a, annotate will annotate the file
92 it detects as binary. With -a, annotate will annotate the file
93 anyway, although the results will probably be neither useful
93 anyway, although the results will probably be neither useful
94 nor desirable.
94 nor desirable.
95
95
96 Returns 0 on success.
96 Returns 0 on success.
97 """
97 """
98 if opts.get('follow'):
98 if opts.get('follow'):
99 # --follow is deprecated and now just an alias for -f/--file
99 # --follow is deprecated and now just an alias for -f/--file
100 # to mimic the behavior of Mercurial before version 1.5
100 # to mimic the behavior of Mercurial before version 1.5
101 opts['file'] = 1
101 opts['file'] = 1
102
102
103 datefunc = ui.quiet and util.shortdate or util.datestr
103 datefunc = ui.quiet and util.shortdate or util.datestr
104 getdate = util.cachefunc(lambda x: datefunc(x[0].date()))
104 getdate = util.cachefunc(lambda x: datefunc(x[0].date()))
105
105
106 if not pats:
106 if not pats:
107 raise util.Abort(_('at least one filename or pattern is required'))
107 raise util.Abort(_('at least one filename or pattern is required'))
108
108
109 opmap = [('user', lambda x: ui.shortuser(x[0].user())),
109 opmap = [('user', lambda x: ui.shortuser(x[0].user())),
110 ('number', lambda x: str(x[0].rev())),
110 ('number', lambda x: str(x[0].rev())),
111 ('changeset', lambda x: short(x[0].node())),
111 ('changeset', lambda x: short(x[0].node())),
112 ('date', getdate),
112 ('date', getdate),
113 ('file', lambda x: x[0].path()),
113 ('file', lambda x: x[0].path()),
114 ]
114 ]
115
115
116 if (not opts.get('user') and not opts.get('changeset')
116 if (not opts.get('user') and not opts.get('changeset')
117 and not opts.get('date') and not opts.get('file')):
117 and not opts.get('date') and not opts.get('file')):
118 opts['number'] = 1
118 opts['number'] = 1
119
119
120 linenumber = opts.get('line_number') is not None
120 linenumber = opts.get('line_number') is not None
121 if linenumber and (not opts.get('changeset')) and (not opts.get('number')):
121 if linenumber and (not opts.get('changeset')) and (not opts.get('number')):
122 raise util.Abort(_('at least one of -n/-c is required for -l'))
122 raise util.Abort(_('at least one of -n/-c is required for -l'))
123
123
124 funcmap = [func for op, func in opmap if opts.get(op)]
124 funcmap = [func for op, func in opmap if opts.get(op)]
125 if linenumber:
125 if linenumber:
126 lastfunc = funcmap[-1]
126 lastfunc = funcmap[-1]
127 funcmap[-1] = lambda x: "%s:%s" % (lastfunc(x), x[1])
127 funcmap[-1] = lambda x: "%s:%s" % (lastfunc(x), x[1])
128
128
129 ctx = repo[opts.get('rev')]
129 ctx = repo[opts.get('rev')]
130 m = cmdutil.match(repo, pats, opts)
130 m = cmdutil.match(repo, pats, opts)
131 follow = not opts.get('no_follow')
131 follow = not opts.get('no_follow')
132 for abs in ctx.walk(m):
132 for abs in ctx.walk(m):
133 fctx = ctx[abs]
133 fctx = ctx[abs]
134 if not opts.get('text') and util.binary(fctx.data()):
134 if not opts.get('text') and util.binary(fctx.data()):
135 ui.write(_("%s: binary file\n") % ((pats and m.rel(abs)) or abs))
135 ui.write(_("%s: binary file\n") % ((pats and m.rel(abs)) or abs))
136 continue
136 continue
137
137
138 lines = fctx.annotate(follow=follow, linenumber=linenumber)
138 lines = fctx.annotate(follow=follow, linenumber=linenumber)
139 pieces = []
139 pieces = []
140
140
141 for f in funcmap:
141 for f in funcmap:
142 l = [f(n) for n, dummy in lines]
142 l = [f(n) for n, dummy in lines]
143 if l:
143 if l:
144 sized = [(x, encoding.colwidth(x)) for x in l]
144 sized = [(x, encoding.colwidth(x)) for x in l]
145 ml = max([w for x, w in sized])
145 ml = max([w for x, w in sized])
146 pieces.append(["%s%s" % (' ' * (ml - w), x) for x, w in sized])
146 pieces.append(["%s%s" % (' ' * (ml - w), x) for x, w in sized])
147
147
148 if pieces:
148 if pieces:
149 for p, l in zip(zip(*pieces), lines):
149 for p, l in zip(zip(*pieces), lines):
150 ui.write("%s: %s" % (" ".join(p), l[1]))
150 ui.write("%s: %s" % (" ".join(p), l[1]))
151
151
152 def archive(ui, repo, dest, **opts):
152 def archive(ui, repo, dest, **opts):
153 '''create an unversioned archive of a repository revision
153 '''create an unversioned archive of a repository revision
154
154
155 By default, the revision used is the parent of the working
155 By default, the revision used is the parent of the working
156 directory; use -r/--rev to specify a different revision.
156 directory; use -r/--rev to specify a different revision.
157
157
158 The archive type is automatically detected based on file
158 The archive type is automatically detected based on file
159 extension (or override using -t/--type).
159 extension (or override using -t/--type).
160
160
161 Valid types are:
161 Valid types are:
162
162
163 :``files``: a directory full of files (default)
163 :``files``: a directory full of files (default)
164 :``tar``: tar archive, uncompressed
164 :``tar``: tar archive, uncompressed
165 :``tbz2``: tar archive, compressed using bzip2
165 :``tbz2``: tar archive, compressed using bzip2
166 :``tgz``: tar archive, compressed using gzip
166 :``tgz``: tar archive, compressed using gzip
167 :``uzip``: zip archive, uncompressed
167 :``uzip``: zip archive, uncompressed
168 :``zip``: zip archive, compressed using deflate
168 :``zip``: zip archive, compressed using deflate
169
169
170 The exact name of the destination archive or directory is given
170 The exact name of the destination archive or directory is given
171 using a format string; see :hg:`help export` for details.
171 using a format string; see :hg:`help export` for details.
172
172
173 Each member added to an archive file has a directory prefix
173 Each member added to an archive file has a directory prefix
174 prepended. Use -p/--prefix to specify a format string for the
174 prepended. Use -p/--prefix to specify a format string for the
175 prefix. The default is the basename of the archive, with suffixes
175 prefix. The default is the basename of the archive, with suffixes
176 removed.
176 removed.
177
177
178 Returns 0 on success.
178 Returns 0 on success.
179 '''
179 '''
180
180
181 ctx = repo[opts.get('rev')]
181 ctx = repo[opts.get('rev')]
182 if not ctx:
182 if not ctx:
183 raise util.Abort(_('no working directory: please specify a revision'))
183 raise util.Abort(_('no working directory: please specify a revision'))
184 node = ctx.node()
184 node = ctx.node()
185 dest = cmdutil.make_filename(repo, dest, node)
185 dest = cmdutil.make_filename(repo, dest, node)
186 if os.path.realpath(dest) == repo.root:
186 if os.path.realpath(dest) == repo.root:
187 raise util.Abort(_('repository root cannot be destination'))
187 raise util.Abort(_('repository root cannot be destination'))
188
188
189 kind = opts.get('type') or archival.guesskind(dest) or 'files'
189 kind = opts.get('type') or archival.guesskind(dest) or 'files'
190 prefix = opts.get('prefix')
190 prefix = opts.get('prefix')
191
191
192 if dest == '-':
192 if dest == '-':
193 if kind == 'files':
193 if kind == 'files':
194 raise util.Abort(_('cannot archive plain files to stdout'))
194 raise util.Abort(_('cannot archive plain files to stdout'))
195 dest = sys.stdout
195 dest = sys.stdout
196 if not prefix:
196 if not prefix:
197 prefix = os.path.basename(repo.root) + '-%h'
197 prefix = os.path.basename(repo.root) + '-%h'
198
198
199 prefix = cmdutil.make_filename(repo, prefix, node)
199 prefix = cmdutil.make_filename(repo, prefix, node)
200 matchfn = cmdutil.match(repo, [], opts)
200 matchfn = cmdutil.match(repo, [], opts)
201 archival.archive(repo, dest, node, kind, not opts.get('no_decode'),
201 archival.archive(repo, dest, node, kind, not opts.get('no_decode'),
202 matchfn, prefix, subrepos=opts.get('subrepos'))
202 matchfn, prefix, subrepos=opts.get('subrepos'))
203
203
204 def backout(ui, repo, node=None, rev=None, **opts):
204 def backout(ui, repo, node=None, rev=None, **opts):
205 '''reverse effect of earlier changeset
205 '''reverse effect of earlier changeset
206
206
207 The backout command merges the reverse effect of the reverted
207 The backout command merges the reverse effect of the reverted
208 changeset into the working directory.
208 changeset into the working directory.
209
209
210 With the --merge option, it first commits the reverted changes
210 With the --merge option, it first commits the reverted changes
211 as a new changeset. This new changeset is a child of the reverted
211 as a new changeset. This new changeset is a child of the reverted
212 changeset.
212 changeset.
213 The --merge option remembers the parent of the working directory
213 The --merge option remembers the parent of the working directory
214 before starting the backout, then merges the new head with that
214 before starting the backout, then merges the new head with that
215 changeset afterwards.
215 changeset afterwards.
216 This will result in an explicit merge in the history.
216 This will result in an explicit merge in the history.
217
217
218 If you backout a changeset other than the original parent of the
218 If you backout a changeset other than the original parent of the
219 working directory, the result of this merge is not committed,
219 working directory, the result of this merge is not committed,
220 as with a normal merge. Otherwise, no merge is needed and the
220 as with a normal merge. Otherwise, no merge is needed and the
221 commit is automatic.
221 commit is automatic.
222
222
223 Note that the default behavior (without --merge) has changed in
223 Note that the default behavior (without --merge) has changed in
224 version 1.7. To restore the previous default behavior, use
224 version 1.7. To restore the previous default behavior, use
225 :hg:`backout --merge` and then :hg:`update --clean .` to get rid of
225 :hg:`backout --merge` and then :hg:`update --clean .` to get rid of
226 the ongoing merge.
226 the ongoing merge.
227
227
228 See :hg:`help dates` for a list of formats valid for -d/--date.
228 See :hg:`help dates` for a list of formats valid for -d/--date.
229
229
230 Returns 0 on success.
230 Returns 0 on success.
231 '''
231 '''
232 if rev and node:
232 if rev and node:
233 raise util.Abort(_("please specify just one revision"))
233 raise util.Abort(_("please specify just one revision"))
234
234
235 if not rev:
235 if not rev:
236 rev = node
236 rev = node
237
237
238 if not rev:
238 if not rev:
239 raise util.Abort(_("please specify a revision to backout"))
239 raise util.Abort(_("please specify a revision to backout"))
240
240
241 date = opts.get('date')
241 date = opts.get('date')
242 if date:
242 if date:
243 opts['date'] = util.parsedate(date)
243 opts['date'] = util.parsedate(date)
244
244
245 cmdutil.bail_if_changed(repo)
245 cmdutil.bail_if_changed(repo)
246 node = repo.lookup(rev)
246 node = repo.lookup(rev)
247
247
248 op1, op2 = repo.dirstate.parents()
248 op1, op2 = repo.dirstate.parents()
249 a = repo.changelog.ancestor(op1, node)
249 a = repo.changelog.ancestor(op1, node)
250 if a != node:
250 if a != node:
251 raise util.Abort(_('cannot backout change on a different branch'))
251 raise util.Abort(_('cannot backout change on a different branch'))
252
252
253 p1, p2 = repo.changelog.parents(node)
253 p1, p2 = repo.changelog.parents(node)
254 if p1 == nullid:
254 if p1 == nullid:
255 raise util.Abort(_('cannot backout a change with no parents'))
255 raise util.Abort(_('cannot backout a change with no parents'))
256 if p2 != nullid:
256 if p2 != nullid:
257 if not opts.get('parent'):
257 if not opts.get('parent'):
258 raise util.Abort(_('cannot backout a merge changeset without '
258 raise util.Abort(_('cannot backout a merge changeset without '
259 '--parent'))
259 '--parent'))
260 p = repo.lookup(opts['parent'])
260 p = repo.lookup(opts['parent'])
261 if p not in (p1, p2):
261 if p not in (p1, p2):
262 raise util.Abort(_('%s is not a parent of %s') %
262 raise util.Abort(_('%s is not a parent of %s') %
263 (short(p), short(node)))
263 (short(p), short(node)))
264 parent = p
264 parent = p
265 else:
265 else:
266 if opts.get('parent'):
266 if opts.get('parent'):
267 raise util.Abort(_('cannot use --parent on non-merge changeset'))
267 raise util.Abort(_('cannot use --parent on non-merge changeset'))
268 parent = p1
268 parent = p1
269
269
270 # the backout should appear on the same branch
270 # the backout should appear on the same branch
271 branch = repo.dirstate.branch()
271 branch = repo.dirstate.branch()
272 hg.clean(repo, node, show_stats=False)
272 hg.clean(repo, node, show_stats=False)
273 repo.dirstate.setbranch(branch)
273 repo.dirstate.setbranch(branch)
274 revert_opts = opts.copy()
274 revert_opts = opts.copy()
275 revert_opts['date'] = None
275 revert_opts['date'] = None
276 revert_opts['all'] = True
276 revert_opts['all'] = True
277 revert_opts['rev'] = hex(parent)
277 revert_opts['rev'] = hex(parent)
278 revert_opts['no_backup'] = None
278 revert_opts['no_backup'] = None
279 revert(ui, repo, **revert_opts)
279 revert(ui, repo, **revert_opts)
280 if not opts.get('merge') and op1 != node:
280 if not opts.get('merge') and op1 != node:
281 try:
281 try:
282 ui.setconfig('ui', 'forcemerge', opts.get('tool', ''))
282 ui.setconfig('ui', 'forcemerge', opts.get('tool', ''))
283 return hg.update(repo, op1)
283 return hg.update(repo, op1)
284 finally:
284 finally:
285 ui.setconfig('ui', 'forcemerge', '')
285 ui.setconfig('ui', 'forcemerge', '')
286
286
287 commit_opts = opts.copy()
287 commit_opts = opts.copy()
288 commit_opts['addremove'] = False
288 commit_opts['addremove'] = False
289 if not commit_opts['message'] and not commit_opts['logfile']:
289 if not commit_opts['message'] and not commit_opts['logfile']:
290 # we don't translate commit messages
290 # we don't translate commit messages
291 commit_opts['message'] = "Backed out changeset %s" % short(node)
291 commit_opts['message'] = "Backed out changeset %s" % short(node)
292 commit_opts['force_editor'] = True
292 commit_opts['force_editor'] = True
293 commit(ui, repo, **commit_opts)
293 commit(ui, repo, **commit_opts)
294 def nice(node):
294 def nice(node):
295 return '%d:%s' % (repo.changelog.rev(node), short(node))
295 return '%d:%s' % (repo.changelog.rev(node), short(node))
296 ui.status(_('changeset %s backs out changeset %s\n') %
296 ui.status(_('changeset %s backs out changeset %s\n') %
297 (nice(repo.changelog.tip()), nice(node)))
297 (nice(repo.changelog.tip()), nice(node)))
298 if opts.get('merge') and op1 != node:
298 if opts.get('merge') and op1 != node:
299 hg.clean(repo, op1, show_stats=False)
299 hg.clean(repo, op1, show_stats=False)
300 ui.status(_('merging with changeset %s\n')
300 ui.status(_('merging with changeset %s\n')
301 % nice(repo.changelog.tip()))
301 % nice(repo.changelog.tip()))
302 try:
302 try:
303 ui.setconfig('ui', 'forcemerge', opts.get('tool', ''))
303 ui.setconfig('ui', 'forcemerge', opts.get('tool', ''))
304 return hg.merge(repo, hex(repo.changelog.tip()))
304 return hg.merge(repo, hex(repo.changelog.tip()))
305 finally:
305 finally:
306 ui.setconfig('ui', 'forcemerge', '')
306 ui.setconfig('ui', 'forcemerge', '')
307 return 0
307 return 0
308
308
309 def bisect(ui, repo, rev=None, extra=None, command=None,
309 def bisect(ui, repo, rev=None, extra=None, command=None,
310 reset=None, good=None, bad=None, skip=None, noupdate=None):
310 reset=None, good=None, bad=None, skip=None, noupdate=None):
311 """subdivision search of changesets
311 """subdivision search of changesets
312
312
313 This command helps to find changesets which introduce problems. To
313 This command helps to find changesets which introduce problems. To
314 use, mark the earliest changeset you know exhibits the problem as
314 use, mark the earliest changeset you know exhibits the problem as
315 bad, then mark the latest changeset which is free from the problem
315 bad, then mark the latest changeset which is free from the problem
316 as good. Bisect will update your working directory to a revision
316 as good. Bisect will update your working directory to a revision
317 for testing (unless the -U/--noupdate option is specified). Once
317 for testing (unless the -U/--noupdate option is specified). Once
318 you have performed tests, mark the working directory as good or
318 you have performed tests, mark the working directory as good or
319 bad, and bisect will either update to another candidate changeset
319 bad, and bisect will either update to another candidate changeset
320 or announce that it has found the bad revision.
320 or announce that it has found the bad revision.
321
321
322 As a shortcut, you can also use the revision argument to mark a
322 As a shortcut, you can also use the revision argument to mark a
323 revision as good or bad without checking it out first.
323 revision as good or bad without checking it out first.
324
324
325 If you supply a command, it will be used for automatic bisection.
325 If you supply a command, it will be used for automatic bisection.
326 Its exit status will be used to mark revisions as good or bad:
326 Its exit status will be used to mark revisions as good or bad:
327 status 0 means good, 125 means to skip the revision, 127
327 status 0 means good, 125 means to skip the revision, 127
328 (command not found) will abort the bisection, and any other
328 (command not found) will abort the bisection, and any other
329 non-zero exit status means the revision is bad.
329 non-zero exit status means the revision is bad.
330
330
331 Returns 0 on success.
331 Returns 0 on success.
332 """
332 """
333 def print_result(nodes, good):
333 def print_result(nodes, good):
334 displayer = cmdutil.show_changeset(ui, repo, {})
334 displayer = cmdutil.show_changeset(ui, repo, {})
335 if len(nodes) == 1:
335 if len(nodes) == 1:
336 # narrowed it down to a single revision
336 # narrowed it down to a single revision
337 if good:
337 if good:
338 ui.write(_("The first good revision is:\n"))
338 ui.write(_("The first good revision is:\n"))
339 else:
339 else:
340 ui.write(_("The first bad revision is:\n"))
340 ui.write(_("The first bad revision is:\n"))
341 displayer.show(repo[nodes[0]])
341 displayer.show(repo[nodes[0]])
342 parents = repo[nodes[0]].parents()
342 parents = repo[nodes[0]].parents()
343 if len(parents) > 1:
343 if len(parents) > 1:
344 side = good and state['bad'] or state['good']
344 side = good and state['bad'] or state['good']
345 num = len(set(i.node() for i in parents) & set(side))
345 num = len(set(i.node() for i in parents) & set(side))
346 if num == 1:
346 if num == 1:
347 common = parents[0].ancestor(parents[1])
347 common = parents[0].ancestor(parents[1])
348 ui.write(_('Not all ancestors of this changeset have been'
348 ui.write(_('Not all ancestors of this changeset have been'
349 ' checked.\nTo check the other ancestors, start'
349 ' checked.\nTo check the other ancestors, start'
350 ' from the common ancestor, %s.\n' % common))
350 ' from the common ancestor, %s.\n' % common))
351 else:
351 else:
352 # multiple possible revisions
352 # multiple possible revisions
353 if good:
353 if good:
354 ui.write(_("Due to skipped revisions, the first "
354 ui.write(_("Due to skipped revisions, the first "
355 "good revision could be any of:\n"))
355 "good revision could be any of:\n"))
356 else:
356 else:
357 ui.write(_("Due to skipped revisions, the first "
357 ui.write(_("Due to skipped revisions, the first "
358 "bad revision could be any of:\n"))
358 "bad revision could be any of:\n"))
359 for n in nodes:
359 for n in nodes:
360 displayer.show(repo[n])
360 displayer.show(repo[n])
361 displayer.close()
361 displayer.close()
362
362
363 def check_state(state, interactive=True):
363 def check_state(state, interactive=True):
364 if not state['good'] or not state['bad']:
364 if not state['good'] or not state['bad']:
365 if (good or bad or skip or reset) and interactive:
365 if (good or bad or skip or reset) and interactive:
366 return
366 return
367 if not state['good']:
367 if not state['good']:
368 raise util.Abort(_('cannot bisect (no known good revisions)'))
368 raise util.Abort(_('cannot bisect (no known good revisions)'))
369 else:
369 else:
370 raise util.Abort(_('cannot bisect (no known bad revisions)'))
370 raise util.Abort(_('cannot bisect (no known bad revisions)'))
371 return True
371 return True
372
372
373 # backward compatibility
373 # backward compatibility
374 if rev in "good bad reset init".split():
374 if rev in "good bad reset init".split():
375 ui.warn(_("(use of 'hg bisect <cmd>' is deprecated)\n"))
375 ui.warn(_("(use of 'hg bisect <cmd>' is deprecated)\n"))
376 cmd, rev, extra = rev, extra, None
376 cmd, rev, extra = rev, extra, None
377 if cmd == "good":
377 if cmd == "good":
378 good = True
378 good = True
379 elif cmd == "bad":
379 elif cmd == "bad":
380 bad = True
380 bad = True
381 else:
381 else:
382 reset = True
382 reset = True
383 elif extra or good + bad + skip + reset + bool(command) > 1:
383 elif extra or good + bad + skip + reset + bool(command) > 1:
384 raise util.Abort(_('incompatible arguments'))
384 raise util.Abort(_('incompatible arguments'))
385
385
386 if reset:
386 if reset:
387 p = repo.join("bisect.state")
387 p = repo.join("bisect.state")
388 if os.path.exists(p):
388 if os.path.exists(p):
389 os.unlink(p)
389 os.unlink(p)
390 return
390 return
391
391
392 state = hbisect.load_state(repo)
392 state = hbisect.load_state(repo)
393
393
394 if command:
394 if command:
395 changesets = 1
395 changesets = 1
396 try:
396 try:
397 while changesets:
397 while changesets:
398 # update state
398 # update state
399 status = util.system(command)
399 status = util.system(command)
400 if status == 125:
400 if status == 125:
401 transition = "skip"
401 transition = "skip"
402 elif status == 0:
402 elif status == 0:
403 transition = "good"
403 transition = "good"
404 # status < 0 means process was killed
404 # status < 0 means process was killed
405 elif status == 127:
405 elif status == 127:
406 raise util.Abort(_("failed to execute %s") % command)
406 raise util.Abort(_("failed to execute %s") % command)
407 elif status < 0:
407 elif status < 0:
408 raise util.Abort(_("%s killed") % command)
408 raise util.Abort(_("%s killed") % command)
409 else:
409 else:
410 transition = "bad"
410 transition = "bad"
411 ctx = repo[rev or '.']
411 ctx = repo[rev or '.']
412 state[transition].append(ctx.node())
412 state[transition].append(ctx.node())
413 ui.status(_('Changeset %d:%s: %s\n') % (ctx, ctx, transition))
413 ui.status(_('Changeset %d:%s: %s\n') % (ctx, ctx, transition))
414 check_state(state, interactive=False)
414 check_state(state, interactive=False)
415 # bisect
415 # bisect
416 nodes, changesets, good = hbisect.bisect(repo.changelog, state)
416 nodes, changesets, good = hbisect.bisect(repo.changelog, state)
417 # update to next check
417 # update to next check
418 cmdutil.bail_if_changed(repo)
418 cmdutil.bail_if_changed(repo)
419 hg.clean(repo, nodes[0], show_stats=False)
419 hg.clean(repo, nodes[0], show_stats=False)
420 finally:
420 finally:
421 hbisect.save_state(repo, state)
421 hbisect.save_state(repo, state)
422 print_result(nodes, good)
422 print_result(nodes, good)
423 return
423 return
424
424
425 # update state
425 # update state
426
426
427 if rev:
427 if rev:
428 nodes = [repo.lookup(i) for i in cmdutil.revrange(repo, [rev])]
428 nodes = [repo.lookup(i) for i in cmdutil.revrange(repo, [rev])]
429 else:
429 else:
430 nodes = [repo.lookup('.')]
430 nodes = [repo.lookup('.')]
431
431
432 if good or bad or skip:
432 if good or bad or skip:
433 if good:
433 if good:
434 state['good'] += nodes
434 state['good'] += nodes
435 elif bad:
435 elif bad:
436 state['bad'] += nodes
436 state['bad'] += nodes
437 elif skip:
437 elif skip:
438 state['skip'] += nodes
438 state['skip'] += nodes
439 hbisect.save_state(repo, state)
439 hbisect.save_state(repo, state)
440
440
441 if not check_state(state):
441 if not check_state(state):
442 return
442 return
443
443
444 # actually bisect
444 # actually bisect
445 nodes, changesets, good = hbisect.bisect(repo.changelog, state)
445 nodes, changesets, good = hbisect.bisect(repo.changelog, state)
446 if changesets == 0:
446 if changesets == 0:
447 print_result(nodes, good)
447 print_result(nodes, good)
448 else:
448 else:
449 assert len(nodes) == 1 # only a single node can be tested next
449 assert len(nodes) == 1 # only a single node can be tested next
450 node = nodes[0]
450 node = nodes[0]
451 # compute the approximate number of remaining tests
451 # compute the approximate number of remaining tests
452 tests, size = 0, 2
452 tests, size = 0, 2
453 while size <= changesets:
453 while size <= changesets:
454 tests, size = tests + 1, size * 2
454 tests, size = tests + 1, size * 2
455 rev = repo.changelog.rev(node)
455 rev = repo.changelog.rev(node)
456 ui.write(_("Testing changeset %d:%s "
456 ui.write(_("Testing changeset %d:%s "
457 "(%d changesets remaining, ~%d tests)\n")
457 "(%d changesets remaining, ~%d tests)\n")
458 % (rev, short(node), changesets, tests))
458 % (rev, short(node), changesets, tests))
459 if not noupdate:
459 if not noupdate:
460 cmdutil.bail_if_changed(repo)
460 cmdutil.bail_if_changed(repo)
461 return hg.clean(repo, node)
461 return hg.clean(repo, node)
462
462
463 def branch(ui, repo, label=None, **opts):
463 def branch(ui, repo, label=None, **opts):
464 """set or show the current branch name
464 """set or show the current branch name
465
465
466 With no argument, show the current branch name. With one argument,
466 With no argument, show the current branch name. With one argument,
467 set the working directory branch name (the branch will not exist
467 set the working directory branch name (the branch will not exist
468 in the repository until the next commit). Standard practice
468 in the repository until the next commit). Standard practice
469 recommends that primary development take place on the 'default'
469 recommends that primary development take place on the 'default'
470 branch.
470 branch.
471
471
472 Unless -f/--force is specified, branch will not let you set a
472 Unless -f/--force is specified, branch will not let you set a
473 branch name that already exists, even if it's inactive.
473 branch name that already exists, even if it's inactive.
474
474
475 Use -C/--clean to reset the working directory branch to that of
475 Use -C/--clean to reset the working directory branch to that of
476 the parent of the working directory, negating a previous branch
476 the parent of the working directory, negating a previous branch
477 change.
477 change.
478
478
479 Use the command :hg:`update` to switch to an existing branch. Use
479 Use the command :hg:`update` to switch to an existing branch. Use
480 :hg:`commit --close-branch` to mark this branch as closed.
480 :hg:`commit --close-branch` to mark this branch as closed.
481
481
482 Returns 0 on success.
482 Returns 0 on success.
483 """
483 """
484
484
485 if opts.get('clean'):
485 if opts.get('clean'):
486 label = repo[None].parents()[0].branch()
486 label = repo[None].parents()[0].branch()
487 repo.dirstate.setbranch(label)
487 repo.dirstate.setbranch(label)
488 ui.status(_('reset working directory to branch %s\n') % label)
488 ui.status(_('reset working directory to branch %s\n') % label)
489 elif label:
489 elif label:
490 utflabel = encoding.fromlocal(label)
490 utflabel = encoding.fromlocal(label)
491 if not opts.get('force') and utflabel in repo.branchtags():
491 if not opts.get('force') and utflabel in repo.branchtags():
492 if label not in [p.branch() for p in repo.parents()]:
492 if label not in [p.branch() for p in repo.parents()]:
493 raise util.Abort(_('a branch of the same name already exists'
493 raise util.Abort(_('a branch of the same name already exists'
494 " (use 'hg update' to switch to it)"))
494 " (use 'hg update' to switch to it)"))
495 repo.dirstate.setbranch(utflabel)
495 repo.dirstate.setbranch(utflabel)
496 ui.status(_('marked working directory as branch %s\n') % label)
496 ui.status(_('marked working directory as branch %s\n') % label)
497 else:
497 else:
498 ui.write("%s\n" % encoding.tolocal(repo.dirstate.branch()))
498 ui.write("%s\n" % encoding.tolocal(repo.dirstate.branch()))
499
499
500 def branches(ui, repo, active=False, closed=False):
500 def branches(ui, repo, active=False, closed=False):
501 """list repository named branches
501 """list repository named branches
502
502
503 List the repository's named branches, indicating which ones are
503 List the repository's named branches, indicating which ones are
504 inactive. If -c/--closed is specified, also list branches which have
504 inactive. If -c/--closed is specified, also list branches which have
505 been marked closed (see :hg:`commit --close-branch`).
505 been marked closed (see :hg:`commit --close-branch`).
506
506
507 If -a/--active is specified, only show active branches. A branch
507 If -a/--active is specified, only show active branches. A branch
508 is considered active if it contains repository heads.
508 is considered active if it contains repository heads.
509
509
510 Use the command :hg:`update` to switch to an existing branch.
510 Use the command :hg:`update` to switch to an existing branch.
511
511
512 Returns 0.
512 Returns 0.
513 """
513 """
514
514
515 hexfunc = ui.debugflag and hex or short
515 hexfunc = ui.debugflag and hex or short
516 activebranches = [repo[n].branch() for n in repo.heads()]
516 activebranches = [repo[n].branch() for n in repo.heads()]
517 def testactive(tag, node):
517 def testactive(tag, node):
518 realhead = tag in activebranches
518 realhead = tag in activebranches
519 open = node in repo.branchheads(tag, closed=False)
519 open = node in repo.branchheads(tag, closed=False)
520 return realhead and open
520 return realhead and open
521 branches = sorted([(testactive(tag, node), repo.changelog.rev(node), tag)
521 branches = sorted([(testactive(tag, node), repo.changelog.rev(node), tag)
522 for tag, node in repo.branchtags().items()],
522 for tag, node in repo.branchtags().items()],
523 reverse=True)
523 reverse=True)
524
524
525 for isactive, node, tag in branches:
525 for isactive, node, tag in branches:
526 if (not active) or isactive:
526 if (not active) or isactive:
527 encodedtag = encoding.tolocal(tag)
527 encodedtag = encoding.tolocal(tag)
528 if ui.quiet:
528 if ui.quiet:
529 ui.write("%s\n" % encodedtag)
529 ui.write("%s\n" % encodedtag)
530 else:
530 else:
531 hn = repo.lookup(node)
531 hn = repo.lookup(node)
532 if isactive:
532 if isactive:
533 label = 'branches.active'
533 label = 'branches.active'
534 notice = ''
534 notice = ''
535 elif hn not in repo.branchheads(tag, closed=False):
535 elif hn not in repo.branchheads(tag, closed=False):
536 if not closed:
536 if not closed:
537 continue
537 continue
538 label = 'branches.closed'
538 label = 'branches.closed'
539 notice = _(' (closed)')
539 notice = _(' (closed)')
540 else:
540 else:
541 label = 'branches.inactive'
541 label = 'branches.inactive'
542 notice = _(' (inactive)')
542 notice = _(' (inactive)')
543 if tag == repo.dirstate.branch():
543 if tag == repo.dirstate.branch():
544 label = 'branches.current'
544 label = 'branches.current'
545 rev = str(node).rjust(31 - encoding.colwidth(encodedtag))
545 rev = str(node).rjust(31 - encoding.colwidth(encodedtag))
546 rev = ui.label('%s:%s' % (rev, hexfunc(hn)), 'log.changeset')
546 rev = ui.label('%s:%s' % (rev, hexfunc(hn)), 'log.changeset')
547 encodedtag = ui.label(encodedtag, label)
547 encodedtag = ui.label(encodedtag, label)
548 ui.write("%s %s%s\n" % (encodedtag, rev, notice))
548 ui.write("%s %s%s\n" % (encodedtag, rev, notice))
549
549
550 def bundle(ui, repo, fname, dest=None, **opts):
550 def bundle(ui, repo, fname, dest=None, **opts):
551 """create a changegroup file
551 """create a changegroup file
552
552
553 Generate a compressed changegroup file collecting changesets not
553 Generate a compressed changegroup file collecting changesets not
554 known to be in another repository.
554 known to be in another repository.
555
555
556 If you omit the destination repository, then hg assumes the
556 If you omit the destination repository, then hg assumes the
557 destination will have all the nodes you specify with --base
557 destination will have all the nodes you specify with --base
558 parameters. To create a bundle containing all changesets, use
558 parameters. To create a bundle containing all changesets, use
559 -a/--all (or --base null).
559 -a/--all (or --base null).
560
560
561 You can change compression method with the -t/--type option.
561 You can change compression method with the -t/--type option.
562 The available compression methods are: none, bzip2, and
562 The available compression methods are: none, bzip2, and
563 gzip (by default, bundles are compressed using bzip2).
563 gzip (by default, bundles are compressed using bzip2).
564
564
565 The bundle file can then be transferred using conventional means
565 The bundle file can then be transferred using conventional means
566 and applied to another repository with the unbundle or pull
566 and applied to another repository with the unbundle or pull
567 command. This is useful when direct push and pull are not
567 command. This is useful when direct push and pull are not
568 available or when exporting an entire repository is undesirable.
568 available or when exporting an entire repository is undesirable.
569
569
570 Applying bundles preserves all changeset contents including
570 Applying bundles preserves all changeset contents including
571 permissions, copy/rename information, and revision history.
571 permissions, copy/rename information, and revision history.
572
572
573 Returns 0 on success, 1 if no changes found.
573 Returns 0 on success, 1 if no changes found.
574 """
574 """
575 revs = opts.get('rev') or None
575 revs = opts.get('rev') or None
576 if opts.get('all'):
576 if opts.get('all'):
577 base = ['null']
577 base = ['null']
578 else:
578 else:
579 base = opts.get('base')
579 base = opts.get('base')
580 if base:
580 if base:
581 if dest:
581 if dest:
582 raise util.Abort(_("--base is incompatible with specifying "
582 raise util.Abort(_("--base is incompatible with specifying "
583 "a destination"))
583 "a destination"))
584 base = [repo.lookup(rev) for rev in base]
584 base = [repo.lookup(rev) for rev in base]
585 # create the right base
585 # create the right base
586 # XXX: nodesbetween / changegroup* should be "fixed" instead
586 # XXX: nodesbetween / changegroup* should be "fixed" instead
587 o = []
587 o = []
588 has = set((nullid,))
588 has = set((nullid,))
589 for n in base:
589 for n in base:
590 has.update(repo.changelog.reachable(n))
590 has.update(repo.changelog.reachable(n))
591 if revs:
591 if revs:
592 revs = [repo.lookup(rev) for rev in revs]
592 revs = [repo.lookup(rev) for rev in revs]
593 visit = revs[:]
593 visit = revs[:]
594 has.difference_update(visit)
594 has.difference_update(visit)
595 else:
595 else:
596 visit = repo.changelog.heads()
596 visit = repo.changelog.heads()
597 seen = {}
597 seen = {}
598 while visit:
598 while visit:
599 n = visit.pop(0)
599 n = visit.pop(0)
600 parents = [p for p in repo.changelog.parents(n) if p not in has]
600 parents = [p for p in repo.changelog.parents(n) if p not in has]
601 if len(parents) == 0:
601 if len(parents) == 0:
602 if n not in has:
602 if n not in has:
603 o.append(n)
603 o.append(n)
604 else:
604 else:
605 for p in parents:
605 for p in parents:
606 if p not in seen:
606 if p not in seen:
607 seen[p] = 1
607 seen[p] = 1
608 visit.append(p)
608 visit.append(p)
609 else:
609 else:
610 dest = ui.expandpath(dest or 'default-push', dest or 'default')
610 dest = ui.expandpath(dest or 'default-push', dest or 'default')
611 dest, branches = hg.parseurl(dest, opts.get('branch'))
611 dest, branches = hg.parseurl(dest, opts.get('branch'))
612 other = hg.repository(hg.remoteui(repo, opts), dest)
612 other = hg.repository(hg.remoteui(repo, opts), dest)
613 revs, checkout = hg.addbranchrevs(repo, other, branches, revs)
613 revs, checkout = hg.addbranchrevs(repo, other, branches, revs)
614 if revs:
614 if revs:
615 revs = [repo.lookup(rev) for rev in revs]
615 revs = [repo.lookup(rev) for rev in revs]
616 o = discovery.findoutgoing(repo, other, force=opts.get('force'))
616 o = discovery.findoutgoing(repo, other, force=opts.get('force'))
617
617
618 if not o:
618 if not o:
619 ui.status(_("no changes found\n"))
619 ui.status(_("no changes found\n"))
620 return 1
620 return 1
621
621
622 if revs:
622 if revs:
623 cg = repo.changegroupsubset(o, revs, 'bundle')
623 cg = repo.changegroupsubset(o, revs, 'bundle')
624 else:
624 else:
625 cg = repo.changegroup(o, 'bundle')
625 cg = repo.changegroup(o, 'bundle')
626
626
627 bundletype = opts.get('type', 'bzip2').lower()
627 bundletype = opts.get('type', 'bzip2').lower()
628 btypes = {'none': 'HG10UN', 'bzip2': 'HG10BZ', 'gzip': 'HG10GZ'}
628 btypes = {'none': 'HG10UN', 'bzip2': 'HG10BZ', 'gzip': 'HG10GZ'}
629 bundletype = btypes.get(bundletype)
629 bundletype = btypes.get(bundletype)
630 if bundletype not in changegroup.bundletypes:
630 if bundletype not in changegroup.bundletypes:
631 raise util.Abort(_('unknown bundle type specified with --type'))
631 raise util.Abort(_('unknown bundle type specified with --type'))
632
632
633 changegroup.writebundle(cg, fname, bundletype)
633 changegroup.writebundle(cg, fname, bundletype)
634
634
635 def cat(ui, repo, file1, *pats, **opts):
635 def cat(ui, repo, file1, *pats, **opts):
636 """output the current or given revision of files
636 """output the current or given revision of files
637
637
638 Print the specified files as they were at the given revision. If
638 Print the specified files as they were at the given revision. If
639 no revision is given, the parent of the working directory is used,
639 no revision is given, the parent of the working directory is used,
640 or tip if no revision is checked out.
640 or tip if no revision is checked out.
641
641
642 Output may be to a file, in which case the name of the file is
642 Output may be to a file, in which case the name of the file is
643 given using a format string. The formatting rules are the same as
643 given using a format string. The formatting rules are the same as
644 for the export command, with the following additions:
644 for the export command, with the following additions:
645
645
646 :``%s``: basename of file being printed
646 :``%s``: basename of file being printed
647 :``%d``: dirname of file being printed, or '.' if in repository root
647 :``%d``: dirname of file being printed, or '.' if in repository root
648 :``%p``: root-relative path name of file being printed
648 :``%p``: root-relative path name of file being printed
649
649
650 Returns 0 on success.
650 Returns 0 on success.
651 """
651 """
652 ctx = cmdutil.revsingle(repo, opts.get('rev'))
652 ctx = cmdutil.revsingle(repo, opts.get('rev'))
653 err = 1
653 err = 1
654 m = cmdutil.match(repo, (file1,) + pats, opts)
654 m = cmdutil.match(repo, (file1,) + pats, opts)
655 for abs in ctx.walk(m):
655 for abs in ctx.walk(m):
656 fp = cmdutil.make_file(repo, opts.get('output'), ctx.node(), pathname=abs)
656 fp = cmdutil.make_file(repo, opts.get('output'), ctx.node(), pathname=abs)
657 data = ctx[abs].data()
657 data = ctx[abs].data()
658 if opts.get('decode'):
658 if opts.get('decode'):
659 data = repo.wwritedata(abs, data)
659 data = repo.wwritedata(abs, data)
660 fp.write(data)
660 fp.write(data)
661 err = 0
661 err = 0
662 return err
662 return err
663
663
664 def clone(ui, source, dest=None, **opts):
664 def clone(ui, source, dest=None, **opts):
665 """make a copy of an existing repository
665 """make a copy of an existing repository
666
666
667 Create a copy of an existing repository in a new directory.
667 Create a copy of an existing repository in a new directory.
668
668
669 If no destination directory name is specified, it defaults to the
669 If no destination directory name is specified, it defaults to the
670 basename of the source.
670 basename of the source.
671
671
672 The location of the source is added to the new repository's
672 The location of the source is added to the new repository's
673 .hg/hgrc file, as the default to be used for future pulls.
673 .hg/hgrc file, as the default to be used for future pulls.
674
674
675 See :hg:`help urls` for valid source format details.
675 See :hg:`help urls` for valid source format details.
676
676
677 It is possible to specify an ``ssh://`` URL as the destination, but no
677 It is possible to specify an ``ssh://`` URL as the destination, but no
678 .hg/hgrc and working directory will be created on the remote side.
678 .hg/hgrc and working directory will be created on the remote side.
679 Please see :hg:`help urls` for important details about ``ssh://`` URLs.
679 Please see :hg:`help urls` for important details about ``ssh://`` URLs.
680
680
681 A set of changesets (tags, or branch names) to pull may be specified
681 A set of changesets (tags, or branch names) to pull may be specified
682 by listing each changeset (tag, or branch name) with -r/--rev.
682 by listing each changeset (tag, or branch name) with -r/--rev.
683 If -r/--rev is used, the cloned repository will contain only a subset
683 If -r/--rev is used, the cloned repository will contain only a subset
684 of the changesets of the source repository. Only the set of changesets
684 of the changesets of the source repository. Only the set of changesets
685 defined by all -r/--rev options (including all their ancestors)
685 defined by all -r/--rev options (including all their ancestors)
686 will be pulled into the destination repository.
686 will be pulled into the destination repository.
687 No subsequent changesets (including subsequent tags) will be present
687 No subsequent changesets (including subsequent tags) will be present
688 in the destination.
688 in the destination.
689
689
690 Using -r/--rev (or 'clone src#rev dest') implies --pull, even for
690 Using -r/--rev (or 'clone src#rev dest') implies --pull, even for
691 local source repositories.
691 local source repositories.
692
692
693 For efficiency, hardlinks are used for cloning whenever the source
693 For efficiency, hardlinks are used for cloning whenever the source
694 and destination are on the same filesystem (note this applies only
694 and destination are on the same filesystem (note this applies only
695 to the repository data, not to the working directory). Some
695 to the repository data, not to the working directory). Some
696 filesystems, such as AFS, implement hardlinking incorrectly, but
696 filesystems, such as AFS, implement hardlinking incorrectly, but
697 do not report errors. In these cases, use the --pull option to
697 do not report errors. In these cases, use the --pull option to
698 avoid hardlinking.
698 avoid hardlinking.
699
699
700 In some cases, you can clone repositories and the working directory
700 In some cases, you can clone repositories and the working directory
701 using full hardlinks with ::
701 using full hardlinks with ::
702
702
703 $ cp -al REPO REPOCLONE
703 $ cp -al REPO REPOCLONE
704
704
705 This is the fastest way to clone, but it is not always safe. The
705 This is the fastest way to clone, but it is not always safe. The
706 operation is not atomic (making sure REPO is not modified during
706 operation is not atomic (making sure REPO is not modified during
707 the operation is up to you) and you have to make sure your editor
707 the operation is up to you) and you have to make sure your editor
708 breaks hardlinks (Emacs and most Linux Kernel tools do so). Also,
708 breaks hardlinks (Emacs and most Linux Kernel tools do so). Also,
709 this is not compatible with certain extensions that place their
709 this is not compatible with certain extensions that place their
710 metadata under the .hg directory, such as mq.
710 metadata under the .hg directory, such as mq.
711
711
712 Mercurial will update the working directory to the first applicable
712 Mercurial will update the working directory to the first applicable
713 revision from this list:
713 revision from this list:
714
714
715 a) null if -U or the source repository has no changesets
715 a) null if -U or the source repository has no changesets
716 b) if -u . and the source repository is local, the first parent of
716 b) if -u . and the source repository is local, the first parent of
717 the source repository's working directory
717 the source repository's working directory
718 c) the changeset specified with -u (if a branch name, this means the
718 c) the changeset specified with -u (if a branch name, this means the
719 latest head of that branch)
719 latest head of that branch)
720 d) the changeset specified with -r
720 d) the changeset specified with -r
721 e) the tipmost head specified with -b
721 e) the tipmost head specified with -b
722 f) the tipmost head specified with the url#branch source syntax
722 f) the tipmost head specified with the url#branch source syntax
723 g) the tipmost head of the default branch
723 g) the tipmost head of the default branch
724 h) tip
724 h) tip
725
725
726 Returns 0 on success.
726 Returns 0 on success.
727 """
727 """
728 if opts.get('noupdate') and opts.get('updaterev'):
728 if opts.get('noupdate') and opts.get('updaterev'):
729 raise util.Abort(_("cannot specify both --noupdate and --updaterev"))
729 raise util.Abort(_("cannot specify both --noupdate and --updaterev"))
730
730
731 r = hg.clone(hg.remoteui(ui, opts), source, dest,
731 r = hg.clone(hg.remoteui(ui, opts), source, dest,
732 pull=opts.get('pull'),
732 pull=opts.get('pull'),
733 stream=opts.get('uncompressed'),
733 stream=opts.get('uncompressed'),
734 rev=opts.get('rev'),
734 rev=opts.get('rev'),
735 update=opts.get('updaterev') or not opts.get('noupdate'),
735 update=opts.get('updaterev') or not opts.get('noupdate'),
736 branch=opts.get('branch'))
736 branch=opts.get('branch'))
737
737
738 return r is None
738 return r is None
739
739
740 def commit(ui, repo, *pats, **opts):
740 def commit(ui, repo, *pats, **opts):
741 """commit the specified files or all outstanding changes
741 """commit the specified files or all outstanding changes
742
742
743 Commit changes to the given files into the repository. Unlike a
743 Commit changes to the given files into the repository. Unlike a
744 centralized RCS, this operation is a local operation. See
744 centralized RCS, this operation is a local operation. See
745 :hg:`push` for a way to actively distribute your changes.
745 :hg:`push` for a way to actively distribute your changes.
746
746
747 If a list of files is omitted, all changes reported by :hg:`status`
747 If a list of files is omitted, all changes reported by :hg:`status`
748 will be committed.
748 will be committed.
749
749
750 If you are committing the result of a merge, do not provide any
750 If you are committing the result of a merge, do not provide any
751 filenames or -I/-X filters.
751 filenames or -I/-X filters.
752
752
753 If no commit message is specified, Mercurial starts your
753 If no commit message is specified, Mercurial starts your
754 configured editor where you can enter a message. In case your
754 configured editor where you can enter a message. In case your
755 commit fails, you will find a backup of your message in
755 commit fails, you will find a backup of your message in
756 ``.hg/last-message.txt``.
756 ``.hg/last-message.txt``.
757
757
758 See :hg:`help dates` for a list of formats valid for -d/--date.
758 See :hg:`help dates` for a list of formats valid for -d/--date.
759
759
760 Returns 0 on success, 1 if nothing changed.
760 Returns 0 on success, 1 if nothing changed.
761 """
761 """
762 extra = {}
762 extra = {}
763 if opts.get('close_branch'):
763 if opts.get('close_branch'):
764 if repo['.'].node() not in repo.branchheads():
764 if repo['.'].node() not in repo.branchheads():
765 # The topo heads set is included in the branch heads set of the
765 # The topo heads set is included in the branch heads set of the
766 # current branch, so it's sufficient to test branchheads
766 # current branch, so it's sufficient to test branchheads
767 raise util.Abort(_('can only close branch heads'))
767 raise util.Abort(_('can only close branch heads'))
768 extra['close'] = 1
768 extra['close'] = 1
769 e = cmdutil.commiteditor
769 e = cmdutil.commiteditor
770 if opts.get('force_editor'):
770 if opts.get('force_editor'):
771 e = cmdutil.commitforceeditor
771 e = cmdutil.commitforceeditor
772
772
773 def commitfunc(ui, repo, message, match, opts):
773 def commitfunc(ui, repo, message, match, opts):
774 return repo.commit(message, opts.get('user'), opts.get('date'), match,
774 return repo.commit(message, opts.get('user'), opts.get('date'), match,
775 editor=e, extra=extra)
775 editor=e, extra=extra)
776
776
777 branch = repo[None].branch()
777 branch = repo[None].branch()
778 bheads = repo.branchheads(branch)
778 bheads = repo.branchheads(branch)
779
779
780 node = cmdutil.commit(ui, repo, commitfunc, pats, opts)
780 node = cmdutil.commit(ui, repo, commitfunc, pats, opts)
781 if not node:
781 if not node:
782 ui.status(_("nothing changed\n"))
782 ui.status(_("nothing changed\n"))
783 return 1
783 return 1
784
784
785 ctx = repo[node]
785 ctx = repo[node]
786 parents = ctx.parents()
786 parents = ctx.parents()
787
787
788 if bheads and not [x for x in parents
788 if bheads and not [x for x in parents
789 if x.node() in bheads and x.branch() == branch]:
789 if x.node() in bheads and x.branch() == branch]:
790 ui.status(_('created new head\n'))
790 ui.status(_('created new head\n'))
791 # The message is not printed for initial roots. For the other
791 # The message is not printed for initial roots. For the other
792 # changesets, it is printed in the following situations:
792 # changesets, it is printed in the following situations:
793 #
793 #
794 # Par column: for the 2 parents with ...
794 # Par column: for the 2 parents with ...
795 # N: null or no parent
795 # N: null or no parent
796 # B: parent is on another named branch
796 # B: parent is on another named branch
797 # C: parent is a regular non head changeset
797 # C: parent is a regular non head changeset
798 # H: parent was a branch head of the current branch
798 # H: parent was a branch head of the current branch
799 # Msg column: whether we print "created new head" message
799 # Msg column: whether we print "created new head" message
800 # In the following, it is assumed that there already exists some
800 # In the following, it is assumed that there already exists some
801 # initial branch heads of the current branch, otherwise nothing is
801 # initial branch heads of the current branch, otherwise nothing is
802 # printed anyway.
802 # printed anyway.
803 #
803 #
804 # Par Msg Comment
804 # Par Msg Comment
805 # NN y additional topo root
805 # NN y additional topo root
806 #
806 #
807 # BN y additional branch root
807 # BN y additional branch root
808 # CN y additional topo head
808 # CN y additional topo head
809 # HN n usual case
809 # HN n usual case
810 #
810 #
811 # BB y weird additional branch root
811 # BB y weird additional branch root
812 # CB y branch merge
812 # CB y branch merge
813 # HB n merge with named branch
813 # HB n merge with named branch
814 #
814 #
815 # CC y additional head from merge
815 # CC y additional head from merge
816 # CH n merge with a head
816 # CH n merge with a head
817 #
817 #
818 # HH n head merge: head count decreases
818 # HH n head merge: head count decreases
819
819
820 if not opts.get('close_branch'):
820 if not opts.get('close_branch'):
821 for r in parents:
821 for r in parents:
822 if r.extra().get('close') and r.branch() == branch:
822 if r.extra().get('close') and r.branch() == branch:
823 ui.status(_('reopening closed branch head %d\n') % r)
823 ui.status(_('reopening closed branch head %d\n') % r)
824
824
825 if ui.debugflag:
825 if ui.debugflag:
826 ui.write(_('committed changeset %d:%s\n') % (int(ctx), ctx.hex()))
826 ui.write(_('committed changeset %d:%s\n') % (int(ctx), ctx.hex()))
827 elif ui.verbose:
827 elif ui.verbose:
828 ui.write(_('committed changeset %d:%s\n') % (int(ctx), ctx))
828 ui.write(_('committed changeset %d:%s\n') % (int(ctx), ctx))
829
829
830 def copy(ui, repo, *pats, **opts):
830 def copy(ui, repo, *pats, **opts):
831 """mark files as copied for the next commit
831 """mark files as copied for the next commit
832
832
833 Mark dest as having copies of source files. If dest is a
833 Mark dest as having copies of source files. If dest is a
834 directory, copies are put in that directory. If dest is a file,
834 directory, copies are put in that directory. If dest is a file,
835 the source must be a single file.
835 the source must be a single file.
836
836
837 By default, this command copies the contents of files as they
837 By default, this command copies the contents of files as they
838 exist in the working directory. If invoked with -A/--after, the
838 exist in the working directory. If invoked with -A/--after, the
839 operation is recorded, but no copying is performed.
839 operation is recorded, but no copying is performed.
840
840
841 This command takes effect with the next commit. To undo a copy
841 This command takes effect with the next commit. To undo a copy
842 before that, see :hg:`revert`.
842 before that, see :hg:`revert`.
843
843
844 Returns 0 on success, 1 if errors are encountered.
844 Returns 0 on success, 1 if errors are encountered.
845 """
845 """
846 wlock = repo.wlock(False)
846 wlock = repo.wlock(False)
847 try:
847 try:
848 return cmdutil.copy(ui, repo, pats, opts)
848 return cmdutil.copy(ui, repo, pats, opts)
849 finally:
849 finally:
850 wlock.release()
850 wlock.release()
851
851
852 def debugancestor(ui, repo, *args):
852 def debugancestor(ui, repo, *args):
853 """find the ancestor revision of two revisions in a given index"""
853 """find the ancestor revision of two revisions in a given index"""
854 if len(args) == 3:
854 if len(args) == 3:
855 index, rev1, rev2 = args
855 index, rev1, rev2 = args
856 r = revlog.revlog(util.opener(os.getcwd(), audit=False), index)
856 r = revlog.revlog(util.opener(os.getcwd(), audit=False), index)
857 lookup = r.lookup
857 lookup = r.lookup
858 elif len(args) == 2:
858 elif len(args) == 2:
859 if not repo:
859 if not repo:
860 raise util.Abort(_("there is no Mercurial repository here "
860 raise util.Abort(_("there is no Mercurial repository here "
861 "(.hg not found)"))
861 "(.hg not found)"))
862 rev1, rev2 = args
862 rev1, rev2 = args
863 r = repo.changelog
863 r = repo.changelog
864 lookup = repo.lookup
864 lookup = repo.lookup
865 else:
865 else:
866 raise util.Abort(_('either two or three arguments required'))
866 raise util.Abort(_('either two or three arguments required'))
867 a = r.ancestor(lookup(rev1), lookup(rev2))
867 a = r.ancestor(lookup(rev1), lookup(rev2))
868 ui.write("%d:%s\n" % (r.rev(a), hex(a)))
868 ui.write("%d:%s\n" % (r.rev(a), hex(a)))
869
869
870 def debugbuilddag(ui, repo, text,
870 def debugbuilddag(ui, repo, text,
871 mergeable_file=False,
871 mergeable_file=False,
872 appended_file=False,
872 appended_file=False,
873 overwritten_file=False,
873 overwritten_file=False,
874 new_file=False):
874 new_file=False):
875 """builds a repo with a given dag from scratch in the current empty repo
875 """builds a repo with a given dag from scratch in the current empty repo
876
876
877 Elements:
877 Elements:
878
878
879 - "+n" is a linear run of n nodes based on the current default parent
879 - "+n" is a linear run of n nodes based on the current default parent
880 - "." is a single node based on the current default parent
880 - "." is a single node based on the current default parent
881 - "$" resets the default parent to null (implied at the start);
881 - "$" resets the default parent to null (implied at the start);
882 otherwise the default parent is always the last node created
882 otherwise the default parent is always the last node created
883 - "<p" sets the default parent to the backref p
883 - "<p" sets the default parent to the backref p
884 - "*p" is a fork at parent p, which is a backref
884 - "*p" is a fork at parent p, which is a backref
885 - "*p1/p2" is a merge of parents p1 and p2, which are backrefs
885 - "*p1/p2" is a merge of parents p1 and p2, which are backrefs
886 - "/p2" is a merge of the preceding node and p2
886 - "/p2" is a merge of the preceding node and p2
887 - ":tag" defines a local tag for the preceding node
887 - ":tag" defines a local tag for the preceding node
888 - "@branch" sets the named branch for subsequent nodes
888 - "@branch" sets the named branch for subsequent nodes
889 - "!command" runs the command using your shell
889 - "!command" runs the command using your shell
890 - "!!my command\\n" is like "!", but to the end of the line
890 - "!!my command\\n" is like "!", but to the end of the line
891 - "#...\\n" is a comment up to the end of the line
891 - "#...\\n" is a comment up to the end of the line
892
892
893 Whitespace between the above elements is ignored.
893 Whitespace between the above elements is ignored.
894
894
895 A backref is either
895 A backref is either
896
896
897 - a number n, which references the node curr-n, where curr is the current
897 - a number n, which references the node curr-n, where curr is the current
898 node, or
898 node, or
899 - the name of a local tag you placed earlier using ":tag", or
899 - the name of a local tag you placed earlier using ":tag", or
900 - empty to denote the default parent.
900 - empty to denote the default parent.
901
901
902 All string valued-elements are either strictly alphanumeric, or must
902 All string valued-elements are either strictly alphanumeric, or must
903 be enclosed in double quotes ("..."), with "\\" as escape character.
903 be enclosed in double quotes ("..."), with "\\" as escape character.
904
904
905 Note that the --overwritten-file and --appended-file options imply the
905 Note that the --overwritten-file and --appended-file options imply the
906 use of "HGMERGE=internal:local" during DAG buildup.
906 use of "HGMERGE=internal:local" during DAG buildup.
907 """
907 """
908
908
909 if not (mergeable_file or appended_file or overwritten_file or new_file):
909 if not (mergeable_file or appended_file or overwritten_file or new_file):
910 raise util.Abort(_('need at least one of -m, -a, -o, -n'))
910 raise util.Abort(_('need at least one of -m, -a, -o, -n'))
911
911
912 if len(repo.changelog) > 0:
912 if len(repo.changelog) > 0:
913 raise util.Abort(_('repository is not empty'))
913 raise util.Abort(_('repository is not empty'))
914
914
915 if overwritten_file or appended_file:
915 if overwritten_file or appended_file:
916 # we don't want to fail in merges during buildup
916 # we don't want to fail in merges during buildup
917 os.environ['HGMERGE'] = 'internal:local'
917 os.environ['HGMERGE'] = 'internal:local'
918
918
919 def writefile(fname, text, fmode="wb"):
919 def writefile(fname, text, fmode="wb"):
920 f = open(fname, fmode)
920 f = open(fname, fmode)
921 try:
921 try:
922 f.write(text)
922 f.write(text)
923 finally:
923 finally:
924 f.close()
924 f.close()
925
925
926 if mergeable_file:
926 if mergeable_file:
927 linesperrev = 2
927 linesperrev = 2
928 # determine number of revs in DAG
928 # determine number of revs in DAG
929 n = 0
929 n = 0
930 for type, data in dagparser.parsedag(text):
930 for type, data in dagparser.parsedag(text):
931 if type == 'n':
931 if type == 'n':
932 n += 1
932 n += 1
933 # make a file with k lines per rev
933 # make a file with k lines per rev
934 writefile("mf", "\n".join(str(i) for i in xrange(0, n * linesperrev))
934 writefile("mf", "\n".join(str(i) for i in xrange(0, n * linesperrev))
935 + "\n")
935 + "\n")
936
936
937 at = -1
937 at = -1
938 atbranch = 'default'
938 atbranch = 'default'
939 for type, data in dagparser.parsedag(text):
939 for type, data in dagparser.parsedag(text):
940 if type == 'n':
940 if type == 'n':
941 ui.status('node %s\n' % str(data))
941 ui.status('node %s\n' % str(data))
942 id, ps = data
942 id, ps = data
943 p1 = ps[0]
943 p1 = ps[0]
944 if p1 != at:
944 if p1 != at:
945 update(ui, repo, node=str(p1), clean=True)
945 update(ui, repo, node=str(p1), clean=True)
946 at = p1
946 at = p1
947 if repo.dirstate.branch() != atbranch:
947 if repo.dirstate.branch() != atbranch:
948 branch(ui, repo, atbranch, force=True)
948 branch(ui, repo, atbranch, force=True)
949 if len(ps) > 1:
949 if len(ps) > 1:
950 p2 = ps[1]
950 p2 = ps[1]
951 merge(ui, repo, node=p2)
951 merge(ui, repo, node=p2)
952
952
953 if mergeable_file:
953 if mergeable_file:
954 f = open("mf", "rb+")
954 f = open("mf", "rb+")
955 try:
955 try:
956 lines = f.read().split("\n")
956 lines = f.read().split("\n")
957 lines[id * linesperrev] += " r%i" % id
957 lines[id * linesperrev] += " r%i" % id
958 f.seek(0)
958 f.seek(0)
959 f.write("\n".join(lines))
959 f.write("\n".join(lines))
960 finally:
960 finally:
961 f.close()
961 f.close()
962
962
963 if appended_file:
963 if appended_file:
964 writefile("af", "r%i\n" % id, "ab")
964 writefile("af", "r%i\n" % id, "ab")
965
965
966 if overwritten_file:
966 if overwritten_file:
967 writefile("of", "r%i\n" % id)
967 writefile("of", "r%i\n" % id)
968
968
969 if new_file:
969 if new_file:
970 writefile("nf%i" % id, "r%i\n" % id)
970 writefile("nf%i" % id, "r%i\n" % id)
971
971
972 commit(ui, repo, addremove=True, message="r%i" % id, date=(id, 0))
972 commit(ui, repo, addremove=True, message="r%i" % id, date=(id, 0))
973 at = id
973 at = id
974 elif type == 'l':
974 elif type == 'l':
975 id, name = data
975 id, name = data
976 ui.status('tag %s\n' % name)
976 ui.status('tag %s\n' % name)
977 tag(ui, repo, name, local=True)
977 tag(ui, repo, name, local=True)
978 elif type == 'a':
978 elif type == 'a':
979 ui.status('branch %s\n' % data)
979 ui.status('branch %s\n' % data)
980 atbranch = data
980 atbranch = data
981 elif type in 'cC':
981 elif type in 'cC':
982 r = util.system(data, cwd=repo.root)
982 r = util.system(data, cwd=repo.root)
983 if r:
983 if r:
984 desc, r = util.explain_exit(r)
984 desc, r = util.explain_exit(r)
985 raise util.Abort(_('%s command %s') % (data, desc))
985 raise util.Abort(_('%s command %s') % (data, desc))
986
986
987 def debugcommands(ui, cmd='', *args):
987 def debugcommands(ui, cmd='', *args):
988 """list all available commands and options"""
988 """list all available commands and options"""
989 for cmd, vals in sorted(table.iteritems()):
989 for cmd, vals in sorted(table.iteritems()):
990 cmd = cmd.split('|')[0].strip('^')
990 cmd = cmd.split('|')[0].strip('^')
991 opts = ', '.join([i[1] for i in vals[1]])
991 opts = ', '.join([i[1] for i in vals[1]])
992 ui.write('%s: %s\n' % (cmd, opts))
992 ui.write('%s: %s\n' % (cmd, opts))
993
993
994 def debugcomplete(ui, cmd='', **opts):
994 def debugcomplete(ui, cmd='', **opts):
995 """returns the completion list associated with the given command"""
995 """returns the completion list associated with the given command"""
996
996
997 if opts.get('options'):
997 if opts.get('options'):
998 options = []
998 options = []
999 otables = [globalopts]
999 otables = [globalopts]
1000 if cmd:
1000 if cmd:
1001 aliases, entry = cmdutil.findcmd(cmd, table, False)
1001 aliases, entry = cmdutil.findcmd(cmd, table, False)
1002 otables.append(entry[1])
1002 otables.append(entry[1])
1003 for t in otables:
1003 for t in otables:
1004 for o in t:
1004 for o in t:
1005 if "(DEPRECATED)" in o[3]:
1005 if "(DEPRECATED)" in o[3]:
1006 continue
1006 continue
1007 if o[0]:
1007 if o[0]:
1008 options.append('-%s' % o[0])
1008 options.append('-%s' % o[0])
1009 options.append('--%s' % o[1])
1009 options.append('--%s' % o[1])
1010 ui.write("%s\n" % "\n".join(options))
1010 ui.write("%s\n" % "\n".join(options))
1011 return
1011 return
1012
1012
1013 cmdlist = cmdutil.findpossible(cmd, table)
1013 cmdlist = cmdutil.findpossible(cmd, table)
1014 if ui.verbose:
1014 if ui.verbose:
1015 cmdlist = [' '.join(c[0]) for c in cmdlist.values()]
1015 cmdlist = [' '.join(c[0]) for c in cmdlist.values()]
1016 ui.write("%s\n" % "\n".join(sorted(cmdlist)))
1016 ui.write("%s\n" % "\n".join(sorted(cmdlist)))
1017
1017
1018 def debugfsinfo(ui, path = "."):
1018 def debugfsinfo(ui, path = "."):
1019 """show information detected about current filesystem"""
1019 """show information detected about current filesystem"""
1020 open('.debugfsinfo', 'w').write('')
1020 open('.debugfsinfo', 'w').write('')
1021 ui.write('exec: %s\n' % (util.checkexec(path) and 'yes' or 'no'))
1021 ui.write('exec: %s\n' % (util.checkexec(path) and 'yes' or 'no'))
1022 ui.write('symlink: %s\n' % (util.checklink(path) and 'yes' or 'no'))
1022 ui.write('symlink: %s\n' % (util.checklink(path) and 'yes' or 'no'))
1023 ui.write('case-sensitive: %s\n' % (util.checkcase('.debugfsinfo')
1023 ui.write('case-sensitive: %s\n' % (util.checkcase('.debugfsinfo')
1024 and 'yes' or 'no'))
1024 and 'yes' or 'no'))
1025 os.unlink('.debugfsinfo')
1025 os.unlink('.debugfsinfo')
1026
1026
1027 def debugrebuildstate(ui, repo, rev="tip"):
1027 def debugrebuildstate(ui, repo, rev="tip"):
1028 """rebuild the dirstate as it would look like for the given revision"""
1028 """rebuild the dirstate as it would look like for the given revision"""
1029 ctx = repo[rev]
1029 ctx = repo[rev]
1030 wlock = repo.wlock()
1030 wlock = repo.wlock()
1031 try:
1031 try:
1032 repo.dirstate.rebuild(ctx.node(), ctx.manifest())
1032 repo.dirstate.rebuild(ctx.node(), ctx.manifest())
1033 finally:
1033 finally:
1034 wlock.release()
1034 wlock.release()
1035
1035
1036 def debugcheckstate(ui, repo):
1036 def debugcheckstate(ui, repo):
1037 """validate the correctness of the current dirstate"""
1037 """validate the correctness of the current dirstate"""
1038 parent1, parent2 = repo.dirstate.parents()
1038 parent1, parent2 = repo.dirstate.parents()
1039 m1 = repo[parent1].manifest()
1039 m1 = repo[parent1].manifest()
1040 m2 = repo[parent2].manifest()
1040 m2 = repo[parent2].manifest()
1041 errors = 0
1041 errors = 0
1042 for f in repo.dirstate:
1042 for f in repo.dirstate:
1043 state = repo.dirstate[f]
1043 state = repo.dirstate[f]
1044 if state in "nr" and f not in m1:
1044 if state in "nr" and f not in m1:
1045 ui.warn(_("%s in state %s, but not in manifest1\n") % (f, state))
1045 ui.warn(_("%s in state %s, but not in manifest1\n") % (f, state))
1046 errors += 1
1046 errors += 1
1047 if state in "a" and f in m1:
1047 if state in "a" and f in m1:
1048 ui.warn(_("%s in state %s, but also in manifest1\n") % (f, state))
1048 ui.warn(_("%s in state %s, but also in manifest1\n") % (f, state))
1049 errors += 1
1049 errors += 1
1050 if state in "m" and f not in m1 and f not in m2:
1050 if state in "m" and f not in m1 and f not in m2:
1051 ui.warn(_("%s in state %s, but not in either manifest\n") %
1051 ui.warn(_("%s in state %s, but not in either manifest\n") %
1052 (f, state))
1052 (f, state))
1053 errors += 1
1053 errors += 1
1054 for f in m1:
1054 for f in m1:
1055 state = repo.dirstate[f]
1055 state = repo.dirstate[f]
1056 if state not in "nrm":
1056 if state not in "nrm":
1057 ui.warn(_("%s in manifest1, but listed as state %s") % (f, state))
1057 ui.warn(_("%s in manifest1, but listed as state %s") % (f, state))
1058 errors += 1
1058 errors += 1
1059 if errors:
1059 if errors:
1060 error = _(".hg/dirstate inconsistent with current parent's manifest")
1060 error = _(".hg/dirstate inconsistent with current parent's manifest")
1061 raise util.Abort(error)
1061 raise util.Abort(error)
1062
1062
1063 def showconfig(ui, repo, *values, **opts):
1063 def showconfig(ui, repo, *values, **opts):
1064 """show combined config settings from all hgrc files
1064 """show combined config settings from all hgrc files
1065
1065
1066 With no arguments, print names and values of all config items.
1066 With no arguments, print names and values of all config items.
1067
1067
1068 With one argument of the form section.name, print just the value
1068 With one argument of the form section.name, print just the value
1069 of that config item.
1069 of that config item.
1070
1070
1071 With multiple arguments, print names and values of all config
1071 With multiple arguments, print names and values of all config
1072 items with matching section names.
1072 items with matching section names.
1073
1073
1074 With --debug, the source (filename and line number) is printed
1074 With --debug, the source (filename and line number) is printed
1075 for each config item.
1075 for each config item.
1076
1076
1077 Returns 0 on success.
1077 Returns 0 on success.
1078 """
1078 """
1079
1079
1080 for f in util.rcpath():
1080 for f in util.rcpath():
1081 ui.debug(_('read config from: %s\n') % f)
1081 ui.debug(_('read config from: %s\n') % f)
1082 untrusted = bool(opts.get('untrusted'))
1082 untrusted = bool(opts.get('untrusted'))
1083 if values:
1083 if values:
1084 sections = [v for v in values if '.' not in v]
1084 sections = [v for v in values if '.' not in v]
1085 items = [v for v in values if '.' in v]
1085 items = [v for v in values if '.' in v]
1086 if len(items) > 1 or items and sections:
1086 if len(items) > 1 or items and sections:
1087 raise util.Abort(_('only one config item permitted'))
1087 raise util.Abort(_('only one config item permitted'))
1088 for section, name, value in ui.walkconfig(untrusted=untrusted):
1088 for section, name, value in ui.walkconfig(untrusted=untrusted):
1089 sectname = section + '.' + name
1089 sectname = section + '.' + name
1090 if values:
1090 if values:
1091 for v in values:
1091 for v in values:
1092 if v == section:
1092 if v == section:
1093 ui.debug('%s: ' %
1093 ui.debug('%s: ' %
1094 ui.configsource(section, name, untrusted))
1094 ui.configsource(section, name, untrusted))
1095 ui.write('%s=%s\n' % (sectname, value))
1095 ui.write('%s=%s\n' % (sectname, value))
1096 elif v == sectname:
1096 elif v == sectname:
1097 ui.debug('%s: ' %
1097 ui.debug('%s: ' %
1098 ui.configsource(section, name, untrusted))
1098 ui.configsource(section, name, untrusted))
1099 ui.write(value, '\n')
1099 ui.write(value, '\n')
1100 else:
1100 else:
1101 ui.debug('%s: ' %
1101 ui.debug('%s: ' %
1102 ui.configsource(section, name, untrusted))
1102 ui.configsource(section, name, untrusted))
1103 ui.write('%s=%s\n' % (sectname, value))
1103 ui.write('%s=%s\n' % (sectname, value))
1104
1104
1105 def debugpushkey(ui, repopath, namespace, *keyinfo):
1105 def debugpushkey(ui, repopath, namespace, *keyinfo):
1106 '''access the pushkey key/value protocol
1106 '''access the pushkey key/value protocol
1107
1107
1108 With two args, list the keys in the given namespace.
1108 With two args, list the keys in the given namespace.
1109
1109
1110 With five args, set a key to new if it currently is set to old.
1110 With five args, set a key to new if it currently is set to old.
1111 Reports success or failure.
1111 Reports success or failure.
1112 '''
1112 '''
1113
1113
1114 target = hg.repository(ui, repopath)
1114 target = hg.repository(ui, repopath)
1115 if keyinfo:
1115 if keyinfo:
1116 key, old, new = keyinfo
1116 key, old, new = keyinfo
1117 r = target.pushkey(namespace, key, old, new)
1117 r = target.pushkey(namespace, key, old, new)
1118 ui.status(str(r) + '\n')
1118 ui.status(str(r) + '\n')
1119 return not(r)
1119 return not(r)
1120 else:
1120 else:
1121 for k, v in target.listkeys(namespace).iteritems():
1121 for k, v in target.listkeys(namespace).iteritems():
1122 ui.write("%s\t%s\n" % (k.encode('string-escape'),
1122 ui.write("%s\t%s\n" % (k.encode('string-escape'),
1123 v.encode('string-escape')))
1123 v.encode('string-escape')))
1124
1124
1125 def debugrevspec(ui, repo, expr):
1125 def debugrevspec(ui, repo, expr):
1126 '''parse and apply a revision specification'''
1126 '''parse and apply a revision specification'''
1127 if ui.verbose:
1127 if ui.verbose:
1128 tree = revset.parse(expr)
1128 tree = revset.parse(expr)
1129 ui.note(tree, "\n")
1129 ui.note(tree, "\n")
1130 func = revset.match(expr)
1130 func = revset.match(expr)
1131 for c in func(repo, range(len(repo))):
1131 for c in func(repo, range(len(repo))):
1132 ui.write("%s\n" % c)
1132 ui.write("%s\n" % c)
1133
1133
1134 def debugsetparents(ui, repo, rev1, rev2=None):
1134 def debugsetparents(ui, repo, rev1, rev2=None):
1135 """manually set the parents of the current working directory
1135 """manually set the parents of the current working directory
1136
1136
1137 This is useful for writing repository conversion tools, but should
1137 This is useful for writing repository conversion tools, but should
1138 be used with care.
1138 be used with care.
1139
1139
1140 Returns 0 on success.
1140 Returns 0 on success.
1141 """
1141 """
1142
1142
1143 if not rev2:
1143 if not rev2:
1144 rev2 = hex(nullid)
1144 rev2 = hex(nullid)
1145
1145
1146 wlock = repo.wlock()
1146 wlock = repo.wlock()
1147 try:
1147 try:
1148 repo.dirstate.setparents(repo.lookup(rev1), repo.lookup(rev2))
1148 repo.dirstate.setparents(repo.lookup(rev1), repo.lookup(rev2))
1149 finally:
1149 finally:
1150 wlock.release()
1150 wlock.release()
1151
1151
1152 def debugstate(ui, repo, nodates=None):
1152 def debugstate(ui, repo, nodates=None):
1153 """show the contents of the current dirstate"""
1153 """show the contents of the current dirstate"""
1154 timestr = ""
1154 timestr = ""
1155 showdate = not nodates
1155 showdate = not nodates
1156 for file_, ent in sorted(repo.dirstate._map.iteritems()):
1156 for file_, ent in sorted(repo.dirstate._map.iteritems()):
1157 if showdate:
1157 if showdate:
1158 if ent[3] == -1:
1158 if ent[3] == -1:
1159 # Pad or slice to locale representation
1159 # Pad or slice to locale representation
1160 locale_len = len(time.strftime("%Y-%m-%d %H:%M:%S ",
1160 locale_len = len(time.strftime("%Y-%m-%d %H:%M:%S ",
1161 time.localtime(0)))
1161 time.localtime(0)))
1162 timestr = 'unset'
1162 timestr = 'unset'
1163 timestr = (timestr[:locale_len] +
1163 timestr = (timestr[:locale_len] +
1164 ' ' * (locale_len - len(timestr)))
1164 ' ' * (locale_len - len(timestr)))
1165 else:
1165 else:
1166 timestr = time.strftime("%Y-%m-%d %H:%M:%S ",
1166 timestr = time.strftime("%Y-%m-%d %H:%M:%S ",
1167 time.localtime(ent[3]))
1167 time.localtime(ent[3]))
1168 if ent[1] & 020000:
1168 if ent[1] & 020000:
1169 mode = 'lnk'
1169 mode = 'lnk'
1170 else:
1170 else:
1171 mode = '%3o' % (ent[1] & 0777)
1171 mode = '%3o' % (ent[1] & 0777)
1172 ui.write("%c %s %10d %s%s\n" % (ent[0], mode, ent[2], timestr, file_))
1172 ui.write("%c %s %10d %s%s\n" % (ent[0], mode, ent[2], timestr, file_))
1173 for f in repo.dirstate.copies():
1173 for f in repo.dirstate.copies():
1174 ui.write(_("copy: %s -> %s\n") % (repo.dirstate.copied(f), f))
1174 ui.write(_("copy: %s -> %s\n") % (repo.dirstate.copied(f), f))
1175
1175
1176 def debugsub(ui, repo, rev=None):
1176 def debugsub(ui, repo, rev=None):
1177 if rev == '':
1177 if rev == '':
1178 rev = None
1178 rev = None
1179 for k, v in sorted(repo[rev].substate.items()):
1179 for k, v in sorted(repo[rev].substate.items()):
1180 ui.write('path %s\n' % k)
1180 ui.write('path %s\n' % k)
1181 ui.write(' source %s\n' % v[0])
1181 ui.write(' source %s\n' % v[0])
1182 ui.write(' revision %s\n' % v[1])
1182 ui.write(' revision %s\n' % v[1])
1183
1183
1184 def debugdag(ui, repo, file_=None, *revs, **opts):
1184 def debugdag(ui, repo, file_=None, *revs, **opts):
1185 """format the changelog or an index DAG as a concise textual description
1185 """format the changelog or an index DAG as a concise textual description
1186
1186
1187 If you pass a revlog index, the revlog's DAG is emitted. If you list
1187 If you pass a revlog index, the revlog's DAG is emitted. If you list
1188 revision numbers, they get labelled in the output as rN.
1188 revision numbers, they get labelled in the output as rN.
1189
1189
1190 Otherwise, the changelog DAG of the current repo is emitted.
1190 Otherwise, the changelog DAG of the current repo is emitted.
1191 """
1191 """
1192 spaces = opts.get('spaces')
1192 spaces = opts.get('spaces')
1193 dots = opts.get('dots')
1193 dots = opts.get('dots')
1194 if file_:
1194 if file_:
1195 rlog = revlog.revlog(util.opener(os.getcwd(), audit=False), file_)
1195 rlog = revlog.revlog(util.opener(os.getcwd(), audit=False), file_)
1196 revs = set((int(r) for r in revs))
1196 revs = set((int(r) for r in revs))
1197 def events():
1197 def events():
1198 for r in rlog:
1198 for r in rlog:
1199 yield 'n', (r, list(set(p for p in rlog.parentrevs(r) if p != -1)))
1199 yield 'n', (r, list(set(p for p in rlog.parentrevs(r) if p != -1)))
1200 if r in revs:
1200 if r in revs:
1201 yield 'l', (r, "r%i" % r)
1201 yield 'l', (r, "r%i" % r)
1202 elif repo:
1202 elif repo:
1203 cl = repo.changelog
1203 cl = repo.changelog
1204 tags = opts.get('tags')
1204 tags = opts.get('tags')
1205 branches = opts.get('branches')
1205 branches = opts.get('branches')
1206 if tags:
1206 if tags:
1207 labels = {}
1207 labels = {}
1208 for l, n in repo.tags().items():
1208 for l, n in repo.tags().items():
1209 labels.setdefault(cl.rev(n), []).append(l)
1209 labels.setdefault(cl.rev(n), []).append(l)
1210 def events():
1210 def events():
1211 b = "default"
1211 b = "default"
1212 for r in cl:
1212 for r in cl:
1213 if branches:
1213 if branches:
1214 newb = cl.read(cl.node(r))[5]['branch']
1214 newb = cl.read(cl.node(r))[5]['branch']
1215 if newb != b:
1215 if newb != b:
1216 yield 'a', newb
1216 yield 'a', newb
1217 b = newb
1217 b = newb
1218 yield 'n', (r, list(set(p for p in cl.parentrevs(r) if p != -1)))
1218 yield 'n', (r, list(set(p for p in cl.parentrevs(r) if p != -1)))
1219 if tags:
1219 if tags:
1220 ls = labels.get(r)
1220 ls = labels.get(r)
1221 if ls:
1221 if ls:
1222 for l in ls:
1222 for l in ls:
1223 yield 'l', (r, l)
1223 yield 'l', (r, l)
1224 else:
1224 else:
1225 raise util.Abort(_('need repo for changelog dag'))
1225 raise util.Abort(_('need repo for changelog dag'))
1226
1226
1227 for line in dagparser.dagtextlines(events(),
1227 for line in dagparser.dagtextlines(events(),
1228 addspaces=spaces,
1228 addspaces=spaces,
1229 wraplabels=True,
1229 wraplabels=True,
1230 wrapannotations=True,
1230 wrapannotations=True,
1231 wrapnonlinear=dots,
1231 wrapnonlinear=dots,
1232 usedots=dots,
1232 usedots=dots,
1233 maxlinewidth=70):
1233 maxlinewidth=70):
1234 ui.write(line)
1234 ui.write(line)
1235 ui.write("\n")
1235 ui.write("\n")
1236
1236
1237 def debugdata(ui, repo, file_, rev):
1237 def debugdata(ui, repo, file_, rev):
1238 """dump the contents of a data file revision"""
1238 """dump the contents of a data file revision"""
1239 r = None
1239 r = None
1240 if repo:
1240 if repo:
1241 filelog = repo.file(file_)
1241 filelog = repo.file(file_)
1242 if len(filelog):
1242 if len(filelog):
1243 r = filelog
1243 r = filelog
1244 if not r:
1244 if not r:
1245 r = revlog.revlog(util.opener(os.getcwd(), audit=False), file_[:-2] + ".i")
1245 r = revlog.revlog(util.opener(os.getcwd(), audit=False), file_[:-2] + ".i")
1246 try:
1246 try:
1247 ui.write(r.revision(r.lookup(rev)))
1247 ui.write(r.revision(r.lookup(rev)))
1248 except KeyError:
1248 except KeyError:
1249 raise util.Abort(_('invalid revision identifier %s') % rev)
1249 raise util.Abort(_('invalid revision identifier %s') % rev)
1250
1250
1251 def debugdate(ui, date, range=None, **opts):
1251 def debugdate(ui, date, range=None, **opts):
1252 """parse and display a date"""
1252 """parse and display a date"""
1253 if opts["extended"]:
1253 if opts["extended"]:
1254 d = util.parsedate(date, util.extendeddateformats)
1254 d = util.parsedate(date, util.extendeddateformats)
1255 else:
1255 else:
1256 d = util.parsedate(date)
1256 d = util.parsedate(date)
1257 ui.write("internal: %s %s\n" % d)
1257 ui.write("internal: %s %s\n" % d)
1258 ui.write("standard: %s\n" % util.datestr(d))
1258 ui.write("standard: %s\n" % util.datestr(d))
1259 if range:
1259 if range:
1260 m = util.matchdate(range)
1260 m = util.matchdate(range)
1261 ui.write("match: %s\n" % m(d[0]))
1261 ui.write("match: %s\n" % m(d[0]))
1262
1262
1263 def debugindex(ui, repo, file_):
1263 def debugindex(ui, repo, file_, **opts):
1264 """dump the contents of an index file"""
1264 """dump the contents of an index file"""
1265 r = None
1265 r = None
1266 if repo:
1266 if repo:
1267 filelog = repo.file(file_)
1267 filelog = repo.file(file_)
1268 if len(filelog):
1268 if len(filelog):
1269 r = filelog
1269 r = filelog
1270
1271 format = opts.get('format', 0)
1272 if format not in (0, 1):
1273 raise util.abort("unknown format %d" % format)
1274
1270 if not r:
1275 if not r:
1271 r = revlog.revlog(util.opener(os.getcwd(), audit=False), file_)
1276 r = revlog.revlog(util.opener(os.getcwd(), audit=False), file_)
1272 ui.write(" rev offset length base linkrev"
1277
1273 " nodeid p1 p2\n")
1278 if format == 0:
1279 ui.write(" rev offset length base linkrev"
1280 " nodeid p1 p2\n")
1281 elif format == 1:
1282 ui.write(" rev flag offset length"
1283 " size base link p1 p2 nodeid\n")
1284
1274 for i in r:
1285 for i in r:
1275 node = r.node(i)
1286 node = r.node(i)
1276 try:
1287 if format == 0:
1277 pp = r.parents(node)
1288 try:
1278 except:
1289 pp = r.parents(node)
1279 pp = [nullid, nullid]
1290 except:
1280 ui.write("% 6d % 9d % 7d % 6d % 7d %s %s %s\n" % (
1291 pp = [nullid, nullid]
1281 i, r.start(i), r.length(i), r.base(i), r.linkrev(i),
1292 ui.write("% 6d % 9d % 7d % 6d % 7d %s %s %s\n" % (
1282 short(node), short(pp[0]), short(pp[1])))
1293 i, r.start(i), r.length(i), r.base(i), r.linkrev(i),
1294 short(node), short(pp[0]), short(pp[1])))
1295 elif format == 1:
1296 pr = r.parentrevs(i)
1297 ui.write("% 6d %04x % 8d % 8d % 8d % 6d % 6d % 6d % 6d %s\n" % (
1298 i, r.flags(i), r.start(i), r.length(i), r.rawsize(i),
1299 r.base(i), r.linkrev(i), pr[0], pr[1], short(node)))
1283
1300
1284 def debugindexdot(ui, repo, file_):
1301 def debugindexdot(ui, repo, file_):
1285 """dump an index DAG as a graphviz dot file"""
1302 """dump an index DAG as a graphviz dot file"""
1286 r = None
1303 r = None
1287 if repo:
1304 if repo:
1288 filelog = repo.file(file_)
1305 filelog = repo.file(file_)
1289 if len(filelog):
1306 if len(filelog):
1290 r = filelog
1307 r = filelog
1291 if not r:
1308 if not r:
1292 r = revlog.revlog(util.opener(os.getcwd(), audit=False), file_)
1309 r = revlog.revlog(util.opener(os.getcwd(), audit=False), file_)
1293 ui.write("digraph G {\n")
1310 ui.write("digraph G {\n")
1294 for i in r:
1311 for i in r:
1295 node = r.node(i)
1312 node = r.node(i)
1296 pp = r.parents(node)
1313 pp = r.parents(node)
1297 ui.write("\t%d -> %d\n" % (r.rev(pp[0]), i))
1314 ui.write("\t%d -> %d\n" % (r.rev(pp[0]), i))
1298 if pp[1] != nullid:
1315 if pp[1] != nullid:
1299 ui.write("\t%d -> %d\n" % (r.rev(pp[1]), i))
1316 ui.write("\t%d -> %d\n" % (r.rev(pp[1]), i))
1300 ui.write("}\n")
1317 ui.write("}\n")
1301
1318
1302 def debuginstall(ui):
1319 def debuginstall(ui):
1303 '''test Mercurial installation
1320 '''test Mercurial installation
1304
1321
1305 Returns 0 on success.
1322 Returns 0 on success.
1306 '''
1323 '''
1307
1324
1308 def writetemp(contents):
1325 def writetemp(contents):
1309 (fd, name) = tempfile.mkstemp(prefix="hg-debuginstall-")
1326 (fd, name) = tempfile.mkstemp(prefix="hg-debuginstall-")
1310 f = os.fdopen(fd, "wb")
1327 f = os.fdopen(fd, "wb")
1311 f.write(contents)
1328 f.write(contents)
1312 f.close()
1329 f.close()
1313 return name
1330 return name
1314
1331
1315 problems = 0
1332 problems = 0
1316
1333
1317 # encoding
1334 # encoding
1318 ui.status(_("Checking encoding (%s)...\n") % encoding.encoding)
1335 ui.status(_("Checking encoding (%s)...\n") % encoding.encoding)
1319 try:
1336 try:
1320 encoding.fromlocal("test")
1337 encoding.fromlocal("test")
1321 except util.Abort, inst:
1338 except util.Abort, inst:
1322 ui.write(" %s\n" % inst)
1339 ui.write(" %s\n" % inst)
1323 ui.write(_(" (check that your locale is properly set)\n"))
1340 ui.write(_(" (check that your locale is properly set)\n"))
1324 problems += 1
1341 problems += 1
1325
1342
1326 # compiled modules
1343 # compiled modules
1327 ui.status(_("Checking installed modules (%s)...\n")
1344 ui.status(_("Checking installed modules (%s)...\n")
1328 % os.path.dirname(__file__))
1345 % os.path.dirname(__file__))
1329 try:
1346 try:
1330 import bdiff, mpatch, base85, osutil
1347 import bdiff, mpatch, base85, osutil
1331 except Exception, inst:
1348 except Exception, inst:
1332 ui.write(" %s\n" % inst)
1349 ui.write(" %s\n" % inst)
1333 ui.write(_(" One or more extensions could not be found"))
1350 ui.write(_(" One or more extensions could not be found"))
1334 ui.write(_(" (check that you compiled the extensions)\n"))
1351 ui.write(_(" (check that you compiled the extensions)\n"))
1335 problems += 1
1352 problems += 1
1336
1353
1337 # templates
1354 # templates
1338 ui.status(_("Checking templates...\n"))
1355 ui.status(_("Checking templates...\n"))
1339 try:
1356 try:
1340 import templater
1357 import templater
1341 templater.templater(templater.templatepath("map-cmdline.default"))
1358 templater.templater(templater.templatepath("map-cmdline.default"))
1342 except Exception, inst:
1359 except Exception, inst:
1343 ui.write(" %s\n" % inst)
1360 ui.write(" %s\n" % inst)
1344 ui.write(_(" (templates seem to have been installed incorrectly)\n"))
1361 ui.write(_(" (templates seem to have been installed incorrectly)\n"))
1345 problems += 1
1362 problems += 1
1346
1363
1347 # patch
1364 # patch
1348 ui.status(_("Checking patch...\n"))
1365 ui.status(_("Checking patch...\n"))
1349 patchproblems = 0
1366 patchproblems = 0
1350 a = "1\n2\n3\n4\n"
1367 a = "1\n2\n3\n4\n"
1351 b = "1\n2\n3\ninsert\n4\n"
1368 b = "1\n2\n3\ninsert\n4\n"
1352 fa = writetemp(a)
1369 fa = writetemp(a)
1353 d = mdiff.unidiff(a, None, b, None, os.path.basename(fa),
1370 d = mdiff.unidiff(a, None, b, None, os.path.basename(fa),
1354 os.path.basename(fa))
1371 os.path.basename(fa))
1355 fd = writetemp(d)
1372 fd = writetemp(d)
1356
1373
1357 files = {}
1374 files = {}
1358 try:
1375 try:
1359 patch.patch(fd, ui, cwd=os.path.dirname(fa), files=files)
1376 patch.patch(fd, ui, cwd=os.path.dirname(fa), files=files)
1360 except util.Abort, e:
1377 except util.Abort, e:
1361 ui.write(_(" patch call failed:\n"))
1378 ui.write(_(" patch call failed:\n"))
1362 ui.write(" " + str(e) + "\n")
1379 ui.write(" " + str(e) + "\n")
1363 patchproblems += 1
1380 patchproblems += 1
1364 else:
1381 else:
1365 if list(files) != [os.path.basename(fa)]:
1382 if list(files) != [os.path.basename(fa)]:
1366 ui.write(_(" unexpected patch output!\n"))
1383 ui.write(_(" unexpected patch output!\n"))
1367 patchproblems += 1
1384 patchproblems += 1
1368 a = open(fa).read()
1385 a = open(fa).read()
1369 if a != b:
1386 if a != b:
1370 ui.write(_(" patch test failed!\n"))
1387 ui.write(_(" patch test failed!\n"))
1371 patchproblems += 1
1388 patchproblems += 1
1372
1389
1373 if patchproblems:
1390 if patchproblems:
1374 if ui.config('ui', 'patch'):
1391 if ui.config('ui', 'patch'):
1375 ui.write(_(" (Current patch tool may be incompatible with patch,"
1392 ui.write(_(" (Current patch tool may be incompatible with patch,"
1376 " or misconfigured. Please check your configuration"
1393 " or misconfigured. Please check your configuration"
1377 " file)\n"))
1394 " file)\n"))
1378 else:
1395 else:
1379 ui.write(_(" Internal patcher failure, please report this error"
1396 ui.write(_(" Internal patcher failure, please report this error"
1380 " to http://mercurial.selenic.com/wiki/BugTracker\n"))
1397 " to http://mercurial.selenic.com/wiki/BugTracker\n"))
1381 problems += patchproblems
1398 problems += patchproblems
1382
1399
1383 os.unlink(fa)
1400 os.unlink(fa)
1384 os.unlink(fd)
1401 os.unlink(fd)
1385
1402
1386 # editor
1403 # editor
1387 ui.status(_("Checking commit editor...\n"))
1404 ui.status(_("Checking commit editor...\n"))
1388 editor = ui.geteditor()
1405 editor = ui.geteditor()
1389 cmdpath = util.find_exe(editor) or util.find_exe(editor.split()[0])
1406 cmdpath = util.find_exe(editor) or util.find_exe(editor.split()[0])
1390 if not cmdpath:
1407 if not cmdpath:
1391 if editor == 'vi':
1408 if editor == 'vi':
1392 ui.write(_(" No commit editor set and can't find vi in PATH\n"))
1409 ui.write(_(" No commit editor set and can't find vi in PATH\n"))
1393 ui.write(_(" (specify a commit editor in your configuration"
1410 ui.write(_(" (specify a commit editor in your configuration"
1394 " file)\n"))
1411 " file)\n"))
1395 else:
1412 else:
1396 ui.write(_(" Can't find editor '%s' in PATH\n") % editor)
1413 ui.write(_(" Can't find editor '%s' in PATH\n") % editor)
1397 ui.write(_(" (specify a commit editor in your configuration"
1414 ui.write(_(" (specify a commit editor in your configuration"
1398 " file)\n"))
1415 " file)\n"))
1399 problems += 1
1416 problems += 1
1400
1417
1401 # check username
1418 # check username
1402 ui.status(_("Checking username...\n"))
1419 ui.status(_("Checking username...\n"))
1403 try:
1420 try:
1404 ui.username()
1421 ui.username()
1405 except util.Abort, e:
1422 except util.Abort, e:
1406 ui.write(" %s\n" % e)
1423 ui.write(" %s\n" % e)
1407 ui.write(_(" (specify a username in your configuration file)\n"))
1424 ui.write(_(" (specify a username in your configuration file)\n"))
1408 problems += 1
1425 problems += 1
1409
1426
1410 if not problems:
1427 if not problems:
1411 ui.status(_("No problems detected\n"))
1428 ui.status(_("No problems detected\n"))
1412 else:
1429 else:
1413 ui.write(_("%s problems detected,"
1430 ui.write(_("%s problems detected,"
1414 " please check your install!\n") % problems)
1431 " please check your install!\n") % problems)
1415
1432
1416 return problems
1433 return problems
1417
1434
1418 def debugrename(ui, repo, file1, *pats, **opts):
1435 def debugrename(ui, repo, file1, *pats, **opts):
1419 """dump rename information"""
1436 """dump rename information"""
1420
1437
1421 ctx = repo[opts.get('rev')]
1438 ctx = repo[opts.get('rev')]
1422 m = cmdutil.match(repo, (file1,) + pats, opts)
1439 m = cmdutil.match(repo, (file1,) + pats, opts)
1423 for abs in ctx.walk(m):
1440 for abs in ctx.walk(m):
1424 fctx = ctx[abs]
1441 fctx = ctx[abs]
1425 o = fctx.filelog().renamed(fctx.filenode())
1442 o = fctx.filelog().renamed(fctx.filenode())
1426 rel = m.rel(abs)
1443 rel = m.rel(abs)
1427 if o:
1444 if o:
1428 ui.write(_("%s renamed from %s:%s\n") % (rel, o[0], hex(o[1])))
1445 ui.write(_("%s renamed from %s:%s\n") % (rel, o[0], hex(o[1])))
1429 else:
1446 else:
1430 ui.write(_("%s not renamed\n") % rel)
1447 ui.write(_("%s not renamed\n") % rel)
1431
1448
1432 def debugwalk(ui, repo, *pats, **opts):
1449 def debugwalk(ui, repo, *pats, **opts):
1433 """show how files match on given patterns"""
1450 """show how files match on given patterns"""
1434 m = cmdutil.match(repo, pats, opts)
1451 m = cmdutil.match(repo, pats, opts)
1435 items = list(repo.walk(m))
1452 items = list(repo.walk(m))
1436 if not items:
1453 if not items:
1437 return
1454 return
1438 fmt = 'f %%-%ds %%-%ds %%s' % (
1455 fmt = 'f %%-%ds %%-%ds %%s' % (
1439 max([len(abs) for abs in items]),
1456 max([len(abs) for abs in items]),
1440 max([len(m.rel(abs)) for abs in items]))
1457 max([len(m.rel(abs)) for abs in items]))
1441 for abs in items:
1458 for abs in items:
1442 line = fmt % (abs, m.rel(abs), m.exact(abs) and 'exact' or '')
1459 line = fmt % (abs, m.rel(abs), m.exact(abs) and 'exact' or '')
1443 ui.write("%s\n" % line.rstrip())
1460 ui.write("%s\n" % line.rstrip())
1444
1461
1445 def diff(ui, repo, *pats, **opts):
1462 def diff(ui, repo, *pats, **opts):
1446 """diff repository (or selected files)
1463 """diff repository (or selected files)
1447
1464
1448 Show differences between revisions for the specified files.
1465 Show differences between revisions for the specified files.
1449
1466
1450 Differences between files are shown using the unified diff format.
1467 Differences between files are shown using the unified diff format.
1451
1468
1452 .. note::
1469 .. note::
1453 diff may generate unexpected results for merges, as it will
1470 diff may generate unexpected results for merges, as it will
1454 default to comparing against the working directory's first
1471 default to comparing against the working directory's first
1455 parent changeset if no revisions are specified.
1472 parent changeset if no revisions are specified.
1456
1473
1457 When two revision arguments are given, then changes are shown
1474 When two revision arguments are given, then changes are shown
1458 between those revisions. If only one revision is specified then
1475 between those revisions. If only one revision is specified then
1459 that revision is compared to the working directory, and, when no
1476 that revision is compared to the working directory, and, when no
1460 revisions are specified, the working directory files are compared
1477 revisions are specified, the working directory files are compared
1461 to its parent.
1478 to its parent.
1462
1479
1463 Alternatively you can specify -c/--change with a revision to see
1480 Alternatively you can specify -c/--change with a revision to see
1464 the changes in that changeset relative to its first parent.
1481 the changes in that changeset relative to its first parent.
1465
1482
1466 Without the -a/--text option, diff will avoid generating diffs of
1483 Without the -a/--text option, diff will avoid generating diffs of
1467 files it detects as binary. With -a, diff will generate a diff
1484 files it detects as binary. With -a, diff will generate a diff
1468 anyway, probably with undesirable results.
1485 anyway, probably with undesirable results.
1469
1486
1470 Use the -g/--git option to generate diffs in the git extended diff
1487 Use the -g/--git option to generate diffs in the git extended diff
1471 format. For more information, read :hg:`help diffs`.
1488 format. For more information, read :hg:`help diffs`.
1472
1489
1473 Returns 0 on success.
1490 Returns 0 on success.
1474 """
1491 """
1475
1492
1476 revs = opts.get('rev')
1493 revs = opts.get('rev')
1477 change = opts.get('change')
1494 change = opts.get('change')
1478 stat = opts.get('stat')
1495 stat = opts.get('stat')
1479 reverse = opts.get('reverse')
1496 reverse = opts.get('reverse')
1480
1497
1481 if revs and change:
1498 if revs and change:
1482 msg = _('cannot specify --rev and --change at the same time')
1499 msg = _('cannot specify --rev and --change at the same time')
1483 raise util.Abort(msg)
1500 raise util.Abort(msg)
1484 elif change:
1501 elif change:
1485 node2 = repo.lookup(change)
1502 node2 = repo.lookup(change)
1486 node1 = repo[node2].parents()[0].node()
1503 node1 = repo[node2].parents()[0].node()
1487 else:
1504 else:
1488 node1, node2 = cmdutil.revpair(repo, revs)
1505 node1, node2 = cmdutil.revpair(repo, revs)
1489
1506
1490 if reverse:
1507 if reverse:
1491 node1, node2 = node2, node1
1508 node1, node2 = node2, node1
1492
1509
1493 diffopts = patch.diffopts(ui, opts)
1510 diffopts = patch.diffopts(ui, opts)
1494 m = cmdutil.match(repo, pats, opts)
1511 m = cmdutil.match(repo, pats, opts)
1495 cmdutil.diffordiffstat(ui, repo, diffopts, node1, node2, m, stat=stat,
1512 cmdutil.diffordiffstat(ui, repo, diffopts, node1, node2, m, stat=stat,
1496 listsubrepos=opts.get('subrepos'))
1513 listsubrepos=opts.get('subrepos'))
1497
1514
1498 def export(ui, repo, *changesets, **opts):
1515 def export(ui, repo, *changesets, **opts):
1499 """dump the header and diffs for one or more changesets
1516 """dump the header and diffs for one or more changesets
1500
1517
1501 Print the changeset header and diffs for one or more revisions.
1518 Print the changeset header and diffs for one or more revisions.
1502
1519
1503 The information shown in the changeset header is: author, date,
1520 The information shown in the changeset header is: author, date,
1504 branch name (if non-default), changeset hash, parent(s) and commit
1521 branch name (if non-default), changeset hash, parent(s) and commit
1505 comment.
1522 comment.
1506
1523
1507 .. note::
1524 .. note::
1508 export may generate unexpected diff output for merge
1525 export may generate unexpected diff output for merge
1509 changesets, as it will compare the merge changeset against its
1526 changesets, as it will compare the merge changeset against its
1510 first parent only.
1527 first parent only.
1511
1528
1512 Output may be to a file, in which case the name of the file is
1529 Output may be to a file, in which case the name of the file is
1513 given using a format string. The formatting rules are as follows:
1530 given using a format string. The formatting rules are as follows:
1514
1531
1515 :``%%``: literal "%" character
1532 :``%%``: literal "%" character
1516 :``%H``: changeset hash (40 hexadecimal digits)
1533 :``%H``: changeset hash (40 hexadecimal digits)
1517 :``%N``: number of patches being generated
1534 :``%N``: number of patches being generated
1518 :``%R``: changeset revision number
1535 :``%R``: changeset revision number
1519 :``%b``: basename of the exporting repository
1536 :``%b``: basename of the exporting repository
1520 :``%h``: short-form changeset hash (12 hexadecimal digits)
1537 :``%h``: short-form changeset hash (12 hexadecimal digits)
1521 :``%n``: zero-padded sequence number, starting at 1
1538 :``%n``: zero-padded sequence number, starting at 1
1522 :``%r``: zero-padded changeset revision number
1539 :``%r``: zero-padded changeset revision number
1523
1540
1524 Without the -a/--text option, export will avoid generating diffs
1541 Without the -a/--text option, export will avoid generating diffs
1525 of files it detects as binary. With -a, export will generate a
1542 of files it detects as binary. With -a, export will generate a
1526 diff anyway, probably with undesirable results.
1543 diff anyway, probably with undesirable results.
1527
1544
1528 Use the -g/--git option to generate diffs in the git extended diff
1545 Use the -g/--git option to generate diffs in the git extended diff
1529 format. See :hg:`help diffs` for more information.
1546 format. See :hg:`help diffs` for more information.
1530
1547
1531 With the --switch-parent option, the diff will be against the
1548 With the --switch-parent option, the diff will be against the
1532 second parent. It can be useful to review a merge.
1549 second parent. It can be useful to review a merge.
1533
1550
1534 Returns 0 on success.
1551 Returns 0 on success.
1535 """
1552 """
1536 changesets += tuple(opts.get('rev', []))
1553 changesets += tuple(opts.get('rev', []))
1537 if not changesets:
1554 if not changesets:
1538 raise util.Abort(_("export requires at least one changeset"))
1555 raise util.Abort(_("export requires at least one changeset"))
1539 revs = cmdutil.revrange(repo, changesets)
1556 revs = cmdutil.revrange(repo, changesets)
1540 if len(revs) > 1:
1557 if len(revs) > 1:
1541 ui.note(_('exporting patches:\n'))
1558 ui.note(_('exporting patches:\n'))
1542 else:
1559 else:
1543 ui.note(_('exporting patch:\n'))
1560 ui.note(_('exporting patch:\n'))
1544 cmdutil.export(repo, revs, template=opts.get('output'),
1561 cmdutil.export(repo, revs, template=opts.get('output'),
1545 switch_parent=opts.get('switch_parent'),
1562 switch_parent=opts.get('switch_parent'),
1546 opts=patch.diffopts(ui, opts))
1563 opts=patch.diffopts(ui, opts))
1547
1564
1548 def forget(ui, repo, *pats, **opts):
1565 def forget(ui, repo, *pats, **opts):
1549 """forget the specified files on the next commit
1566 """forget the specified files on the next commit
1550
1567
1551 Mark the specified files so they will no longer be tracked
1568 Mark the specified files so they will no longer be tracked
1552 after the next commit.
1569 after the next commit.
1553
1570
1554 This only removes files from the current branch, not from the
1571 This only removes files from the current branch, not from the
1555 entire project history, and it does not delete them from the
1572 entire project history, and it does not delete them from the
1556 working directory.
1573 working directory.
1557
1574
1558 To undo a forget before the next commit, see :hg:`add`.
1575 To undo a forget before the next commit, see :hg:`add`.
1559
1576
1560 Returns 0 on success.
1577 Returns 0 on success.
1561 """
1578 """
1562
1579
1563 if not pats:
1580 if not pats:
1564 raise util.Abort(_('no files specified'))
1581 raise util.Abort(_('no files specified'))
1565
1582
1566 m = cmdutil.match(repo, pats, opts)
1583 m = cmdutil.match(repo, pats, opts)
1567 s = repo.status(match=m, clean=True)
1584 s = repo.status(match=m, clean=True)
1568 forget = sorted(s[0] + s[1] + s[3] + s[6])
1585 forget = sorted(s[0] + s[1] + s[3] + s[6])
1569 errs = 0
1586 errs = 0
1570
1587
1571 for f in m.files():
1588 for f in m.files():
1572 if f not in repo.dirstate and not os.path.isdir(m.rel(f)):
1589 if f not in repo.dirstate and not os.path.isdir(m.rel(f)):
1573 ui.warn(_('not removing %s: file is already untracked\n')
1590 ui.warn(_('not removing %s: file is already untracked\n')
1574 % m.rel(f))
1591 % m.rel(f))
1575 errs = 1
1592 errs = 1
1576
1593
1577 for f in forget:
1594 for f in forget:
1578 if ui.verbose or not m.exact(f):
1595 if ui.verbose or not m.exact(f):
1579 ui.status(_('removing %s\n') % m.rel(f))
1596 ui.status(_('removing %s\n') % m.rel(f))
1580
1597
1581 repo[None].remove(forget, unlink=False)
1598 repo[None].remove(forget, unlink=False)
1582 return errs
1599 return errs
1583
1600
1584 def grep(ui, repo, pattern, *pats, **opts):
1601 def grep(ui, repo, pattern, *pats, **opts):
1585 """search for a pattern in specified files and revisions
1602 """search for a pattern in specified files and revisions
1586
1603
1587 Search revisions of files for a regular expression.
1604 Search revisions of files for a regular expression.
1588
1605
1589 This command behaves differently than Unix grep. It only accepts
1606 This command behaves differently than Unix grep. It only accepts
1590 Python/Perl regexps. It searches repository history, not the
1607 Python/Perl regexps. It searches repository history, not the
1591 working directory. It always prints the revision number in which a
1608 working directory. It always prints the revision number in which a
1592 match appears.
1609 match appears.
1593
1610
1594 By default, grep only prints output for the first revision of a
1611 By default, grep only prints output for the first revision of a
1595 file in which it finds a match. To get it to print every revision
1612 file in which it finds a match. To get it to print every revision
1596 that contains a change in match status ("-" for a match that
1613 that contains a change in match status ("-" for a match that
1597 becomes a non-match, or "+" for a non-match that becomes a match),
1614 becomes a non-match, or "+" for a non-match that becomes a match),
1598 use the --all flag.
1615 use the --all flag.
1599
1616
1600 Returns 0 if a match is found, 1 otherwise.
1617 Returns 0 if a match is found, 1 otherwise.
1601 """
1618 """
1602 reflags = 0
1619 reflags = 0
1603 if opts.get('ignore_case'):
1620 if opts.get('ignore_case'):
1604 reflags |= re.I
1621 reflags |= re.I
1605 try:
1622 try:
1606 regexp = re.compile(pattern, reflags)
1623 regexp = re.compile(pattern, reflags)
1607 except re.error, inst:
1624 except re.error, inst:
1608 ui.warn(_("grep: invalid match pattern: %s\n") % inst)
1625 ui.warn(_("grep: invalid match pattern: %s\n") % inst)
1609 return 1
1626 return 1
1610 sep, eol = ':', '\n'
1627 sep, eol = ':', '\n'
1611 if opts.get('print0'):
1628 if opts.get('print0'):
1612 sep = eol = '\0'
1629 sep = eol = '\0'
1613
1630
1614 getfile = util.lrucachefunc(repo.file)
1631 getfile = util.lrucachefunc(repo.file)
1615
1632
1616 def matchlines(body):
1633 def matchlines(body):
1617 begin = 0
1634 begin = 0
1618 linenum = 0
1635 linenum = 0
1619 while True:
1636 while True:
1620 match = regexp.search(body, begin)
1637 match = regexp.search(body, begin)
1621 if not match:
1638 if not match:
1622 break
1639 break
1623 mstart, mend = match.span()
1640 mstart, mend = match.span()
1624 linenum += body.count('\n', begin, mstart) + 1
1641 linenum += body.count('\n', begin, mstart) + 1
1625 lstart = body.rfind('\n', begin, mstart) + 1 or begin
1642 lstart = body.rfind('\n', begin, mstart) + 1 or begin
1626 begin = body.find('\n', mend) + 1 or len(body)
1643 begin = body.find('\n', mend) + 1 or len(body)
1627 lend = begin - 1
1644 lend = begin - 1
1628 yield linenum, mstart - lstart, mend - lstart, body[lstart:lend]
1645 yield linenum, mstart - lstart, mend - lstart, body[lstart:lend]
1629
1646
1630 class linestate(object):
1647 class linestate(object):
1631 def __init__(self, line, linenum, colstart, colend):
1648 def __init__(self, line, linenum, colstart, colend):
1632 self.line = line
1649 self.line = line
1633 self.linenum = linenum
1650 self.linenum = linenum
1634 self.colstart = colstart
1651 self.colstart = colstart
1635 self.colend = colend
1652 self.colend = colend
1636
1653
1637 def __hash__(self):
1654 def __hash__(self):
1638 return hash((self.linenum, self.line))
1655 return hash((self.linenum, self.line))
1639
1656
1640 def __eq__(self, other):
1657 def __eq__(self, other):
1641 return self.line == other.line
1658 return self.line == other.line
1642
1659
1643 matches = {}
1660 matches = {}
1644 copies = {}
1661 copies = {}
1645 def grepbody(fn, rev, body):
1662 def grepbody(fn, rev, body):
1646 matches[rev].setdefault(fn, [])
1663 matches[rev].setdefault(fn, [])
1647 m = matches[rev][fn]
1664 m = matches[rev][fn]
1648 for lnum, cstart, cend, line in matchlines(body):
1665 for lnum, cstart, cend, line in matchlines(body):
1649 s = linestate(line, lnum, cstart, cend)
1666 s = linestate(line, lnum, cstart, cend)
1650 m.append(s)
1667 m.append(s)
1651
1668
1652 def difflinestates(a, b):
1669 def difflinestates(a, b):
1653 sm = difflib.SequenceMatcher(None, a, b)
1670 sm = difflib.SequenceMatcher(None, a, b)
1654 for tag, alo, ahi, blo, bhi in sm.get_opcodes():
1671 for tag, alo, ahi, blo, bhi in sm.get_opcodes():
1655 if tag == 'insert':
1672 if tag == 'insert':
1656 for i in xrange(blo, bhi):
1673 for i in xrange(blo, bhi):
1657 yield ('+', b[i])
1674 yield ('+', b[i])
1658 elif tag == 'delete':
1675 elif tag == 'delete':
1659 for i in xrange(alo, ahi):
1676 for i in xrange(alo, ahi):
1660 yield ('-', a[i])
1677 yield ('-', a[i])
1661 elif tag == 'replace':
1678 elif tag == 'replace':
1662 for i in xrange(alo, ahi):
1679 for i in xrange(alo, ahi):
1663 yield ('-', a[i])
1680 yield ('-', a[i])
1664 for i in xrange(blo, bhi):
1681 for i in xrange(blo, bhi):
1665 yield ('+', b[i])
1682 yield ('+', b[i])
1666
1683
1667 def display(fn, ctx, pstates, states):
1684 def display(fn, ctx, pstates, states):
1668 rev = ctx.rev()
1685 rev = ctx.rev()
1669 datefunc = ui.quiet and util.shortdate or util.datestr
1686 datefunc = ui.quiet and util.shortdate or util.datestr
1670 found = False
1687 found = False
1671 filerevmatches = {}
1688 filerevmatches = {}
1672 if opts.get('all'):
1689 if opts.get('all'):
1673 iter = difflinestates(pstates, states)
1690 iter = difflinestates(pstates, states)
1674 else:
1691 else:
1675 iter = [('', l) for l in states]
1692 iter = [('', l) for l in states]
1676 for change, l in iter:
1693 for change, l in iter:
1677 cols = [fn, str(rev)]
1694 cols = [fn, str(rev)]
1678 before, match, after = None, None, None
1695 before, match, after = None, None, None
1679 if opts.get('line_number'):
1696 if opts.get('line_number'):
1680 cols.append(str(l.linenum))
1697 cols.append(str(l.linenum))
1681 if opts.get('all'):
1698 if opts.get('all'):
1682 cols.append(change)
1699 cols.append(change)
1683 if opts.get('user'):
1700 if opts.get('user'):
1684 cols.append(ui.shortuser(ctx.user()))
1701 cols.append(ui.shortuser(ctx.user()))
1685 if opts.get('date'):
1702 if opts.get('date'):
1686 cols.append(datefunc(ctx.date()))
1703 cols.append(datefunc(ctx.date()))
1687 if opts.get('files_with_matches'):
1704 if opts.get('files_with_matches'):
1688 c = (fn, rev)
1705 c = (fn, rev)
1689 if c in filerevmatches:
1706 if c in filerevmatches:
1690 continue
1707 continue
1691 filerevmatches[c] = 1
1708 filerevmatches[c] = 1
1692 else:
1709 else:
1693 before = l.line[:l.colstart]
1710 before = l.line[:l.colstart]
1694 match = l.line[l.colstart:l.colend]
1711 match = l.line[l.colstart:l.colend]
1695 after = l.line[l.colend:]
1712 after = l.line[l.colend:]
1696 ui.write(sep.join(cols))
1713 ui.write(sep.join(cols))
1697 if before is not None:
1714 if before is not None:
1698 ui.write(sep + before)
1715 ui.write(sep + before)
1699 ui.write(match, label='grep.match')
1716 ui.write(match, label='grep.match')
1700 ui.write(after)
1717 ui.write(after)
1701 ui.write(eol)
1718 ui.write(eol)
1702 found = True
1719 found = True
1703 return found
1720 return found
1704
1721
1705 skip = {}
1722 skip = {}
1706 revfiles = {}
1723 revfiles = {}
1707 matchfn = cmdutil.match(repo, pats, opts)
1724 matchfn = cmdutil.match(repo, pats, opts)
1708 found = False
1725 found = False
1709 follow = opts.get('follow')
1726 follow = opts.get('follow')
1710
1727
1711 def prep(ctx, fns):
1728 def prep(ctx, fns):
1712 rev = ctx.rev()
1729 rev = ctx.rev()
1713 pctx = ctx.parents()[0]
1730 pctx = ctx.parents()[0]
1714 parent = pctx.rev()
1731 parent = pctx.rev()
1715 matches.setdefault(rev, {})
1732 matches.setdefault(rev, {})
1716 matches.setdefault(parent, {})
1733 matches.setdefault(parent, {})
1717 files = revfiles.setdefault(rev, [])
1734 files = revfiles.setdefault(rev, [])
1718 for fn in fns:
1735 for fn in fns:
1719 flog = getfile(fn)
1736 flog = getfile(fn)
1720 try:
1737 try:
1721 fnode = ctx.filenode(fn)
1738 fnode = ctx.filenode(fn)
1722 except error.LookupError:
1739 except error.LookupError:
1723 continue
1740 continue
1724
1741
1725 copied = flog.renamed(fnode)
1742 copied = flog.renamed(fnode)
1726 copy = follow and copied and copied[0]
1743 copy = follow and copied and copied[0]
1727 if copy:
1744 if copy:
1728 copies.setdefault(rev, {})[fn] = copy
1745 copies.setdefault(rev, {})[fn] = copy
1729 if fn in skip:
1746 if fn in skip:
1730 if copy:
1747 if copy:
1731 skip[copy] = True
1748 skip[copy] = True
1732 continue
1749 continue
1733 files.append(fn)
1750 files.append(fn)
1734
1751
1735 if fn not in matches[rev]:
1752 if fn not in matches[rev]:
1736 grepbody(fn, rev, flog.read(fnode))
1753 grepbody(fn, rev, flog.read(fnode))
1737
1754
1738 pfn = copy or fn
1755 pfn = copy or fn
1739 if pfn not in matches[parent]:
1756 if pfn not in matches[parent]:
1740 try:
1757 try:
1741 fnode = pctx.filenode(pfn)
1758 fnode = pctx.filenode(pfn)
1742 grepbody(pfn, parent, flog.read(fnode))
1759 grepbody(pfn, parent, flog.read(fnode))
1743 except error.LookupError:
1760 except error.LookupError:
1744 pass
1761 pass
1745
1762
1746 for ctx in cmdutil.walkchangerevs(repo, matchfn, opts, prep):
1763 for ctx in cmdutil.walkchangerevs(repo, matchfn, opts, prep):
1747 rev = ctx.rev()
1764 rev = ctx.rev()
1748 parent = ctx.parents()[0].rev()
1765 parent = ctx.parents()[0].rev()
1749 for fn in sorted(revfiles.get(rev, [])):
1766 for fn in sorted(revfiles.get(rev, [])):
1750 states = matches[rev][fn]
1767 states = matches[rev][fn]
1751 copy = copies.get(rev, {}).get(fn)
1768 copy = copies.get(rev, {}).get(fn)
1752 if fn in skip:
1769 if fn in skip:
1753 if copy:
1770 if copy:
1754 skip[copy] = True
1771 skip[copy] = True
1755 continue
1772 continue
1756 pstates = matches.get(parent, {}).get(copy or fn, [])
1773 pstates = matches.get(parent, {}).get(copy or fn, [])
1757 if pstates or states:
1774 if pstates or states:
1758 r = display(fn, ctx, pstates, states)
1775 r = display(fn, ctx, pstates, states)
1759 found = found or r
1776 found = found or r
1760 if r and not opts.get('all'):
1777 if r and not opts.get('all'):
1761 skip[fn] = True
1778 skip[fn] = True
1762 if copy:
1779 if copy:
1763 skip[copy] = True
1780 skip[copy] = True
1764 del matches[rev]
1781 del matches[rev]
1765 del revfiles[rev]
1782 del revfiles[rev]
1766
1783
1767 return not found
1784 return not found
1768
1785
1769 def heads(ui, repo, *branchrevs, **opts):
1786 def heads(ui, repo, *branchrevs, **opts):
1770 """show current repository heads or show branch heads
1787 """show current repository heads or show branch heads
1771
1788
1772 With no arguments, show all repository branch heads.
1789 With no arguments, show all repository branch heads.
1773
1790
1774 Repository "heads" are changesets with no child changesets. They are
1791 Repository "heads" are changesets with no child changesets. They are
1775 where development generally takes place and are the usual targets
1792 where development generally takes place and are the usual targets
1776 for update and merge operations. Branch heads are changesets that have
1793 for update and merge operations. Branch heads are changesets that have
1777 no child changeset on the same branch.
1794 no child changeset on the same branch.
1778
1795
1779 If one or more REVs are given, only branch heads on the branches
1796 If one or more REVs are given, only branch heads on the branches
1780 associated with the specified changesets are shown.
1797 associated with the specified changesets are shown.
1781
1798
1782 If -c/--closed is specified, also show branch heads marked closed
1799 If -c/--closed is specified, also show branch heads marked closed
1783 (see :hg:`commit --close-branch`).
1800 (see :hg:`commit --close-branch`).
1784
1801
1785 If STARTREV is specified, only those heads that are descendants of
1802 If STARTREV is specified, only those heads that are descendants of
1786 STARTREV will be displayed.
1803 STARTREV will be displayed.
1787
1804
1788 If -t/--topo is specified, named branch mechanics will be ignored and only
1805 If -t/--topo is specified, named branch mechanics will be ignored and only
1789 changesets without children will be shown.
1806 changesets without children will be shown.
1790
1807
1791 Returns 0 if matching heads are found, 1 if not.
1808 Returns 0 if matching heads are found, 1 if not.
1792 """
1809 """
1793
1810
1794 if opts.get('rev'):
1811 if opts.get('rev'):
1795 start = repo.lookup(opts['rev'])
1812 start = repo.lookup(opts['rev'])
1796 else:
1813 else:
1797 start = None
1814 start = None
1798
1815
1799 if opts.get('topo'):
1816 if opts.get('topo'):
1800 heads = [repo[h] for h in repo.heads(start)]
1817 heads = [repo[h] for h in repo.heads(start)]
1801 else:
1818 else:
1802 heads = []
1819 heads = []
1803 for b, ls in repo.branchmap().iteritems():
1820 for b, ls in repo.branchmap().iteritems():
1804 if start is None:
1821 if start is None:
1805 heads += [repo[h] for h in ls]
1822 heads += [repo[h] for h in ls]
1806 continue
1823 continue
1807 startrev = repo.changelog.rev(start)
1824 startrev = repo.changelog.rev(start)
1808 descendants = set(repo.changelog.descendants(startrev))
1825 descendants = set(repo.changelog.descendants(startrev))
1809 descendants.add(startrev)
1826 descendants.add(startrev)
1810 rev = repo.changelog.rev
1827 rev = repo.changelog.rev
1811 heads += [repo[h] for h in ls if rev(h) in descendants]
1828 heads += [repo[h] for h in ls if rev(h) in descendants]
1812
1829
1813 if branchrevs:
1830 if branchrevs:
1814 decode, encode = encoding.fromlocal, encoding.tolocal
1831 decode, encode = encoding.fromlocal, encoding.tolocal
1815 branches = set(repo[decode(br)].branch() for br in branchrevs)
1832 branches = set(repo[decode(br)].branch() for br in branchrevs)
1816 heads = [h for h in heads if h.branch() in branches]
1833 heads = [h for h in heads if h.branch() in branches]
1817
1834
1818 if not opts.get('closed'):
1835 if not opts.get('closed'):
1819 heads = [h for h in heads if not h.extra().get('close')]
1836 heads = [h for h in heads if not h.extra().get('close')]
1820
1837
1821 if opts.get('active') and branchrevs:
1838 if opts.get('active') and branchrevs:
1822 dagheads = repo.heads(start)
1839 dagheads = repo.heads(start)
1823 heads = [h for h in heads if h.node() in dagheads]
1840 heads = [h for h in heads if h.node() in dagheads]
1824
1841
1825 if branchrevs:
1842 if branchrevs:
1826 haveheads = set(h.branch() for h in heads)
1843 haveheads = set(h.branch() for h in heads)
1827 if branches - haveheads:
1844 if branches - haveheads:
1828 headless = ', '.join(encode(b) for b in branches - haveheads)
1845 headless = ', '.join(encode(b) for b in branches - haveheads)
1829 msg = _('no open branch heads found on branches %s')
1846 msg = _('no open branch heads found on branches %s')
1830 if opts.get('rev'):
1847 if opts.get('rev'):
1831 msg += _(' (started at %s)' % opts['rev'])
1848 msg += _(' (started at %s)' % opts['rev'])
1832 ui.warn((msg + '\n') % headless)
1849 ui.warn((msg + '\n') % headless)
1833
1850
1834 if not heads:
1851 if not heads:
1835 return 1
1852 return 1
1836
1853
1837 heads = sorted(heads, key=lambda x: -x.rev())
1854 heads = sorted(heads, key=lambda x: -x.rev())
1838 displayer = cmdutil.show_changeset(ui, repo, opts)
1855 displayer = cmdutil.show_changeset(ui, repo, opts)
1839 for ctx in heads:
1856 for ctx in heads:
1840 displayer.show(ctx)
1857 displayer.show(ctx)
1841 displayer.close()
1858 displayer.close()
1842
1859
1843 def help_(ui, name=None, with_version=False, unknowncmd=False):
1860 def help_(ui, name=None, with_version=False, unknowncmd=False):
1844 """show help for a given topic or a help overview
1861 """show help for a given topic or a help overview
1845
1862
1846 With no arguments, print a list of commands with short help messages.
1863 With no arguments, print a list of commands with short help messages.
1847
1864
1848 Given a topic, extension, or command name, print help for that
1865 Given a topic, extension, or command name, print help for that
1849 topic.
1866 topic.
1850
1867
1851 Returns 0 if successful.
1868 Returns 0 if successful.
1852 """
1869 """
1853 option_lists = []
1870 option_lists = []
1854 textwidth = ui.termwidth() - 2
1871 textwidth = ui.termwidth() - 2
1855
1872
1856 def addglobalopts(aliases):
1873 def addglobalopts(aliases):
1857 if ui.verbose:
1874 if ui.verbose:
1858 option_lists.append((_("global options:"), globalopts))
1875 option_lists.append((_("global options:"), globalopts))
1859 if name == 'shortlist':
1876 if name == 'shortlist':
1860 option_lists.append((_('use "hg help" for the full list '
1877 option_lists.append((_('use "hg help" for the full list '
1861 'of commands'), ()))
1878 'of commands'), ()))
1862 else:
1879 else:
1863 if name == 'shortlist':
1880 if name == 'shortlist':
1864 msg = _('use "hg help" for the full list of commands '
1881 msg = _('use "hg help" for the full list of commands '
1865 'or "hg -v" for details')
1882 'or "hg -v" for details')
1866 elif aliases:
1883 elif aliases:
1867 msg = _('use "hg -v help%s" to show aliases and '
1884 msg = _('use "hg -v help%s" to show aliases and '
1868 'global options') % (name and " " + name or "")
1885 'global options') % (name and " " + name or "")
1869 else:
1886 else:
1870 msg = _('use "hg -v help %s" to show global options') % name
1887 msg = _('use "hg -v help %s" to show global options') % name
1871 option_lists.append((msg, ()))
1888 option_lists.append((msg, ()))
1872
1889
1873 def helpcmd(name):
1890 def helpcmd(name):
1874 if with_version:
1891 if with_version:
1875 version_(ui)
1892 version_(ui)
1876 ui.write('\n')
1893 ui.write('\n')
1877
1894
1878 try:
1895 try:
1879 aliases, entry = cmdutil.findcmd(name, table, strict=unknowncmd)
1896 aliases, entry = cmdutil.findcmd(name, table, strict=unknowncmd)
1880 except error.AmbiguousCommand, inst:
1897 except error.AmbiguousCommand, inst:
1881 # py3k fix: except vars can't be used outside the scope of the
1898 # py3k fix: except vars can't be used outside the scope of the
1882 # except block, nor can be used inside a lambda. python issue4617
1899 # except block, nor can be used inside a lambda. python issue4617
1883 prefix = inst.args[0]
1900 prefix = inst.args[0]
1884 select = lambda c: c.lstrip('^').startswith(prefix)
1901 select = lambda c: c.lstrip('^').startswith(prefix)
1885 helplist(_('list of commands:\n\n'), select)
1902 helplist(_('list of commands:\n\n'), select)
1886 return
1903 return
1887
1904
1888 # check if it's an invalid alias and display its error if it is
1905 # check if it's an invalid alias and display its error if it is
1889 if getattr(entry[0], 'badalias', False):
1906 if getattr(entry[0], 'badalias', False):
1890 if not unknowncmd:
1907 if not unknowncmd:
1891 entry[0](ui)
1908 entry[0](ui)
1892 return
1909 return
1893
1910
1894 # synopsis
1911 # synopsis
1895 if len(entry) > 2:
1912 if len(entry) > 2:
1896 if entry[2].startswith('hg'):
1913 if entry[2].startswith('hg'):
1897 ui.write("%s\n" % entry[2])
1914 ui.write("%s\n" % entry[2])
1898 else:
1915 else:
1899 ui.write('hg %s %s\n' % (aliases[0], entry[2]))
1916 ui.write('hg %s %s\n' % (aliases[0], entry[2]))
1900 else:
1917 else:
1901 ui.write('hg %s\n' % aliases[0])
1918 ui.write('hg %s\n' % aliases[0])
1902
1919
1903 # aliases
1920 # aliases
1904 if not ui.quiet and len(aliases) > 1:
1921 if not ui.quiet and len(aliases) > 1:
1905 ui.write(_("\naliases: %s\n") % ', '.join(aliases[1:]))
1922 ui.write(_("\naliases: %s\n") % ', '.join(aliases[1:]))
1906
1923
1907 # description
1924 # description
1908 doc = gettext(entry[0].__doc__)
1925 doc = gettext(entry[0].__doc__)
1909 if not doc:
1926 if not doc:
1910 doc = _("(no help text available)")
1927 doc = _("(no help text available)")
1911 if hasattr(entry[0], 'definition'): # aliased command
1928 if hasattr(entry[0], 'definition'): # aliased command
1912 if entry[0].definition.startswith('!'): # shell alias
1929 if entry[0].definition.startswith('!'): # shell alias
1913 doc = _('shell alias for::\n\n %s') % entry[0].definition[1:]
1930 doc = _('shell alias for::\n\n %s') % entry[0].definition[1:]
1914 else:
1931 else:
1915 doc = _('alias for: hg %s\n\n%s') % (entry[0].definition, doc)
1932 doc = _('alias for: hg %s\n\n%s') % (entry[0].definition, doc)
1916 if ui.quiet:
1933 if ui.quiet:
1917 doc = doc.splitlines()[0]
1934 doc = doc.splitlines()[0]
1918 keep = ui.verbose and ['verbose'] or []
1935 keep = ui.verbose and ['verbose'] or []
1919 formatted, pruned = minirst.format(doc, textwidth, keep=keep)
1936 formatted, pruned = minirst.format(doc, textwidth, keep=keep)
1920 ui.write("\n%s\n" % formatted)
1937 ui.write("\n%s\n" % formatted)
1921 if pruned:
1938 if pruned:
1922 ui.write(_('\nuse "hg -v help %s" to show verbose help\n') % name)
1939 ui.write(_('\nuse "hg -v help %s" to show verbose help\n') % name)
1923
1940
1924 if not ui.quiet:
1941 if not ui.quiet:
1925 # options
1942 # options
1926 if entry[1]:
1943 if entry[1]:
1927 option_lists.append((_("options:\n"), entry[1]))
1944 option_lists.append((_("options:\n"), entry[1]))
1928
1945
1929 addglobalopts(False)
1946 addglobalopts(False)
1930
1947
1931 def helplist(header, select=None):
1948 def helplist(header, select=None):
1932 h = {}
1949 h = {}
1933 cmds = {}
1950 cmds = {}
1934 for c, e in table.iteritems():
1951 for c, e in table.iteritems():
1935 f = c.split("|", 1)[0]
1952 f = c.split("|", 1)[0]
1936 if select and not select(f):
1953 if select and not select(f):
1937 continue
1954 continue
1938 if (not select and name != 'shortlist' and
1955 if (not select and name != 'shortlist' and
1939 e[0].__module__ != __name__):
1956 e[0].__module__ != __name__):
1940 continue
1957 continue
1941 if name == "shortlist" and not f.startswith("^"):
1958 if name == "shortlist" and not f.startswith("^"):
1942 continue
1959 continue
1943 f = f.lstrip("^")
1960 f = f.lstrip("^")
1944 if not ui.debugflag and f.startswith("debug"):
1961 if not ui.debugflag and f.startswith("debug"):
1945 continue
1962 continue
1946 doc = e[0].__doc__
1963 doc = e[0].__doc__
1947 if doc and 'DEPRECATED' in doc and not ui.verbose:
1964 if doc and 'DEPRECATED' in doc and not ui.verbose:
1948 continue
1965 continue
1949 doc = gettext(doc)
1966 doc = gettext(doc)
1950 if not doc:
1967 if not doc:
1951 doc = _("(no help text available)")
1968 doc = _("(no help text available)")
1952 h[f] = doc.splitlines()[0].rstrip()
1969 h[f] = doc.splitlines()[0].rstrip()
1953 cmds[f] = c.lstrip("^")
1970 cmds[f] = c.lstrip("^")
1954
1971
1955 if not h:
1972 if not h:
1956 ui.status(_('no commands defined\n'))
1973 ui.status(_('no commands defined\n'))
1957 return
1974 return
1958
1975
1959 ui.status(header)
1976 ui.status(header)
1960 fns = sorted(h)
1977 fns = sorted(h)
1961 m = max(map(len, fns))
1978 m = max(map(len, fns))
1962 for f in fns:
1979 for f in fns:
1963 if ui.verbose:
1980 if ui.verbose:
1964 commands = cmds[f].replace("|",", ")
1981 commands = cmds[f].replace("|",", ")
1965 ui.write(" %s:\n %s\n"%(commands, h[f]))
1982 ui.write(" %s:\n %s\n"%(commands, h[f]))
1966 else:
1983 else:
1967 ui.write('%s\n' % (util.wrap(h[f], textwidth,
1984 ui.write('%s\n' % (util.wrap(h[f], textwidth,
1968 initindent=' %-*s ' % (m, f),
1985 initindent=' %-*s ' % (m, f),
1969 hangindent=' ' * (m + 4))))
1986 hangindent=' ' * (m + 4))))
1970
1987
1971 if not ui.quiet:
1988 if not ui.quiet:
1972 addglobalopts(True)
1989 addglobalopts(True)
1973
1990
1974 def helptopic(name):
1991 def helptopic(name):
1975 for names, header, doc in help.helptable:
1992 for names, header, doc in help.helptable:
1976 if name in names:
1993 if name in names:
1977 break
1994 break
1978 else:
1995 else:
1979 raise error.UnknownCommand(name)
1996 raise error.UnknownCommand(name)
1980
1997
1981 # description
1998 # description
1982 if not doc:
1999 if not doc:
1983 doc = _("(no help text available)")
2000 doc = _("(no help text available)")
1984 if hasattr(doc, '__call__'):
2001 if hasattr(doc, '__call__'):
1985 doc = doc()
2002 doc = doc()
1986
2003
1987 ui.write("%s\n\n" % header)
2004 ui.write("%s\n\n" % header)
1988 ui.write("%s\n" % minirst.format(doc, textwidth, indent=4))
2005 ui.write("%s\n" % minirst.format(doc, textwidth, indent=4))
1989
2006
1990 def helpext(name):
2007 def helpext(name):
1991 try:
2008 try:
1992 mod = extensions.find(name)
2009 mod = extensions.find(name)
1993 doc = gettext(mod.__doc__) or _('no help text available')
2010 doc = gettext(mod.__doc__) or _('no help text available')
1994 except KeyError:
2011 except KeyError:
1995 mod = None
2012 mod = None
1996 doc = extensions.disabledext(name)
2013 doc = extensions.disabledext(name)
1997 if not doc:
2014 if not doc:
1998 raise error.UnknownCommand(name)
2015 raise error.UnknownCommand(name)
1999
2016
2000 if '\n' not in doc:
2017 if '\n' not in doc:
2001 head, tail = doc, ""
2018 head, tail = doc, ""
2002 else:
2019 else:
2003 head, tail = doc.split('\n', 1)
2020 head, tail = doc.split('\n', 1)
2004 ui.write(_('%s extension - %s\n\n') % (name.split('.')[-1], head))
2021 ui.write(_('%s extension - %s\n\n') % (name.split('.')[-1], head))
2005 if tail:
2022 if tail:
2006 ui.write(minirst.format(tail, textwidth))
2023 ui.write(minirst.format(tail, textwidth))
2007 ui.status('\n\n')
2024 ui.status('\n\n')
2008
2025
2009 if mod:
2026 if mod:
2010 try:
2027 try:
2011 ct = mod.cmdtable
2028 ct = mod.cmdtable
2012 except AttributeError:
2029 except AttributeError:
2013 ct = {}
2030 ct = {}
2014 modcmds = set([c.split('|', 1)[0] for c in ct])
2031 modcmds = set([c.split('|', 1)[0] for c in ct])
2015 helplist(_('list of commands:\n\n'), modcmds.__contains__)
2032 helplist(_('list of commands:\n\n'), modcmds.__contains__)
2016 else:
2033 else:
2017 ui.write(_('use "hg help extensions" for information on enabling '
2034 ui.write(_('use "hg help extensions" for information on enabling '
2018 'extensions\n'))
2035 'extensions\n'))
2019
2036
2020 def helpextcmd(name):
2037 def helpextcmd(name):
2021 cmd, ext, mod = extensions.disabledcmd(name, ui.config('ui', 'strict'))
2038 cmd, ext, mod = extensions.disabledcmd(name, ui.config('ui', 'strict'))
2022 doc = gettext(mod.__doc__).splitlines()[0]
2039 doc = gettext(mod.__doc__).splitlines()[0]
2023
2040
2024 msg = help.listexts(_("'%s' is provided by the following "
2041 msg = help.listexts(_("'%s' is provided by the following "
2025 "extension:") % cmd, {ext: doc}, len(ext),
2042 "extension:") % cmd, {ext: doc}, len(ext),
2026 indent=4)
2043 indent=4)
2027 ui.write(minirst.format(msg, textwidth))
2044 ui.write(minirst.format(msg, textwidth))
2028 ui.write('\n\n')
2045 ui.write('\n\n')
2029 ui.write(_('use "hg help extensions" for information on enabling '
2046 ui.write(_('use "hg help extensions" for information on enabling '
2030 'extensions\n'))
2047 'extensions\n'))
2031
2048
2032 help.addtopichook('revsets', revset.makedoc)
2049 help.addtopichook('revsets', revset.makedoc)
2033
2050
2034 if name and name != 'shortlist':
2051 if name and name != 'shortlist':
2035 i = None
2052 i = None
2036 if unknowncmd:
2053 if unknowncmd:
2037 queries = (helpextcmd,)
2054 queries = (helpextcmd,)
2038 else:
2055 else:
2039 queries = (helptopic, helpcmd, helpext, helpextcmd)
2056 queries = (helptopic, helpcmd, helpext, helpextcmd)
2040 for f in queries:
2057 for f in queries:
2041 try:
2058 try:
2042 f(name)
2059 f(name)
2043 i = None
2060 i = None
2044 break
2061 break
2045 except error.UnknownCommand, inst:
2062 except error.UnknownCommand, inst:
2046 i = inst
2063 i = inst
2047 if i:
2064 if i:
2048 raise i
2065 raise i
2049
2066
2050 else:
2067 else:
2051 # program name
2068 # program name
2052 if ui.verbose or with_version:
2069 if ui.verbose or with_version:
2053 version_(ui)
2070 version_(ui)
2054 else:
2071 else:
2055 ui.status(_("Mercurial Distributed SCM\n"))
2072 ui.status(_("Mercurial Distributed SCM\n"))
2056 ui.status('\n')
2073 ui.status('\n')
2057
2074
2058 # list of commands
2075 # list of commands
2059 if name == "shortlist":
2076 if name == "shortlist":
2060 header = _('basic commands:\n\n')
2077 header = _('basic commands:\n\n')
2061 else:
2078 else:
2062 header = _('list of commands:\n\n')
2079 header = _('list of commands:\n\n')
2063
2080
2064 helplist(header)
2081 helplist(header)
2065 if name != 'shortlist':
2082 if name != 'shortlist':
2066 exts, maxlength = extensions.enabled()
2083 exts, maxlength = extensions.enabled()
2067 text = help.listexts(_('enabled extensions:'), exts, maxlength)
2084 text = help.listexts(_('enabled extensions:'), exts, maxlength)
2068 if text:
2085 if text:
2069 ui.write("\n%s\n" % minirst.format(text, textwidth))
2086 ui.write("\n%s\n" % minirst.format(text, textwidth))
2070
2087
2071 # list all option lists
2088 # list all option lists
2072 opt_output = []
2089 opt_output = []
2073 multioccur = False
2090 multioccur = False
2074 for title, options in option_lists:
2091 for title, options in option_lists:
2075 opt_output.append(("\n%s" % title, None))
2092 opt_output.append(("\n%s" % title, None))
2076 for option in options:
2093 for option in options:
2077 if len(option) == 5:
2094 if len(option) == 5:
2078 shortopt, longopt, default, desc, optlabel = option
2095 shortopt, longopt, default, desc, optlabel = option
2079 else:
2096 else:
2080 shortopt, longopt, default, desc = option
2097 shortopt, longopt, default, desc = option
2081 optlabel = _("VALUE") # default label
2098 optlabel = _("VALUE") # default label
2082
2099
2083 if _("DEPRECATED") in desc and not ui.verbose:
2100 if _("DEPRECATED") in desc and not ui.verbose:
2084 continue
2101 continue
2085 if isinstance(default, list):
2102 if isinstance(default, list):
2086 numqualifier = " %s [+]" % optlabel
2103 numqualifier = " %s [+]" % optlabel
2087 multioccur = True
2104 multioccur = True
2088 elif (default is not None) and not isinstance(default, bool):
2105 elif (default is not None) and not isinstance(default, bool):
2089 numqualifier = " %s" % optlabel
2106 numqualifier = " %s" % optlabel
2090 else:
2107 else:
2091 numqualifier = ""
2108 numqualifier = ""
2092 opt_output.append(("%2s%s" %
2109 opt_output.append(("%2s%s" %
2093 (shortopt and "-%s" % shortopt,
2110 (shortopt and "-%s" % shortopt,
2094 longopt and " --%s%s" %
2111 longopt and " --%s%s" %
2095 (longopt, numqualifier)),
2112 (longopt, numqualifier)),
2096 "%s%s" % (desc,
2113 "%s%s" % (desc,
2097 default
2114 default
2098 and _(" (default: %s)") % default
2115 and _(" (default: %s)") % default
2099 or "")))
2116 or "")))
2100 if multioccur:
2117 if multioccur:
2101 msg = _("\n[+] marked option can be specified multiple times")
2118 msg = _("\n[+] marked option can be specified multiple times")
2102 if ui.verbose and name != 'shortlist':
2119 if ui.verbose and name != 'shortlist':
2103 opt_output.append((msg, None))
2120 opt_output.append((msg, None))
2104 else:
2121 else:
2105 opt_output.insert(-1, (msg, None))
2122 opt_output.insert(-1, (msg, None))
2106
2123
2107 if not name:
2124 if not name:
2108 ui.write(_("\nadditional help topics:\n\n"))
2125 ui.write(_("\nadditional help topics:\n\n"))
2109 topics = []
2126 topics = []
2110 for names, header, doc in help.helptable:
2127 for names, header, doc in help.helptable:
2111 topics.append((sorted(names, key=len, reverse=True)[0], header))
2128 topics.append((sorted(names, key=len, reverse=True)[0], header))
2112 topics_len = max([len(s[0]) for s in topics])
2129 topics_len = max([len(s[0]) for s in topics])
2113 for t, desc in topics:
2130 for t, desc in topics:
2114 ui.write(" %-*s %s\n" % (topics_len, t, desc))
2131 ui.write(" %-*s %s\n" % (topics_len, t, desc))
2115
2132
2116 if opt_output:
2133 if opt_output:
2117 colwidth = encoding.colwidth
2134 colwidth = encoding.colwidth
2118 # normalize: (opt or message, desc or None, width of opt)
2135 # normalize: (opt or message, desc or None, width of opt)
2119 entries = [desc and (opt, desc, colwidth(opt)) or (opt, None, 0)
2136 entries = [desc and (opt, desc, colwidth(opt)) or (opt, None, 0)
2120 for opt, desc in opt_output]
2137 for opt, desc in opt_output]
2121 hanging = max([e[2] for e in entries])
2138 hanging = max([e[2] for e in entries])
2122 for opt, desc, width in entries:
2139 for opt, desc, width in entries:
2123 if desc:
2140 if desc:
2124 initindent = ' %s%s ' % (opt, ' ' * (hanging - width))
2141 initindent = ' %s%s ' % (opt, ' ' * (hanging - width))
2125 hangindent = ' ' * (hanging + 3)
2142 hangindent = ' ' * (hanging + 3)
2126 ui.write('%s\n' % (util.wrap(desc, textwidth,
2143 ui.write('%s\n' % (util.wrap(desc, textwidth,
2127 initindent=initindent,
2144 initindent=initindent,
2128 hangindent=hangindent)))
2145 hangindent=hangindent)))
2129 else:
2146 else:
2130 ui.write("%s\n" % opt)
2147 ui.write("%s\n" % opt)
2131
2148
2132 def identify(ui, repo, source=None,
2149 def identify(ui, repo, source=None,
2133 rev=None, num=None, id=None, branch=None, tags=None):
2150 rev=None, num=None, id=None, branch=None, tags=None):
2134 """identify the working copy or specified revision
2151 """identify the working copy or specified revision
2135
2152
2136 With no revision, print a summary of the current state of the
2153 With no revision, print a summary of the current state of the
2137 repository.
2154 repository.
2138
2155
2139 Specifying a path to a repository root or Mercurial bundle will
2156 Specifying a path to a repository root or Mercurial bundle will
2140 cause lookup to operate on that repository/bundle.
2157 cause lookup to operate on that repository/bundle.
2141
2158
2142 This summary identifies the repository state using one or two
2159 This summary identifies the repository state using one or two
2143 parent hash identifiers, followed by a "+" if there are
2160 parent hash identifiers, followed by a "+" if there are
2144 uncommitted changes in the working directory, a list of tags for
2161 uncommitted changes in the working directory, a list of tags for
2145 this revision and a branch name for non-default branches.
2162 this revision and a branch name for non-default branches.
2146
2163
2147 Returns 0 if successful.
2164 Returns 0 if successful.
2148 """
2165 """
2149
2166
2150 if not repo and not source:
2167 if not repo and not source:
2151 raise util.Abort(_("there is no Mercurial repository here "
2168 raise util.Abort(_("there is no Mercurial repository here "
2152 "(.hg not found)"))
2169 "(.hg not found)"))
2153
2170
2154 hexfunc = ui.debugflag and hex or short
2171 hexfunc = ui.debugflag and hex or short
2155 default = not (num or id or branch or tags)
2172 default = not (num or id or branch or tags)
2156 output = []
2173 output = []
2157
2174
2158 revs = []
2175 revs = []
2159 if source:
2176 if source:
2160 source, branches = hg.parseurl(ui.expandpath(source))
2177 source, branches = hg.parseurl(ui.expandpath(source))
2161 repo = hg.repository(ui, source)
2178 repo = hg.repository(ui, source)
2162 revs, checkout = hg.addbranchrevs(repo, repo, branches, None)
2179 revs, checkout = hg.addbranchrevs(repo, repo, branches, None)
2163
2180
2164 if not repo.local():
2181 if not repo.local():
2165 if not rev and revs:
2182 if not rev and revs:
2166 rev = revs[0]
2183 rev = revs[0]
2167 if not rev:
2184 if not rev:
2168 rev = "tip"
2185 rev = "tip"
2169 if num or branch or tags:
2186 if num or branch or tags:
2170 raise util.Abort(
2187 raise util.Abort(
2171 "can't query remote revision number, branch, or tags")
2188 "can't query remote revision number, branch, or tags")
2172 output = [hexfunc(repo.lookup(rev))]
2189 output = [hexfunc(repo.lookup(rev))]
2173 elif not rev:
2190 elif not rev:
2174 ctx = repo[None]
2191 ctx = repo[None]
2175 parents = ctx.parents()
2192 parents = ctx.parents()
2176 changed = False
2193 changed = False
2177 if default or id or num:
2194 if default or id or num:
2178 changed = util.any(repo.status())
2195 changed = util.any(repo.status())
2179 if default or id:
2196 if default or id:
2180 output = ["%s%s" % ('+'.join([hexfunc(p.node()) for p in parents]),
2197 output = ["%s%s" % ('+'.join([hexfunc(p.node()) for p in parents]),
2181 (changed) and "+" or "")]
2198 (changed) and "+" or "")]
2182 if num:
2199 if num:
2183 output.append("%s%s" % ('+'.join([str(p.rev()) for p in parents]),
2200 output.append("%s%s" % ('+'.join([str(p.rev()) for p in parents]),
2184 (changed) and "+" or ""))
2201 (changed) and "+" or ""))
2185 else:
2202 else:
2186 ctx = repo[rev]
2203 ctx = repo[rev]
2187 if default or id:
2204 if default or id:
2188 output = [hexfunc(ctx.node())]
2205 output = [hexfunc(ctx.node())]
2189 if num:
2206 if num:
2190 output.append(str(ctx.rev()))
2207 output.append(str(ctx.rev()))
2191
2208
2192 if repo.local() and default and not ui.quiet:
2209 if repo.local() and default and not ui.quiet:
2193 b = encoding.tolocal(ctx.branch())
2210 b = encoding.tolocal(ctx.branch())
2194 if b != 'default':
2211 if b != 'default':
2195 output.append("(%s)" % b)
2212 output.append("(%s)" % b)
2196
2213
2197 # multiple tags for a single parent separated by '/'
2214 # multiple tags for a single parent separated by '/'
2198 t = "/".join(ctx.tags())
2215 t = "/".join(ctx.tags())
2199 if t:
2216 if t:
2200 output.append(t)
2217 output.append(t)
2201
2218
2202 if branch:
2219 if branch:
2203 output.append(encoding.tolocal(ctx.branch()))
2220 output.append(encoding.tolocal(ctx.branch()))
2204
2221
2205 if tags:
2222 if tags:
2206 output.extend(ctx.tags())
2223 output.extend(ctx.tags())
2207
2224
2208 ui.write("%s\n" % ' '.join(output))
2225 ui.write("%s\n" % ' '.join(output))
2209
2226
2210 def import_(ui, repo, patch1, *patches, **opts):
2227 def import_(ui, repo, patch1, *patches, **opts):
2211 """import an ordered set of patches
2228 """import an ordered set of patches
2212
2229
2213 Import a list of patches and commit them individually (unless
2230 Import a list of patches and commit them individually (unless
2214 --no-commit is specified).
2231 --no-commit is specified).
2215
2232
2216 If there are outstanding changes in the working directory, import
2233 If there are outstanding changes in the working directory, import
2217 will abort unless given the -f/--force flag.
2234 will abort unless given the -f/--force flag.
2218
2235
2219 You can import a patch straight from a mail message. Even patches
2236 You can import a patch straight from a mail message. Even patches
2220 as attachments work (to use the body part, it must have type
2237 as attachments work (to use the body part, it must have type
2221 text/plain or text/x-patch). From and Subject headers of email
2238 text/plain or text/x-patch). From and Subject headers of email
2222 message are used as default committer and commit message. All
2239 message are used as default committer and commit message. All
2223 text/plain body parts before first diff are added to commit
2240 text/plain body parts before first diff are added to commit
2224 message.
2241 message.
2225
2242
2226 If the imported patch was generated by :hg:`export`, user and
2243 If the imported patch was generated by :hg:`export`, user and
2227 description from patch override values from message headers and
2244 description from patch override values from message headers and
2228 body. Values given on command line with -m/--message and -u/--user
2245 body. Values given on command line with -m/--message and -u/--user
2229 override these.
2246 override these.
2230
2247
2231 If --exact is specified, import will set the working directory to
2248 If --exact is specified, import will set the working directory to
2232 the parent of each patch before applying it, and will abort if the
2249 the parent of each patch before applying it, and will abort if the
2233 resulting changeset has a different ID than the one recorded in
2250 resulting changeset has a different ID than the one recorded in
2234 the patch. This may happen due to character set problems or other
2251 the patch. This may happen due to character set problems or other
2235 deficiencies in the text patch format.
2252 deficiencies in the text patch format.
2236
2253
2237 With -s/--similarity, hg will attempt to discover renames and
2254 With -s/--similarity, hg will attempt to discover renames and
2238 copies in the patch in the same way as 'addremove'.
2255 copies in the patch in the same way as 'addremove'.
2239
2256
2240 To read a patch from standard input, use "-" as the patch name. If
2257 To read a patch from standard input, use "-" as the patch name. If
2241 a URL is specified, the patch will be downloaded from it.
2258 a URL is specified, the patch will be downloaded from it.
2242 See :hg:`help dates` for a list of formats valid for -d/--date.
2259 See :hg:`help dates` for a list of formats valid for -d/--date.
2243
2260
2244 Returns 0 on success.
2261 Returns 0 on success.
2245 """
2262 """
2246 patches = (patch1,) + patches
2263 patches = (patch1,) + patches
2247
2264
2248 date = opts.get('date')
2265 date = opts.get('date')
2249 if date:
2266 if date:
2250 opts['date'] = util.parsedate(date)
2267 opts['date'] = util.parsedate(date)
2251
2268
2252 try:
2269 try:
2253 sim = float(opts.get('similarity') or 0)
2270 sim = float(opts.get('similarity') or 0)
2254 except ValueError:
2271 except ValueError:
2255 raise util.Abort(_('similarity must be a number'))
2272 raise util.Abort(_('similarity must be a number'))
2256 if sim < 0 or sim > 100:
2273 if sim < 0 or sim > 100:
2257 raise util.Abort(_('similarity must be between 0 and 100'))
2274 raise util.Abort(_('similarity must be between 0 and 100'))
2258
2275
2259 if opts.get('exact') or not opts.get('force'):
2276 if opts.get('exact') or not opts.get('force'):
2260 cmdutil.bail_if_changed(repo)
2277 cmdutil.bail_if_changed(repo)
2261
2278
2262 d = opts["base"]
2279 d = opts["base"]
2263 strip = opts["strip"]
2280 strip = opts["strip"]
2264 wlock = lock = None
2281 wlock = lock = None
2265
2282
2266 def tryone(ui, hunk):
2283 def tryone(ui, hunk):
2267 tmpname, message, user, date, branch, nodeid, p1, p2 = \
2284 tmpname, message, user, date, branch, nodeid, p1, p2 = \
2268 patch.extract(ui, hunk)
2285 patch.extract(ui, hunk)
2269
2286
2270 if not tmpname:
2287 if not tmpname:
2271 return None
2288 return None
2272 commitid = _('to working directory')
2289 commitid = _('to working directory')
2273
2290
2274 try:
2291 try:
2275 cmdline_message = cmdutil.logmessage(opts)
2292 cmdline_message = cmdutil.logmessage(opts)
2276 if cmdline_message:
2293 if cmdline_message:
2277 # pickup the cmdline msg
2294 # pickup the cmdline msg
2278 message = cmdline_message
2295 message = cmdline_message
2279 elif message:
2296 elif message:
2280 # pickup the patch msg
2297 # pickup the patch msg
2281 message = message.strip()
2298 message = message.strip()
2282 else:
2299 else:
2283 # launch the editor
2300 # launch the editor
2284 message = None
2301 message = None
2285 ui.debug('message:\n%s\n' % message)
2302 ui.debug('message:\n%s\n' % message)
2286
2303
2287 wp = repo.parents()
2304 wp = repo.parents()
2288 if opts.get('exact'):
2305 if opts.get('exact'):
2289 if not nodeid or not p1:
2306 if not nodeid or not p1:
2290 raise util.Abort(_('not a Mercurial patch'))
2307 raise util.Abort(_('not a Mercurial patch'))
2291 p1 = repo.lookup(p1)
2308 p1 = repo.lookup(p1)
2292 p2 = repo.lookup(p2 or hex(nullid))
2309 p2 = repo.lookup(p2 or hex(nullid))
2293
2310
2294 if p1 != wp[0].node():
2311 if p1 != wp[0].node():
2295 hg.clean(repo, p1)
2312 hg.clean(repo, p1)
2296 repo.dirstate.setparents(p1, p2)
2313 repo.dirstate.setparents(p1, p2)
2297 elif p2:
2314 elif p2:
2298 try:
2315 try:
2299 p1 = repo.lookup(p1)
2316 p1 = repo.lookup(p1)
2300 p2 = repo.lookup(p2)
2317 p2 = repo.lookup(p2)
2301 if p1 == wp[0].node():
2318 if p1 == wp[0].node():
2302 repo.dirstate.setparents(p1, p2)
2319 repo.dirstate.setparents(p1, p2)
2303 except error.RepoError:
2320 except error.RepoError:
2304 pass
2321 pass
2305 if opts.get('exact') or opts.get('import_branch'):
2322 if opts.get('exact') or opts.get('import_branch'):
2306 repo.dirstate.setbranch(branch or 'default')
2323 repo.dirstate.setbranch(branch or 'default')
2307
2324
2308 files = {}
2325 files = {}
2309 try:
2326 try:
2310 patch.patch(tmpname, ui, strip=strip, cwd=repo.root,
2327 patch.patch(tmpname, ui, strip=strip, cwd=repo.root,
2311 files=files, eolmode=None)
2328 files=files, eolmode=None)
2312 finally:
2329 finally:
2313 files = cmdutil.updatedir(ui, repo, files,
2330 files = cmdutil.updatedir(ui, repo, files,
2314 similarity=sim / 100.0)
2331 similarity=sim / 100.0)
2315 if not opts.get('no_commit'):
2332 if not opts.get('no_commit'):
2316 if opts.get('exact'):
2333 if opts.get('exact'):
2317 m = None
2334 m = None
2318 else:
2335 else:
2319 m = cmdutil.matchfiles(repo, files or [])
2336 m = cmdutil.matchfiles(repo, files or [])
2320 n = repo.commit(message, opts.get('user') or user,
2337 n = repo.commit(message, opts.get('user') or user,
2321 opts.get('date') or date, match=m,
2338 opts.get('date') or date, match=m,
2322 editor=cmdutil.commiteditor)
2339 editor=cmdutil.commiteditor)
2323 if opts.get('exact'):
2340 if opts.get('exact'):
2324 if hex(n) != nodeid:
2341 if hex(n) != nodeid:
2325 repo.rollback()
2342 repo.rollback()
2326 raise util.Abort(_('patch is damaged'
2343 raise util.Abort(_('patch is damaged'
2327 ' or loses information'))
2344 ' or loses information'))
2328 # Force a dirstate write so that the next transaction
2345 # Force a dirstate write so that the next transaction
2329 # backups an up-do-date file.
2346 # backups an up-do-date file.
2330 repo.dirstate.write()
2347 repo.dirstate.write()
2331 if n:
2348 if n:
2332 commitid = short(n)
2349 commitid = short(n)
2333
2350
2334 return commitid
2351 return commitid
2335 finally:
2352 finally:
2336 os.unlink(tmpname)
2353 os.unlink(tmpname)
2337
2354
2338 try:
2355 try:
2339 wlock = repo.wlock()
2356 wlock = repo.wlock()
2340 lock = repo.lock()
2357 lock = repo.lock()
2341 lastcommit = None
2358 lastcommit = None
2342 for p in patches:
2359 for p in patches:
2343 pf = os.path.join(d, p)
2360 pf = os.path.join(d, p)
2344
2361
2345 if pf == '-':
2362 if pf == '-':
2346 ui.status(_("applying patch from stdin\n"))
2363 ui.status(_("applying patch from stdin\n"))
2347 pf = sys.stdin
2364 pf = sys.stdin
2348 else:
2365 else:
2349 ui.status(_("applying %s\n") % p)
2366 ui.status(_("applying %s\n") % p)
2350 pf = url.open(ui, pf)
2367 pf = url.open(ui, pf)
2351
2368
2352 haspatch = False
2369 haspatch = False
2353 for hunk in patch.split(pf):
2370 for hunk in patch.split(pf):
2354 commitid = tryone(ui, hunk)
2371 commitid = tryone(ui, hunk)
2355 if commitid:
2372 if commitid:
2356 haspatch = True
2373 haspatch = True
2357 if lastcommit:
2374 if lastcommit:
2358 ui.status(_('applied %s\n') % lastcommit)
2375 ui.status(_('applied %s\n') % lastcommit)
2359 lastcommit = commitid
2376 lastcommit = commitid
2360
2377
2361 if not haspatch:
2378 if not haspatch:
2362 raise util.Abort(_('no diffs found'))
2379 raise util.Abort(_('no diffs found'))
2363
2380
2364 finally:
2381 finally:
2365 release(lock, wlock)
2382 release(lock, wlock)
2366
2383
2367 def incoming(ui, repo, source="default", **opts):
2384 def incoming(ui, repo, source="default", **opts):
2368 """show new changesets found in source
2385 """show new changesets found in source
2369
2386
2370 Show new changesets found in the specified path/URL or the default
2387 Show new changesets found in the specified path/URL or the default
2371 pull location. These are the changesets that would have been pulled
2388 pull location. These are the changesets that would have been pulled
2372 if a pull at the time you issued this command.
2389 if a pull at the time you issued this command.
2373
2390
2374 For remote repository, using --bundle avoids downloading the
2391 For remote repository, using --bundle avoids downloading the
2375 changesets twice if the incoming is followed by a pull.
2392 changesets twice if the incoming is followed by a pull.
2376
2393
2377 See pull for valid source format details.
2394 See pull for valid source format details.
2378
2395
2379 Returns 0 if there are incoming changes, 1 otherwise.
2396 Returns 0 if there are incoming changes, 1 otherwise.
2380 """
2397 """
2381 if opts.get('bundle') and opts.get('subrepos'):
2398 if opts.get('bundle') and opts.get('subrepos'):
2382 raise util.Abort(_('cannot combine --bundle and --subrepos'))
2399 raise util.Abort(_('cannot combine --bundle and --subrepos'))
2383
2400
2384 ret = hg.incoming(ui, repo, source, opts)
2401 ret = hg.incoming(ui, repo, source, opts)
2385 return ret
2402 return ret
2386
2403
2387 def init(ui, dest=".", **opts):
2404 def init(ui, dest=".", **opts):
2388 """create a new repository in the given directory
2405 """create a new repository in the given directory
2389
2406
2390 Initialize a new repository in the given directory. If the given
2407 Initialize a new repository in the given directory. If the given
2391 directory does not exist, it will be created.
2408 directory does not exist, it will be created.
2392
2409
2393 If no directory is given, the current directory is used.
2410 If no directory is given, the current directory is used.
2394
2411
2395 It is possible to specify an ``ssh://`` URL as the destination.
2412 It is possible to specify an ``ssh://`` URL as the destination.
2396 See :hg:`help urls` for more information.
2413 See :hg:`help urls` for more information.
2397
2414
2398 Returns 0 on success.
2415 Returns 0 on success.
2399 """
2416 """
2400 hg.repository(hg.remoteui(ui, opts), ui.expandpath(dest), create=1)
2417 hg.repository(hg.remoteui(ui, opts), ui.expandpath(dest), create=1)
2401
2418
2402 def locate(ui, repo, *pats, **opts):
2419 def locate(ui, repo, *pats, **opts):
2403 """locate files matching specific patterns
2420 """locate files matching specific patterns
2404
2421
2405 Print files under Mercurial control in the working directory whose
2422 Print files under Mercurial control in the working directory whose
2406 names match the given patterns.
2423 names match the given patterns.
2407
2424
2408 By default, this command searches all directories in the working
2425 By default, this command searches all directories in the working
2409 directory. To search just the current directory and its
2426 directory. To search just the current directory and its
2410 subdirectories, use "--include .".
2427 subdirectories, use "--include .".
2411
2428
2412 If no patterns are given to match, this command prints the names
2429 If no patterns are given to match, this command prints the names
2413 of all files under Mercurial control in the working directory.
2430 of all files under Mercurial control in the working directory.
2414
2431
2415 If you want to feed the output of this command into the "xargs"
2432 If you want to feed the output of this command into the "xargs"
2416 command, use the -0 option to both this command and "xargs". This
2433 command, use the -0 option to both this command and "xargs". This
2417 will avoid the problem of "xargs" treating single filenames that
2434 will avoid the problem of "xargs" treating single filenames that
2418 contain whitespace as multiple filenames.
2435 contain whitespace as multiple filenames.
2419
2436
2420 Returns 0 if a match is found, 1 otherwise.
2437 Returns 0 if a match is found, 1 otherwise.
2421 """
2438 """
2422 end = opts.get('print0') and '\0' or '\n'
2439 end = opts.get('print0') and '\0' or '\n'
2423 rev = opts.get('rev') or None
2440 rev = opts.get('rev') or None
2424
2441
2425 ret = 1
2442 ret = 1
2426 m = cmdutil.match(repo, pats, opts, default='relglob')
2443 m = cmdutil.match(repo, pats, opts, default='relglob')
2427 m.bad = lambda x, y: False
2444 m.bad = lambda x, y: False
2428 for abs in repo[rev].walk(m):
2445 for abs in repo[rev].walk(m):
2429 if not rev and abs not in repo.dirstate:
2446 if not rev and abs not in repo.dirstate:
2430 continue
2447 continue
2431 if opts.get('fullpath'):
2448 if opts.get('fullpath'):
2432 ui.write(repo.wjoin(abs), end)
2449 ui.write(repo.wjoin(abs), end)
2433 else:
2450 else:
2434 ui.write(((pats and m.rel(abs)) or abs), end)
2451 ui.write(((pats and m.rel(abs)) or abs), end)
2435 ret = 0
2452 ret = 0
2436
2453
2437 return ret
2454 return ret
2438
2455
2439 def log(ui, repo, *pats, **opts):
2456 def log(ui, repo, *pats, **opts):
2440 """show revision history of entire repository or files
2457 """show revision history of entire repository or files
2441
2458
2442 Print the revision history of the specified files or the entire
2459 Print the revision history of the specified files or the entire
2443 project.
2460 project.
2444
2461
2445 File history is shown without following rename or copy history of
2462 File history is shown without following rename or copy history of
2446 files. Use -f/--follow with a filename to follow history across
2463 files. Use -f/--follow with a filename to follow history across
2447 renames and copies. --follow without a filename will only show
2464 renames and copies. --follow without a filename will only show
2448 ancestors or descendants of the starting revision. --follow-first
2465 ancestors or descendants of the starting revision. --follow-first
2449 only follows the first parent of merge revisions.
2466 only follows the first parent of merge revisions.
2450
2467
2451 If no revision range is specified, the default is ``tip:0`` unless
2468 If no revision range is specified, the default is ``tip:0`` unless
2452 --follow is set, in which case the working directory parent is
2469 --follow is set, in which case the working directory parent is
2453 used as the starting revision. You can specify a revision set for
2470 used as the starting revision. You can specify a revision set for
2454 log, see :hg:`help revsets` for more information.
2471 log, see :hg:`help revsets` for more information.
2455
2472
2456 See :hg:`help dates` for a list of formats valid for -d/--date.
2473 See :hg:`help dates` for a list of formats valid for -d/--date.
2457
2474
2458 By default this command prints revision number and changeset id,
2475 By default this command prints revision number and changeset id,
2459 tags, non-trivial parents, user, date and time, and a summary for
2476 tags, non-trivial parents, user, date and time, and a summary for
2460 each commit. When the -v/--verbose switch is used, the list of
2477 each commit. When the -v/--verbose switch is used, the list of
2461 changed files and full commit message are shown.
2478 changed files and full commit message are shown.
2462
2479
2463 .. note::
2480 .. note::
2464 log -p/--patch may generate unexpected diff output for merge
2481 log -p/--patch may generate unexpected diff output for merge
2465 changesets, as it will only compare the merge changeset against
2482 changesets, as it will only compare the merge changeset against
2466 its first parent. Also, only files different from BOTH parents
2483 its first parent. Also, only files different from BOTH parents
2467 will appear in files:.
2484 will appear in files:.
2468
2485
2469 Returns 0 on success.
2486 Returns 0 on success.
2470 """
2487 """
2471
2488
2472 matchfn = cmdutil.match(repo, pats, opts)
2489 matchfn = cmdutil.match(repo, pats, opts)
2473 limit = cmdutil.loglimit(opts)
2490 limit = cmdutil.loglimit(opts)
2474 count = 0
2491 count = 0
2475
2492
2476 endrev = None
2493 endrev = None
2477 if opts.get('copies') and opts.get('rev'):
2494 if opts.get('copies') and opts.get('rev'):
2478 endrev = max(cmdutil.revrange(repo, opts.get('rev'))) + 1
2495 endrev = max(cmdutil.revrange(repo, opts.get('rev'))) + 1
2479
2496
2480 df = False
2497 df = False
2481 if opts["date"]:
2498 if opts["date"]:
2482 df = util.matchdate(opts["date"])
2499 df = util.matchdate(opts["date"])
2483
2500
2484 branches = opts.get('branch', []) + opts.get('only_branch', [])
2501 branches = opts.get('branch', []) + opts.get('only_branch', [])
2485 opts['branch'] = [repo.lookupbranch(b) for b in branches]
2502 opts['branch'] = [repo.lookupbranch(b) for b in branches]
2486
2503
2487 displayer = cmdutil.show_changeset(ui, repo, opts, True)
2504 displayer = cmdutil.show_changeset(ui, repo, opts, True)
2488 def prep(ctx, fns):
2505 def prep(ctx, fns):
2489 rev = ctx.rev()
2506 rev = ctx.rev()
2490 parents = [p for p in repo.changelog.parentrevs(rev)
2507 parents = [p for p in repo.changelog.parentrevs(rev)
2491 if p != nullrev]
2508 if p != nullrev]
2492 if opts.get('no_merges') and len(parents) == 2:
2509 if opts.get('no_merges') and len(parents) == 2:
2493 return
2510 return
2494 if opts.get('only_merges') and len(parents) != 2:
2511 if opts.get('only_merges') and len(parents) != 2:
2495 return
2512 return
2496 if opts.get('branch') and ctx.branch() not in opts['branch']:
2513 if opts.get('branch') and ctx.branch() not in opts['branch']:
2497 return
2514 return
2498 if df and not df(ctx.date()[0]):
2515 if df and not df(ctx.date()[0]):
2499 return
2516 return
2500 if opts['user'] and not [k for k in opts['user']
2517 if opts['user'] and not [k for k in opts['user']
2501 if k.lower() in ctx.user().lower()]:
2518 if k.lower() in ctx.user().lower()]:
2502 return
2519 return
2503 if opts.get('keyword'):
2520 if opts.get('keyword'):
2504 for k in [kw.lower() for kw in opts['keyword']]:
2521 for k in [kw.lower() for kw in opts['keyword']]:
2505 if (k in ctx.user().lower() or
2522 if (k in ctx.user().lower() or
2506 k in ctx.description().lower() or
2523 k in ctx.description().lower() or
2507 k in " ".join(ctx.files()).lower()):
2524 k in " ".join(ctx.files()).lower()):
2508 break
2525 break
2509 else:
2526 else:
2510 return
2527 return
2511
2528
2512 copies = None
2529 copies = None
2513 if opts.get('copies') and rev:
2530 if opts.get('copies') and rev:
2514 copies = []
2531 copies = []
2515 getrenamed = templatekw.getrenamedfn(repo, endrev=endrev)
2532 getrenamed = templatekw.getrenamedfn(repo, endrev=endrev)
2516 for fn in ctx.files():
2533 for fn in ctx.files():
2517 rename = getrenamed(fn, rev)
2534 rename = getrenamed(fn, rev)
2518 if rename:
2535 if rename:
2519 copies.append((fn, rename[0]))
2536 copies.append((fn, rename[0]))
2520
2537
2521 revmatchfn = None
2538 revmatchfn = None
2522 if opts.get('patch') or opts.get('stat'):
2539 if opts.get('patch') or opts.get('stat'):
2523 if opts.get('follow') or opts.get('follow_first'):
2540 if opts.get('follow') or opts.get('follow_first'):
2524 # note: this might be wrong when following through merges
2541 # note: this might be wrong when following through merges
2525 revmatchfn = cmdutil.match(repo, fns, default='path')
2542 revmatchfn = cmdutil.match(repo, fns, default='path')
2526 else:
2543 else:
2527 revmatchfn = matchfn
2544 revmatchfn = matchfn
2528
2545
2529 displayer.show(ctx, copies=copies, matchfn=revmatchfn)
2546 displayer.show(ctx, copies=copies, matchfn=revmatchfn)
2530
2547
2531 for ctx in cmdutil.walkchangerevs(repo, matchfn, opts, prep):
2548 for ctx in cmdutil.walkchangerevs(repo, matchfn, opts, prep):
2532 if count == limit:
2549 if count == limit:
2533 break
2550 break
2534 if displayer.flush(ctx.rev()):
2551 if displayer.flush(ctx.rev()):
2535 count += 1
2552 count += 1
2536 displayer.close()
2553 displayer.close()
2537
2554
2538 def manifest(ui, repo, node=None, rev=None):
2555 def manifest(ui, repo, node=None, rev=None):
2539 """output the current or given revision of the project manifest
2556 """output the current or given revision of the project manifest
2540
2557
2541 Print a list of version controlled files for the given revision.
2558 Print a list of version controlled files for the given revision.
2542 If no revision is given, the first parent of the working directory
2559 If no revision is given, the first parent of the working directory
2543 is used, or the null revision if no revision is checked out.
2560 is used, or the null revision if no revision is checked out.
2544
2561
2545 With -v, print file permissions, symlink and executable bits.
2562 With -v, print file permissions, symlink and executable bits.
2546 With --debug, print file revision hashes.
2563 With --debug, print file revision hashes.
2547
2564
2548 Returns 0 on success.
2565 Returns 0 on success.
2549 """
2566 """
2550
2567
2551 if rev and node:
2568 if rev and node:
2552 raise util.Abort(_("please specify just one revision"))
2569 raise util.Abort(_("please specify just one revision"))
2553
2570
2554 if not node:
2571 if not node:
2555 node = rev
2572 node = rev
2556
2573
2557 decor = {'l':'644 @ ', 'x':'755 * ', '':'644 '}
2574 decor = {'l':'644 @ ', 'x':'755 * ', '':'644 '}
2558 ctx = repo[node]
2575 ctx = repo[node]
2559 for f in ctx:
2576 for f in ctx:
2560 if ui.debugflag:
2577 if ui.debugflag:
2561 ui.write("%40s " % hex(ctx.manifest()[f]))
2578 ui.write("%40s " % hex(ctx.manifest()[f]))
2562 if ui.verbose:
2579 if ui.verbose:
2563 ui.write(decor[ctx.flags(f)])
2580 ui.write(decor[ctx.flags(f)])
2564 ui.write("%s\n" % f)
2581 ui.write("%s\n" % f)
2565
2582
2566 def merge(ui, repo, node=None, **opts):
2583 def merge(ui, repo, node=None, **opts):
2567 """merge working directory with another revision
2584 """merge working directory with another revision
2568
2585
2569 The current working directory is updated with all changes made in
2586 The current working directory is updated with all changes made in
2570 the requested revision since the last common predecessor revision.
2587 the requested revision since the last common predecessor revision.
2571
2588
2572 Files that changed between either parent are marked as changed for
2589 Files that changed between either parent are marked as changed for
2573 the next commit and a commit must be performed before any further
2590 the next commit and a commit must be performed before any further
2574 updates to the repository are allowed. The next commit will have
2591 updates to the repository are allowed. The next commit will have
2575 two parents.
2592 two parents.
2576
2593
2577 ``--tool`` can be used to specify the merge tool used for file
2594 ``--tool`` can be used to specify the merge tool used for file
2578 merges. It overrides the HGMERGE environment variable and your
2595 merges. It overrides the HGMERGE environment variable and your
2579 configuration files.
2596 configuration files.
2580
2597
2581 If no revision is specified, the working directory's parent is a
2598 If no revision is specified, the working directory's parent is a
2582 head revision, and the current branch contains exactly one other
2599 head revision, and the current branch contains exactly one other
2583 head, the other head is merged with by default. Otherwise, an
2600 head, the other head is merged with by default. Otherwise, an
2584 explicit revision with which to merge with must be provided.
2601 explicit revision with which to merge with must be provided.
2585
2602
2586 :hg:`resolve` must be used to resolve unresolved files.
2603 :hg:`resolve` must be used to resolve unresolved files.
2587
2604
2588 To undo an uncommitted merge, use :hg:`update --clean .` which
2605 To undo an uncommitted merge, use :hg:`update --clean .` which
2589 will check out a clean copy of the original merge parent, losing
2606 will check out a clean copy of the original merge parent, losing
2590 all changes.
2607 all changes.
2591
2608
2592 Returns 0 on success, 1 if there are unresolved files.
2609 Returns 0 on success, 1 if there are unresolved files.
2593 """
2610 """
2594
2611
2595 if opts.get('rev') and node:
2612 if opts.get('rev') and node:
2596 raise util.Abort(_("please specify just one revision"))
2613 raise util.Abort(_("please specify just one revision"))
2597 if not node:
2614 if not node:
2598 node = opts.get('rev')
2615 node = opts.get('rev')
2599
2616
2600 if not node:
2617 if not node:
2601 branch = repo.changectx(None).branch()
2618 branch = repo.changectx(None).branch()
2602 bheads = repo.branchheads(branch)
2619 bheads = repo.branchheads(branch)
2603 if len(bheads) > 2:
2620 if len(bheads) > 2:
2604 raise util.Abort(_(
2621 raise util.Abort(_(
2605 'branch \'%s\' has %d heads - '
2622 'branch \'%s\' has %d heads - '
2606 'please merge with an explicit rev\n'
2623 'please merge with an explicit rev\n'
2607 '(run \'hg heads .\' to see heads)')
2624 '(run \'hg heads .\' to see heads)')
2608 % (branch, len(bheads)))
2625 % (branch, len(bheads)))
2609
2626
2610 parent = repo.dirstate.parents()[0]
2627 parent = repo.dirstate.parents()[0]
2611 if len(bheads) == 1:
2628 if len(bheads) == 1:
2612 if len(repo.heads()) > 1:
2629 if len(repo.heads()) > 1:
2613 raise util.Abort(_(
2630 raise util.Abort(_(
2614 'branch \'%s\' has one head - '
2631 'branch \'%s\' has one head - '
2615 'please merge with an explicit rev\n'
2632 'please merge with an explicit rev\n'
2616 '(run \'hg heads\' to see all heads)')
2633 '(run \'hg heads\' to see all heads)')
2617 % branch)
2634 % branch)
2618 msg = _('there is nothing to merge')
2635 msg = _('there is nothing to merge')
2619 if parent != repo.lookup(repo[None].branch()):
2636 if parent != repo.lookup(repo[None].branch()):
2620 msg = _('%s - use "hg update" instead') % msg
2637 msg = _('%s - use "hg update" instead') % msg
2621 raise util.Abort(msg)
2638 raise util.Abort(msg)
2622
2639
2623 if parent not in bheads:
2640 if parent not in bheads:
2624 raise util.Abort(_('working dir not at a head rev - '
2641 raise util.Abort(_('working dir not at a head rev - '
2625 'use "hg update" or merge with an explicit rev'))
2642 'use "hg update" or merge with an explicit rev'))
2626 node = parent == bheads[0] and bheads[-1] or bheads[0]
2643 node = parent == bheads[0] and bheads[-1] or bheads[0]
2627
2644
2628 if opts.get('preview'):
2645 if opts.get('preview'):
2629 # find nodes that are ancestors of p2 but not of p1
2646 # find nodes that are ancestors of p2 but not of p1
2630 p1 = repo.lookup('.')
2647 p1 = repo.lookup('.')
2631 p2 = repo.lookup(node)
2648 p2 = repo.lookup(node)
2632 nodes = repo.changelog.findmissing(common=[p1], heads=[p2])
2649 nodes = repo.changelog.findmissing(common=[p1], heads=[p2])
2633
2650
2634 displayer = cmdutil.show_changeset(ui, repo, opts)
2651 displayer = cmdutil.show_changeset(ui, repo, opts)
2635 for node in nodes:
2652 for node in nodes:
2636 displayer.show(repo[node])
2653 displayer.show(repo[node])
2637 displayer.close()
2654 displayer.close()
2638 return 0
2655 return 0
2639
2656
2640 try:
2657 try:
2641 # ui.forcemerge is an internal variable, do not document
2658 # ui.forcemerge is an internal variable, do not document
2642 ui.setconfig('ui', 'forcemerge', opts.get('tool', ''))
2659 ui.setconfig('ui', 'forcemerge', opts.get('tool', ''))
2643 return hg.merge(repo, node, force=opts.get('force'))
2660 return hg.merge(repo, node, force=opts.get('force'))
2644 finally:
2661 finally:
2645 ui.setconfig('ui', 'forcemerge', '')
2662 ui.setconfig('ui', 'forcemerge', '')
2646
2663
2647 def outgoing(ui, repo, dest=None, **opts):
2664 def outgoing(ui, repo, dest=None, **opts):
2648 """show changesets not found in the destination
2665 """show changesets not found in the destination
2649
2666
2650 Show changesets not found in the specified destination repository
2667 Show changesets not found in the specified destination repository
2651 or the default push location. These are the changesets that would
2668 or the default push location. These are the changesets that would
2652 be pushed if a push was requested.
2669 be pushed if a push was requested.
2653
2670
2654 See pull for details of valid destination formats.
2671 See pull for details of valid destination formats.
2655
2672
2656 Returns 0 if there are outgoing changes, 1 otherwise.
2673 Returns 0 if there are outgoing changes, 1 otherwise.
2657 """
2674 """
2658 ret = hg.outgoing(ui, repo, dest, opts)
2675 ret = hg.outgoing(ui, repo, dest, opts)
2659 return ret
2676 return ret
2660
2677
2661 def parents(ui, repo, file_=None, **opts):
2678 def parents(ui, repo, file_=None, **opts):
2662 """show the parents of the working directory or revision
2679 """show the parents of the working directory or revision
2663
2680
2664 Print the working directory's parent revisions. If a revision is
2681 Print the working directory's parent revisions. If a revision is
2665 given via -r/--rev, the parent of that revision will be printed.
2682 given via -r/--rev, the parent of that revision will be printed.
2666 If a file argument is given, the revision in which the file was
2683 If a file argument is given, the revision in which the file was
2667 last changed (before the working directory revision or the
2684 last changed (before the working directory revision or the
2668 argument to --rev if given) is printed.
2685 argument to --rev if given) is printed.
2669
2686
2670 Returns 0 on success.
2687 Returns 0 on success.
2671 """
2688 """
2672 rev = opts.get('rev')
2689 rev = opts.get('rev')
2673 if rev:
2690 if rev:
2674 ctx = repo[rev]
2691 ctx = repo[rev]
2675 else:
2692 else:
2676 ctx = repo[None]
2693 ctx = repo[None]
2677
2694
2678 if file_:
2695 if file_:
2679 m = cmdutil.match(repo, (file_,), opts)
2696 m = cmdutil.match(repo, (file_,), opts)
2680 if m.anypats() or len(m.files()) != 1:
2697 if m.anypats() or len(m.files()) != 1:
2681 raise util.Abort(_('can only specify an explicit filename'))
2698 raise util.Abort(_('can only specify an explicit filename'))
2682 file_ = m.files()[0]
2699 file_ = m.files()[0]
2683 filenodes = []
2700 filenodes = []
2684 for cp in ctx.parents():
2701 for cp in ctx.parents():
2685 if not cp:
2702 if not cp:
2686 continue
2703 continue
2687 try:
2704 try:
2688 filenodes.append(cp.filenode(file_))
2705 filenodes.append(cp.filenode(file_))
2689 except error.LookupError:
2706 except error.LookupError:
2690 pass
2707 pass
2691 if not filenodes:
2708 if not filenodes:
2692 raise util.Abort(_("'%s' not found in manifest!") % file_)
2709 raise util.Abort(_("'%s' not found in manifest!") % file_)
2693 fl = repo.file(file_)
2710 fl = repo.file(file_)
2694 p = [repo.lookup(fl.linkrev(fl.rev(fn))) for fn in filenodes]
2711 p = [repo.lookup(fl.linkrev(fl.rev(fn))) for fn in filenodes]
2695 else:
2712 else:
2696 p = [cp.node() for cp in ctx.parents()]
2713 p = [cp.node() for cp in ctx.parents()]
2697
2714
2698 displayer = cmdutil.show_changeset(ui, repo, opts)
2715 displayer = cmdutil.show_changeset(ui, repo, opts)
2699 for n in p:
2716 for n in p:
2700 if n != nullid:
2717 if n != nullid:
2701 displayer.show(repo[n])
2718 displayer.show(repo[n])
2702 displayer.close()
2719 displayer.close()
2703
2720
2704 def paths(ui, repo, search=None):
2721 def paths(ui, repo, search=None):
2705 """show aliases for remote repositories
2722 """show aliases for remote repositories
2706
2723
2707 Show definition of symbolic path name NAME. If no name is given,
2724 Show definition of symbolic path name NAME. If no name is given,
2708 show definition of all available names.
2725 show definition of all available names.
2709
2726
2710 Path names are defined in the [paths] section of your
2727 Path names are defined in the [paths] section of your
2711 configuration file and in ``/etc/mercurial/hgrc``. If run inside a
2728 configuration file and in ``/etc/mercurial/hgrc``. If run inside a
2712 repository, ``.hg/hgrc`` is used, too.
2729 repository, ``.hg/hgrc`` is used, too.
2713
2730
2714 The path names ``default`` and ``default-push`` have a special
2731 The path names ``default`` and ``default-push`` have a special
2715 meaning. When performing a push or pull operation, they are used
2732 meaning. When performing a push or pull operation, they are used
2716 as fallbacks if no location is specified on the command-line.
2733 as fallbacks if no location is specified on the command-line.
2717 When ``default-push`` is set, it will be used for push and
2734 When ``default-push`` is set, it will be used for push and
2718 ``default`` will be used for pull; otherwise ``default`` is used
2735 ``default`` will be used for pull; otherwise ``default`` is used
2719 as the fallback for both. When cloning a repository, the clone
2736 as the fallback for both. When cloning a repository, the clone
2720 source is written as ``default`` in ``.hg/hgrc``. Note that
2737 source is written as ``default`` in ``.hg/hgrc``. Note that
2721 ``default`` and ``default-push`` apply to all inbound (e.g.
2738 ``default`` and ``default-push`` apply to all inbound (e.g.
2722 :hg:`incoming`) and outbound (e.g. :hg:`outgoing`, :hg:`email` and
2739 :hg:`incoming`) and outbound (e.g. :hg:`outgoing`, :hg:`email` and
2723 :hg:`bundle`) operations.
2740 :hg:`bundle`) operations.
2724
2741
2725 See :hg:`help urls` for more information.
2742 See :hg:`help urls` for more information.
2726
2743
2727 Returns 0 on success.
2744 Returns 0 on success.
2728 """
2745 """
2729 if search:
2746 if search:
2730 for name, path in ui.configitems("paths"):
2747 for name, path in ui.configitems("paths"):
2731 if name == search:
2748 if name == search:
2732 ui.write("%s\n" % url.hidepassword(path))
2749 ui.write("%s\n" % url.hidepassword(path))
2733 return
2750 return
2734 ui.warn(_("not found!\n"))
2751 ui.warn(_("not found!\n"))
2735 return 1
2752 return 1
2736 else:
2753 else:
2737 for name, path in ui.configitems("paths"):
2754 for name, path in ui.configitems("paths"):
2738 ui.write("%s = %s\n" % (name, url.hidepassword(path)))
2755 ui.write("%s = %s\n" % (name, url.hidepassword(path)))
2739
2756
2740 def postincoming(ui, repo, modheads, optupdate, checkout):
2757 def postincoming(ui, repo, modheads, optupdate, checkout):
2741 if modheads == 0:
2758 if modheads == 0:
2742 return
2759 return
2743 if optupdate:
2760 if optupdate:
2744 if (modheads <= 1 or len(repo.branchheads()) == 1) or checkout:
2761 if (modheads <= 1 or len(repo.branchheads()) == 1) or checkout:
2745 return hg.update(repo, checkout)
2762 return hg.update(repo, checkout)
2746 else:
2763 else:
2747 ui.status(_("not updating, since new heads added\n"))
2764 ui.status(_("not updating, since new heads added\n"))
2748 if modheads > 1:
2765 if modheads > 1:
2749 ui.status(_("(run 'hg heads' to see heads, 'hg merge' to merge)\n"))
2766 ui.status(_("(run 'hg heads' to see heads, 'hg merge' to merge)\n"))
2750 else:
2767 else:
2751 ui.status(_("(run 'hg update' to get a working copy)\n"))
2768 ui.status(_("(run 'hg update' to get a working copy)\n"))
2752
2769
2753 def pull(ui, repo, source="default", **opts):
2770 def pull(ui, repo, source="default", **opts):
2754 """pull changes from the specified source
2771 """pull changes from the specified source
2755
2772
2756 Pull changes from a remote repository to a local one.
2773 Pull changes from a remote repository to a local one.
2757
2774
2758 This finds all changes from the repository at the specified path
2775 This finds all changes from the repository at the specified path
2759 or URL and adds them to a local repository (the current one unless
2776 or URL and adds them to a local repository (the current one unless
2760 -R is specified). By default, this does not update the copy of the
2777 -R is specified). By default, this does not update the copy of the
2761 project in the working directory.
2778 project in the working directory.
2762
2779
2763 Use :hg:`incoming` if you want to see what would have been added
2780 Use :hg:`incoming` if you want to see what would have been added
2764 by a pull at the time you issued this command. If you then decide
2781 by a pull at the time you issued this command. If you then decide
2765 to add those changes to the repository, you should use :hg:`pull
2782 to add those changes to the repository, you should use :hg:`pull
2766 -r X` where ``X`` is the last changeset listed by :hg:`incoming`.
2783 -r X` where ``X`` is the last changeset listed by :hg:`incoming`.
2767
2784
2768 If SOURCE is omitted, the 'default' path will be used.
2785 If SOURCE is omitted, the 'default' path will be used.
2769 See :hg:`help urls` for more information.
2786 See :hg:`help urls` for more information.
2770
2787
2771 Returns 0 on success, 1 if an update had unresolved files.
2788 Returns 0 on success, 1 if an update had unresolved files.
2772 """
2789 """
2773 source, branches = hg.parseurl(ui.expandpath(source), opts.get('branch'))
2790 source, branches = hg.parseurl(ui.expandpath(source), opts.get('branch'))
2774 other = hg.repository(hg.remoteui(repo, opts), source)
2791 other = hg.repository(hg.remoteui(repo, opts), source)
2775 ui.status(_('pulling from %s\n') % url.hidepassword(source))
2792 ui.status(_('pulling from %s\n') % url.hidepassword(source))
2776 revs, checkout = hg.addbranchrevs(repo, other, branches, opts.get('rev'))
2793 revs, checkout = hg.addbranchrevs(repo, other, branches, opts.get('rev'))
2777 if revs:
2794 if revs:
2778 try:
2795 try:
2779 revs = [other.lookup(rev) for rev in revs]
2796 revs = [other.lookup(rev) for rev in revs]
2780 except error.CapabilityError:
2797 except error.CapabilityError:
2781 err = _("other repository doesn't support revision lookup, "
2798 err = _("other repository doesn't support revision lookup, "
2782 "so a rev cannot be specified.")
2799 "so a rev cannot be specified.")
2783 raise util.Abort(err)
2800 raise util.Abort(err)
2784
2801
2785 modheads = repo.pull(other, heads=revs, force=opts.get('force'))
2802 modheads = repo.pull(other, heads=revs, force=opts.get('force'))
2786 if checkout:
2803 if checkout:
2787 checkout = str(repo.changelog.rev(other.lookup(checkout)))
2804 checkout = str(repo.changelog.rev(other.lookup(checkout)))
2788 repo._subtoppath = source
2805 repo._subtoppath = source
2789 try:
2806 try:
2790 return postincoming(ui, repo, modheads, opts.get('update'), checkout)
2807 return postincoming(ui, repo, modheads, opts.get('update'), checkout)
2791 finally:
2808 finally:
2792 del repo._subtoppath
2809 del repo._subtoppath
2793
2810
2794 def push(ui, repo, dest=None, **opts):
2811 def push(ui, repo, dest=None, **opts):
2795 """push changes to the specified destination
2812 """push changes to the specified destination
2796
2813
2797 Push changesets from the local repository to the specified
2814 Push changesets from the local repository to the specified
2798 destination.
2815 destination.
2799
2816
2800 This operation is symmetrical to pull: it is identical to a pull
2817 This operation is symmetrical to pull: it is identical to a pull
2801 in the destination repository from the current one.
2818 in the destination repository from the current one.
2802
2819
2803 By default, push will not allow creation of new heads at the
2820 By default, push will not allow creation of new heads at the
2804 destination, since multiple heads would make it unclear which head
2821 destination, since multiple heads would make it unclear which head
2805 to use. In this situation, it is recommended to pull and merge
2822 to use. In this situation, it is recommended to pull and merge
2806 before pushing.
2823 before pushing.
2807
2824
2808 Use --new-branch if you want to allow push to create a new named
2825 Use --new-branch if you want to allow push to create a new named
2809 branch that is not present at the destination. This allows you to
2826 branch that is not present at the destination. This allows you to
2810 only create a new branch without forcing other changes.
2827 only create a new branch without forcing other changes.
2811
2828
2812 Use -f/--force to override the default behavior and push all
2829 Use -f/--force to override the default behavior and push all
2813 changesets on all branches.
2830 changesets on all branches.
2814
2831
2815 If -r/--rev is used, the specified revision and all its ancestors
2832 If -r/--rev is used, the specified revision and all its ancestors
2816 will be pushed to the remote repository.
2833 will be pushed to the remote repository.
2817
2834
2818 Please see :hg:`help urls` for important details about ``ssh://``
2835 Please see :hg:`help urls` for important details about ``ssh://``
2819 URLs. If DESTINATION is omitted, a default path will be used.
2836 URLs. If DESTINATION is omitted, a default path will be used.
2820
2837
2821 Returns 0 if push was successful, 1 if nothing to push.
2838 Returns 0 if push was successful, 1 if nothing to push.
2822 """
2839 """
2823 dest = ui.expandpath(dest or 'default-push', dest or 'default')
2840 dest = ui.expandpath(dest or 'default-push', dest or 'default')
2824 dest, branches = hg.parseurl(dest, opts.get('branch'))
2841 dest, branches = hg.parseurl(dest, opts.get('branch'))
2825 revs, checkout = hg.addbranchrevs(repo, repo, branches, opts.get('rev'))
2842 revs, checkout = hg.addbranchrevs(repo, repo, branches, opts.get('rev'))
2826 other = hg.repository(hg.remoteui(repo, opts), dest)
2843 other = hg.repository(hg.remoteui(repo, opts), dest)
2827 ui.status(_('pushing to %s\n') % url.hidepassword(dest))
2844 ui.status(_('pushing to %s\n') % url.hidepassword(dest))
2828 if revs:
2845 if revs:
2829 revs = [repo.lookup(rev) for rev in revs]
2846 revs = [repo.lookup(rev) for rev in revs]
2830
2847
2831 repo._subtoppath = dest
2848 repo._subtoppath = dest
2832 try:
2849 try:
2833 # push subrepos depth-first for coherent ordering
2850 # push subrepos depth-first for coherent ordering
2834 c = repo['']
2851 c = repo['']
2835 subs = c.substate # only repos that are committed
2852 subs = c.substate # only repos that are committed
2836 for s in sorted(subs):
2853 for s in sorted(subs):
2837 if not c.sub(s).push(opts.get('force')):
2854 if not c.sub(s).push(opts.get('force')):
2838 return False
2855 return False
2839 finally:
2856 finally:
2840 del repo._subtoppath
2857 del repo._subtoppath
2841 r = repo.push(other, opts.get('force'), revs=revs,
2858 r = repo.push(other, opts.get('force'), revs=revs,
2842 newbranch=opts.get('new_branch'))
2859 newbranch=opts.get('new_branch'))
2843 return r == 0
2860 return r == 0
2844
2861
2845 def recover(ui, repo):
2862 def recover(ui, repo):
2846 """roll back an interrupted transaction
2863 """roll back an interrupted transaction
2847
2864
2848 Recover from an interrupted commit or pull.
2865 Recover from an interrupted commit or pull.
2849
2866
2850 This command tries to fix the repository status after an
2867 This command tries to fix the repository status after an
2851 interrupted operation. It should only be necessary when Mercurial
2868 interrupted operation. It should only be necessary when Mercurial
2852 suggests it.
2869 suggests it.
2853
2870
2854 Returns 0 if successful, 1 if nothing to recover or verify fails.
2871 Returns 0 if successful, 1 if nothing to recover or verify fails.
2855 """
2872 """
2856 if repo.recover():
2873 if repo.recover():
2857 return hg.verify(repo)
2874 return hg.verify(repo)
2858 return 1
2875 return 1
2859
2876
2860 def remove(ui, repo, *pats, **opts):
2877 def remove(ui, repo, *pats, **opts):
2861 """remove the specified files on the next commit
2878 """remove the specified files on the next commit
2862
2879
2863 Schedule the indicated files for removal from the repository.
2880 Schedule the indicated files for removal from the repository.
2864
2881
2865 This only removes files from the current branch, not from the
2882 This only removes files from the current branch, not from the
2866 entire project history. -A/--after can be used to remove only
2883 entire project history. -A/--after can be used to remove only
2867 files that have already been deleted, -f/--force can be used to
2884 files that have already been deleted, -f/--force can be used to
2868 force deletion, and -Af can be used to remove files from the next
2885 force deletion, and -Af can be used to remove files from the next
2869 revision without deleting them from the working directory.
2886 revision without deleting them from the working directory.
2870
2887
2871 The following table details the behavior of remove for different
2888 The following table details the behavior of remove for different
2872 file states (columns) and option combinations (rows). The file
2889 file states (columns) and option combinations (rows). The file
2873 states are Added [A], Clean [C], Modified [M] and Missing [!] (as
2890 states are Added [A], Clean [C], Modified [M] and Missing [!] (as
2874 reported by :hg:`status`). The actions are Warn, Remove (from
2891 reported by :hg:`status`). The actions are Warn, Remove (from
2875 branch) and Delete (from disk)::
2892 branch) and Delete (from disk)::
2876
2893
2877 A C M !
2894 A C M !
2878 none W RD W R
2895 none W RD W R
2879 -f R RD RD R
2896 -f R RD RD R
2880 -A W W W R
2897 -A W W W R
2881 -Af R R R R
2898 -Af R R R R
2882
2899
2883 This command schedules the files to be removed at the next commit.
2900 This command schedules the files to be removed at the next commit.
2884 To undo a remove before that, see :hg:`revert`.
2901 To undo a remove before that, see :hg:`revert`.
2885
2902
2886 Returns 0 on success, 1 if any warnings encountered.
2903 Returns 0 on success, 1 if any warnings encountered.
2887 """
2904 """
2888
2905
2889 ret = 0
2906 ret = 0
2890 after, force = opts.get('after'), opts.get('force')
2907 after, force = opts.get('after'), opts.get('force')
2891 if not pats and not after:
2908 if not pats and not after:
2892 raise util.Abort(_('no files specified'))
2909 raise util.Abort(_('no files specified'))
2893
2910
2894 m = cmdutil.match(repo, pats, opts)
2911 m = cmdutil.match(repo, pats, opts)
2895 s = repo.status(match=m, clean=True)
2912 s = repo.status(match=m, clean=True)
2896 modified, added, deleted, clean = s[0], s[1], s[3], s[6]
2913 modified, added, deleted, clean = s[0], s[1], s[3], s[6]
2897
2914
2898 for f in m.files():
2915 for f in m.files():
2899 if f not in repo.dirstate and not os.path.isdir(m.rel(f)):
2916 if f not in repo.dirstate and not os.path.isdir(m.rel(f)):
2900 ui.warn(_('not removing %s: file is untracked\n') % m.rel(f))
2917 ui.warn(_('not removing %s: file is untracked\n') % m.rel(f))
2901 ret = 1
2918 ret = 1
2902
2919
2903 if force:
2920 if force:
2904 remove, forget = modified + deleted + clean, added
2921 remove, forget = modified + deleted + clean, added
2905 elif after:
2922 elif after:
2906 remove, forget = deleted, []
2923 remove, forget = deleted, []
2907 for f in modified + added + clean:
2924 for f in modified + added + clean:
2908 ui.warn(_('not removing %s: file still exists (use -f'
2925 ui.warn(_('not removing %s: file still exists (use -f'
2909 ' to force removal)\n') % m.rel(f))
2926 ' to force removal)\n') % m.rel(f))
2910 ret = 1
2927 ret = 1
2911 else:
2928 else:
2912 remove, forget = deleted + clean, []
2929 remove, forget = deleted + clean, []
2913 for f in modified:
2930 for f in modified:
2914 ui.warn(_('not removing %s: file is modified (use -f'
2931 ui.warn(_('not removing %s: file is modified (use -f'
2915 ' to force removal)\n') % m.rel(f))
2932 ' to force removal)\n') % m.rel(f))
2916 ret = 1
2933 ret = 1
2917 for f in added:
2934 for f in added:
2918 ui.warn(_('not removing %s: file has been marked for add (use -f'
2935 ui.warn(_('not removing %s: file has been marked for add (use -f'
2919 ' to force removal)\n') % m.rel(f))
2936 ' to force removal)\n') % m.rel(f))
2920 ret = 1
2937 ret = 1
2921
2938
2922 for f in sorted(remove + forget):
2939 for f in sorted(remove + forget):
2923 if ui.verbose or not m.exact(f):
2940 if ui.verbose or not m.exact(f):
2924 ui.status(_('removing %s\n') % m.rel(f))
2941 ui.status(_('removing %s\n') % m.rel(f))
2925
2942
2926 repo[None].forget(forget)
2943 repo[None].forget(forget)
2927 repo[None].remove(remove, unlink=not after)
2944 repo[None].remove(remove, unlink=not after)
2928 return ret
2945 return ret
2929
2946
2930 def rename(ui, repo, *pats, **opts):
2947 def rename(ui, repo, *pats, **opts):
2931 """rename files; equivalent of copy + remove
2948 """rename files; equivalent of copy + remove
2932
2949
2933 Mark dest as copies of sources; mark sources for deletion. If dest
2950 Mark dest as copies of sources; mark sources for deletion. If dest
2934 is a directory, copies are put in that directory. If dest is a
2951 is a directory, copies are put in that directory. If dest is a
2935 file, there can only be one source.
2952 file, there can only be one source.
2936
2953
2937 By default, this command copies the contents of files as they
2954 By default, this command copies the contents of files as they
2938 exist in the working directory. If invoked with -A/--after, the
2955 exist in the working directory. If invoked with -A/--after, the
2939 operation is recorded, but no copying is performed.
2956 operation is recorded, but no copying is performed.
2940
2957
2941 This command takes effect at the next commit. To undo a rename
2958 This command takes effect at the next commit. To undo a rename
2942 before that, see :hg:`revert`.
2959 before that, see :hg:`revert`.
2943
2960
2944 Returns 0 on success, 1 if errors are encountered.
2961 Returns 0 on success, 1 if errors are encountered.
2945 """
2962 """
2946 wlock = repo.wlock(False)
2963 wlock = repo.wlock(False)
2947 try:
2964 try:
2948 return cmdutil.copy(ui, repo, pats, opts, rename=True)
2965 return cmdutil.copy(ui, repo, pats, opts, rename=True)
2949 finally:
2966 finally:
2950 wlock.release()
2967 wlock.release()
2951
2968
2952 def resolve(ui, repo, *pats, **opts):
2969 def resolve(ui, repo, *pats, **opts):
2953 """redo merges or set/view the merge status of files
2970 """redo merges or set/view the merge status of files
2954
2971
2955 Merges with unresolved conflicts are often the result of
2972 Merges with unresolved conflicts are often the result of
2956 non-interactive merging using the ``internal:merge`` configuration
2973 non-interactive merging using the ``internal:merge`` configuration
2957 setting, or a command-line merge tool like ``diff3``. The resolve
2974 setting, or a command-line merge tool like ``diff3``. The resolve
2958 command is used to manage the files involved in a merge, after
2975 command is used to manage the files involved in a merge, after
2959 :hg:`merge` has been run, and before :hg:`commit` is run (i.e. the
2976 :hg:`merge` has been run, and before :hg:`commit` is run (i.e. the
2960 working directory must have two parents).
2977 working directory must have two parents).
2961
2978
2962 The resolve command can be used in the following ways:
2979 The resolve command can be used in the following ways:
2963
2980
2964 - :hg:`resolve [--tool TOOL] FILE...`: attempt to re-merge the specified
2981 - :hg:`resolve [--tool TOOL] FILE...`: attempt to re-merge the specified
2965 files, discarding any previous merge attempts. Re-merging is not
2982 files, discarding any previous merge attempts. Re-merging is not
2966 performed for files already marked as resolved. Use ``--all/-a``
2983 performed for files already marked as resolved. Use ``--all/-a``
2967 to selects all unresolved files. ``--tool`` can be used to specify
2984 to selects all unresolved files. ``--tool`` can be used to specify
2968 the merge tool used for the given files. It overrides the HGMERGE
2985 the merge tool used for the given files. It overrides the HGMERGE
2969 environment variable and your configuration files.
2986 environment variable and your configuration files.
2970
2987
2971 - :hg:`resolve -m [FILE]`: mark a file as having been resolved
2988 - :hg:`resolve -m [FILE]`: mark a file as having been resolved
2972 (e.g. after having manually fixed-up the files). The default is
2989 (e.g. after having manually fixed-up the files). The default is
2973 to mark all unresolved files.
2990 to mark all unresolved files.
2974
2991
2975 - :hg:`resolve -u [FILE]...`: mark a file as unresolved. The
2992 - :hg:`resolve -u [FILE]...`: mark a file as unresolved. The
2976 default is to mark all resolved files.
2993 default is to mark all resolved files.
2977
2994
2978 - :hg:`resolve -l`: list files which had or still have conflicts.
2995 - :hg:`resolve -l`: list files which had or still have conflicts.
2979 In the printed list, ``U`` = unresolved and ``R`` = resolved.
2996 In the printed list, ``U`` = unresolved and ``R`` = resolved.
2980
2997
2981 Note that Mercurial will not let you commit files with unresolved
2998 Note that Mercurial will not let you commit files with unresolved
2982 merge conflicts. You must use :hg:`resolve -m ...` before you can
2999 merge conflicts. You must use :hg:`resolve -m ...` before you can
2983 commit after a conflicting merge.
3000 commit after a conflicting merge.
2984
3001
2985 Returns 0 on success, 1 if any files fail a resolve attempt.
3002 Returns 0 on success, 1 if any files fail a resolve attempt.
2986 """
3003 """
2987
3004
2988 all, mark, unmark, show, nostatus = \
3005 all, mark, unmark, show, nostatus = \
2989 [opts.get(o) for o in 'all mark unmark list no_status'.split()]
3006 [opts.get(o) for o in 'all mark unmark list no_status'.split()]
2990
3007
2991 if (show and (mark or unmark)) or (mark and unmark):
3008 if (show and (mark or unmark)) or (mark and unmark):
2992 raise util.Abort(_("too many options specified"))
3009 raise util.Abort(_("too many options specified"))
2993 if pats and all:
3010 if pats and all:
2994 raise util.Abort(_("can't specify --all and patterns"))
3011 raise util.Abort(_("can't specify --all and patterns"))
2995 if not (all or pats or show or mark or unmark):
3012 if not (all or pats or show or mark or unmark):
2996 raise util.Abort(_('no files or directories specified; '
3013 raise util.Abort(_('no files or directories specified; '
2997 'use --all to remerge all files'))
3014 'use --all to remerge all files'))
2998
3015
2999 ms = mergemod.mergestate(repo)
3016 ms = mergemod.mergestate(repo)
3000 m = cmdutil.match(repo, pats, opts)
3017 m = cmdutil.match(repo, pats, opts)
3001 ret = 0
3018 ret = 0
3002
3019
3003 for f in ms:
3020 for f in ms:
3004 if m(f):
3021 if m(f):
3005 if show:
3022 if show:
3006 if nostatus:
3023 if nostatus:
3007 ui.write("%s\n" % f)
3024 ui.write("%s\n" % f)
3008 else:
3025 else:
3009 ui.write("%s %s\n" % (ms[f].upper(), f),
3026 ui.write("%s %s\n" % (ms[f].upper(), f),
3010 label='resolve.' +
3027 label='resolve.' +
3011 {'u': 'unresolved', 'r': 'resolved'}[ms[f]])
3028 {'u': 'unresolved', 'r': 'resolved'}[ms[f]])
3012 elif mark:
3029 elif mark:
3013 ms.mark(f, "r")
3030 ms.mark(f, "r")
3014 elif unmark:
3031 elif unmark:
3015 ms.mark(f, "u")
3032 ms.mark(f, "u")
3016 else:
3033 else:
3017 wctx = repo[None]
3034 wctx = repo[None]
3018 mctx = wctx.parents()[-1]
3035 mctx = wctx.parents()[-1]
3019
3036
3020 # backup pre-resolve (merge uses .orig for its own purposes)
3037 # backup pre-resolve (merge uses .orig for its own purposes)
3021 a = repo.wjoin(f)
3038 a = repo.wjoin(f)
3022 util.copyfile(a, a + ".resolve")
3039 util.copyfile(a, a + ".resolve")
3023
3040
3024 try:
3041 try:
3025 # resolve file
3042 # resolve file
3026 ui.setconfig('ui', 'forcemerge', opts.get('tool', ''))
3043 ui.setconfig('ui', 'forcemerge', opts.get('tool', ''))
3027 if ms.resolve(f, wctx, mctx):
3044 if ms.resolve(f, wctx, mctx):
3028 ret = 1
3045 ret = 1
3029 finally:
3046 finally:
3030 ui.setconfig('ui', 'forcemerge', '')
3047 ui.setconfig('ui', 'forcemerge', '')
3031
3048
3032 # replace filemerge's .orig file with our resolve file
3049 # replace filemerge's .orig file with our resolve file
3033 util.rename(a + ".resolve", a + ".orig")
3050 util.rename(a + ".resolve", a + ".orig")
3034
3051
3035 ms.commit()
3052 ms.commit()
3036 return ret
3053 return ret
3037
3054
3038 def revert(ui, repo, *pats, **opts):
3055 def revert(ui, repo, *pats, **opts):
3039 """restore individual files or directories to an earlier state
3056 """restore individual files or directories to an earlier state
3040
3057
3041 .. note::
3058 .. note::
3042 This command is most likely not what you are looking for.
3059 This command is most likely not what you are looking for.
3043 Revert will partially overwrite content in the working
3060 Revert will partially overwrite content in the working
3044 directory without changing the working directory parents. Use
3061 directory without changing the working directory parents. Use
3045 :hg:`update -r rev` to check out earlier revisions, or
3062 :hg:`update -r rev` to check out earlier revisions, or
3046 :hg:`update --clean .` to undo a merge which has added another
3063 :hg:`update --clean .` to undo a merge which has added another
3047 parent.
3064 parent.
3048
3065
3049 With no revision specified, revert the named files or directories
3066 With no revision specified, revert the named files or directories
3050 to the contents they had in the parent of the working directory.
3067 to the contents they had in the parent of the working directory.
3051 This restores the contents of the affected files to an unmodified
3068 This restores the contents of the affected files to an unmodified
3052 state and unschedules adds, removes, copies, and renames. If the
3069 state and unschedules adds, removes, copies, and renames. If the
3053 working directory has two parents, you must explicitly specify a
3070 working directory has two parents, you must explicitly specify a
3054 revision.
3071 revision.
3055
3072
3056 Using the -r/--rev option, revert the given files or directories
3073 Using the -r/--rev option, revert the given files or directories
3057 to their contents as of a specific revision. This can be helpful
3074 to their contents as of a specific revision. This can be helpful
3058 to "roll back" some or all of an earlier change. See :hg:`help
3075 to "roll back" some or all of an earlier change. See :hg:`help
3059 dates` for a list of formats valid for -d/--date.
3076 dates` for a list of formats valid for -d/--date.
3060
3077
3061 Revert modifies the working directory. It does not commit any
3078 Revert modifies the working directory. It does not commit any
3062 changes, or change the parent of the working directory. If you
3079 changes, or change the parent of the working directory. If you
3063 revert to a revision other than the parent of the working
3080 revert to a revision other than the parent of the working
3064 directory, the reverted files will thus appear modified
3081 directory, the reverted files will thus appear modified
3065 afterwards.
3082 afterwards.
3066
3083
3067 If a file has been deleted, it is restored. If the executable mode
3084 If a file has been deleted, it is restored. If the executable mode
3068 of a file was changed, it is reset.
3085 of a file was changed, it is reset.
3069
3086
3070 If names are given, all files matching the names are reverted.
3087 If names are given, all files matching the names are reverted.
3071 If no arguments are given, no files are reverted.
3088 If no arguments are given, no files are reverted.
3072
3089
3073 Modified files are saved with a .orig suffix before reverting.
3090 Modified files are saved with a .orig suffix before reverting.
3074 To disable these backups, use --no-backup.
3091 To disable these backups, use --no-backup.
3075
3092
3076 Returns 0 on success.
3093 Returns 0 on success.
3077 """
3094 """
3078
3095
3079 if opts.get("date"):
3096 if opts.get("date"):
3080 if opts.get("rev"):
3097 if opts.get("rev"):
3081 raise util.Abort(_("you can't specify a revision and a date"))
3098 raise util.Abort(_("you can't specify a revision and a date"))
3082 opts["rev"] = cmdutil.finddate(ui, repo, opts["date"])
3099 opts["rev"] = cmdutil.finddate(ui, repo, opts["date"])
3083
3100
3084 if not pats and not opts.get('all'):
3101 if not pats and not opts.get('all'):
3085 raise util.Abort(_('no files or directories specified; '
3102 raise util.Abort(_('no files or directories specified; '
3086 'use --all to revert the whole repo'))
3103 'use --all to revert the whole repo'))
3087
3104
3088 parent, p2 = repo.dirstate.parents()
3105 parent, p2 = repo.dirstate.parents()
3089 if not opts.get('rev') and p2 != nullid:
3106 if not opts.get('rev') and p2 != nullid:
3090 raise util.Abort(_('uncommitted merge - please provide a '
3107 raise util.Abort(_('uncommitted merge - please provide a '
3091 'specific revision'))
3108 'specific revision'))
3092 ctx = repo[opts.get('rev')]
3109 ctx = repo[opts.get('rev')]
3093 node = ctx.node()
3110 node = ctx.node()
3094 mf = ctx.manifest()
3111 mf = ctx.manifest()
3095 if node == parent:
3112 if node == parent:
3096 pmf = mf
3113 pmf = mf
3097 else:
3114 else:
3098 pmf = None
3115 pmf = None
3099
3116
3100 # need all matching names in dirstate and manifest of target rev,
3117 # need all matching names in dirstate and manifest of target rev,
3101 # so have to walk both. do not print errors if files exist in one
3118 # so have to walk both. do not print errors if files exist in one
3102 # but not other.
3119 # but not other.
3103
3120
3104 names = {}
3121 names = {}
3105
3122
3106 wlock = repo.wlock()
3123 wlock = repo.wlock()
3107 try:
3124 try:
3108 # walk dirstate.
3125 # walk dirstate.
3109
3126
3110 m = cmdutil.match(repo, pats, opts)
3127 m = cmdutil.match(repo, pats, opts)
3111 m.bad = lambda x, y: False
3128 m.bad = lambda x, y: False
3112 for abs in repo.walk(m):
3129 for abs in repo.walk(m):
3113 names[abs] = m.rel(abs), m.exact(abs)
3130 names[abs] = m.rel(abs), m.exact(abs)
3114
3131
3115 # walk target manifest.
3132 # walk target manifest.
3116
3133
3117 def badfn(path, msg):
3134 def badfn(path, msg):
3118 if path in names:
3135 if path in names:
3119 return
3136 return
3120 path_ = path + '/'
3137 path_ = path + '/'
3121 for f in names:
3138 for f in names:
3122 if f.startswith(path_):
3139 if f.startswith(path_):
3123 return
3140 return
3124 ui.warn("%s: %s\n" % (m.rel(path), msg))
3141 ui.warn("%s: %s\n" % (m.rel(path), msg))
3125
3142
3126 m = cmdutil.match(repo, pats, opts)
3143 m = cmdutil.match(repo, pats, opts)
3127 m.bad = badfn
3144 m.bad = badfn
3128 for abs in repo[node].walk(m):
3145 for abs in repo[node].walk(m):
3129 if abs not in names:
3146 if abs not in names:
3130 names[abs] = m.rel(abs), m.exact(abs)
3147 names[abs] = m.rel(abs), m.exact(abs)
3131
3148
3132 m = cmdutil.matchfiles(repo, names)
3149 m = cmdutil.matchfiles(repo, names)
3133 changes = repo.status(match=m)[:4]
3150 changes = repo.status(match=m)[:4]
3134 modified, added, removed, deleted = map(set, changes)
3151 modified, added, removed, deleted = map(set, changes)
3135
3152
3136 # if f is a rename, also revert the source
3153 # if f is a rename, also revert the source
3137 cwd = repo.getcwd()
3154 cwd = repo.getcwd()
3138 for f in added:
3155 for f in added:
3139 src = repo.dirstate.copied(f)
3156 src = repo.dirstate.copied(f)
3140 if src and src not in names and repo.dirstate[src] == 'r':
3157 if src and src not in names and repo.dirstate[src] == 'r':
3141 removed.add(src)
3158 removed.add(src)
3142 names[src] = (repo.pathto(src, cwd), True)
3159 names[src] = (repo.pathto(src, cwd), True)
3143
3160
3144 def removeforget(abs):
3161 def removeforget(abs):
3145 if repo.dirstate[abs] == 'a':
3162 if repo.dirstate[abs] == 'a':
3146 return _('forgetting %s\n')
3163 return _('forgetting %s\n')
3147 return _('removing %s\n')
3164 return _('removing %s\n')
3148
3165
3149 revert = ([], _('reverting %s\n'))
3166 revert = ([], _('reverting %s\n'))
3150 add = ([], _('adding %s\n'))
3167 add = ([], _('adding %s\n'))
3151 remove = ([], removeforget)
3168 remove = ([], removeforget)
3152 undelete = ([], _('undeleting %s\n'))
3169 undelete = ([], _('undeleting %s\n'))
3153
3170
3154 disptable = (
3171 disptable = (
3155 # dispatch table:
3172 # dispatch table:
3156 # file state
3173 # file state
3157 # action if in target manifest
3174 # action if in target manifest
3158 # action if not in target manifest
3175 # action if not in target manifest
3159 # make backup if in target manifest
3176 # make backup if in target manifest
3160 # make backup if not in target manifest
3177 # make backup if not in target manifest
3161 (modified, revert, remove, True, True),
3178 (modified, revert, remove, True, True),
3162 (added, revert, remove, True, False),
3179 (added, revert, remove, True, False),
3163 (removed, undelete, None, False, False),
3180 (removed, undelete, None, False, False),
3164 (deleted, revert, remove, False, False),
3181 (deleted, revert, remove, False, False),
3165 )
3182 )
3166
3183
3167 for abs, (rel, exact) in sorted(names.items()):
3184 for abs, (rel, exact) in sorted(names.items()):
3168 mfentry = mf.get(abs)
3185 mfentry = mf.get(abs)
3169 target = repo.wjoin(abs)
3186 target = repo.wjoin(abs)
3170 def handle(xlist, dobackup):
3187 def handle(xlist, dobackup):
3171 xlist[0].append(abs)
3188 xlist[0].append(abs)
3172 if (dobackup and not opts.get('no_backup') and
3189 if (dobackup and not opts.get('no_backup') and
3173 os.path.lexists(target)):
3190 os.path.lexists(target)):
3174 bakname = "%s.orig" % rel
3191 bakname = "%s.orig" % rel
3175 ui.note(_('saving current version of %s as %s\n') %
3192 ui.note(_('saving current version of %s as %s\n') %
3176 (rel, bakname))
3193 (rel, bakname))
3177 if not opts.get('dry_run'):
3194 if not opts.get('dry_run'):
3178 util.rename(target, bakname)
3195 util.rename(target, bakname)
3179 if ui.verbose or not exact:
3196 if ui.verbose or not exact:
3180 msg = xlist[1]
3197 msg = xlist[1]
3181 if not isinstance(msg, basestring):
3198 if not isinstance(msg, basestring):
3182 msg = msg(abs)
3199 msg = msg(abs)
3183 ui.status(msg % rel)
3200 ui.status(msg % rel)
3184 for table, hitlist, misslist, backuphit, backupmiss in disptable:
3201 for table, hitlist, misslist, backuphit, backupmiss in disptable:
3185 if abs not in table:
3202 if abs not in table:
3186 continue
3203 continue
3187 # file has changed in dirstate
3204 # file has changed in dirstate
3188 if mfentry:
3205 if mfentry:
3189 handle(hitlist, backuphit)
3206 handle(hitlist, backuphit)
3190 elif misslist is not None:
3207 elif misslist is not None:
3191 handle(misslist, backupmiss)
3208 handle(misslist, backupmiss)
3192 break
3209 break
3193 else:
3210 else:
3194 if abs not in repo.dirstate:
3211 if abs not in repo.dirstate:
3195 if mfentry:
3212 if mfentry:
3196 handle(add, True)
3213 handle(add, True)
3197 elif exact:
3214 elif exact:
3198 ui.warn(_('file not managed: %s\n') % rel)
3215 ui.warn(_('file not managed: %s\n') % rel)
3199 continue
3216 continue
3200 # file has not changed in dirstate
3217 # file has not changed in dirstate
3201 if node == parent:
3218 if node == parent:
3202 if exact:
3219 if exact:
3203 ui.warn(_('no changes needed to %s\n') % rel)
3220 ui.warn(_('no changes needed to %s\n') % rel)
3204 continue
3221 continue
3205 if pmf is None:
3222 if pmf is None:
3206 # only need parent manifest in this unlikely case,
3223 # only need parent manifest in this unlikely case,
3207 # so do not read by default
3224 # so do not read by default
3208 pmf = repo[parent].manifest()
3225 pmf = repo[parent].manifest()
3209 if abs in pmf:
3226 if abs in pmf:
3210 if mfentry:
3227 if mfentry:
3211 # if version of file is same in parent and target
3228 # if version of file is same in parent and target
3212 # manifests, do nothing
3229 # manifests, do nothing
3213 if (pmf[abs] != mfentry or
3230 if (pmf[abs] != mfentry or
3214 pmf.flags(abs) != mf.flags(abs)):
3231 pmf.flags(abs) != mf.flags(abs)):
3215 handle(revert, False)
3232 handle(revert, False)
3216 else:
3233 else:
3217 handle(remove, False)
3234 handle(remove, False)
3218
3235
3219 if not opts.get('dry_run'):
3236 if not opts.get('dry_run'):
3220 def checkout(f):
3237 def checkout(f):
3221 fc = ctx[f]
3238 fc = ctx[f]
3222 repo.wwrite(f, fc.data(), fc.flags())
3239 repo.wwrite(f, fc.data(), fc.flags())
3223
3240
3224 audit_path = util.path_auditor(repo.root)
3241 audit_path = util.path_auditor(repo.root)
3225 for f in remove[0]:
3242 for f in remove[0]:
3226 if repo.dirstate[f] == 'a':
3243 if repo.dirstate[f] == 'a':
3227 repo.dirstate.forget(f)
3244 repo.dirstate.forget(f)
3228 continue
3245 continue
3229 audit_path(f)
3246 audit_path(f)
3230 try:
3247 try:
3231 util.unlink(repo.wjoin(f))
3248 util.unlink(repo.wjoin(f))
3232 except OSError:
3249 except OSError:
3233 pass
3250 pass
3234 repo.dirstate.remove(f)
3251 repo.dirstate.remove(f)
3235
3252
3236 normal = None
3253 normal = None
3237 if node == parent:
3254 if node == parent:
3238 # We're reverting to our parent. If possible, we'd like status
3255 # We're reverting to our parent. If possible, we'd like status
3239 # to report the file as clean. We have to use normallookup for
3256 # to report the file as clean. We have to use normallookup for
3240 # merges to avoid losing information about merged/dirty files.
3257 # merges to avoid losing information about merged/dirty files.
3241 if p2 != nullid:
3258 if p2 != nullid:
3242 normal = repo.dirstate.normallookup
3259 normal = repo.dirstate.normallookup
3243 else:
3260 else:
3244 normal = repo.dirstate.normal
3261 normal = repo.dirstate.normal
3245 for f in revert[0]:
3262 for f in revert[0]:
3246 checkout(f)
3263 checkout(f)
3247 if normal:
3264 if normal:
3248 normal(f)
3265 normal(f)
3249
3266
3250 for f in add[0]:
3267 for f in add[0]:
3251 checkout(f)
3268 checkout(f)
3252 repo.dirstate.add(f)
3269 repo.dirstate.add(f)
3253
3270
3254 normal = repo.dirstate.normallookup
3271 normal = repo.dirstate.normallookup
3255 if node == parent and p2 == nullid:
3272 if node == parent and p2 == nullid:
3256 normal = repo.dirstate.normal
3273 normal = repo.dirstate.normal
3257 for f in undelete[0]:
3274 for f in undelete[0]:
3258 checkout(f)
3275 checkout(f)
3259 normal(f)
3276 normal(f)
3260
3277
3261 finally:
3278 finally:
3262 wlock.release()
3279 wlock.release()
3263
3280
3264 def rollback(ui, repo, **opts):
3281 def rollback(ui, repo, **opts):
3265 """roll back the last transaction (dangerous)
3282 """roll back the last transaction (dangerous)
3266
3283
3267 This command should be used with care. There is only one level of
3284 This command should be used with care. There is only one level of
3268 rollback, and there is no way to undo a rollback. It will also
3285 rollback, and there is no way to undo a rollback. It will also
3269 restore the dirstate at the time of the last transaction, losing
3286 restore the dirstate at the time of the last transaction, losing
3270 any dirstate changes since that time. This command does not alter
3287 any dirstate changes since that time. This command does not alter
3271 the working directory.
3288 the working directory.
3272
3289
3273 Transactions are used to encapsulate the effects of all commands
3290 Transactions are used to encapsulate the effects of all commands
3274 that create new changesets or propagate existing changesets into a
3291 that create new changesets or propagate existing changesets into a
3275 repository. For example, the following commands are transactional,
3292 repository. For example, the following commands are transactional,
3276 and their effects can be rolled back:
3293 and their effects can be rolled back:
3277
3294
3278 - commit
3295 - commit
3279 - import
3296 - import
3280 - pull
3297 - pull
3281 - push (with this repository as the destination)
3298 - push (with this repository as the destination)
3282 - unbundle
3299 - unbundle
3283
3300
3284 This command is not intended for use on public repositories. Once
3301 This command is not intended for use on public repositories. Once
3285 changes are visible for pull by other users, rolling a transaction
3302 changes are visible for pull by other users, rolling a transaction
3286 back locally is ineffective (someone else may already have pulled
3303 back locally is ineffective (someone else may already have pulled
3287 the changes). Furthermore, a race is possible with readers of the
3304 the changes). Furthermore, a race is possible with readers of the
3288 repository; for example an in-progress pull from the repository
3305 repository; for example an in-progress pull from the repository
3289 may fail if a rollback is performed.
3306 may fail if a rollback is performed.
3290
3307
3291 Returns 0 on success, 1 if no rollback data is available.
3308 Returns 0 on success, 1 if no rollback data is available.
3292 """
3309 """
3293 return repo.rollback(opts.get('dry_run'))
3310 return repo.rollback(opts.get('dry_run'))
3294
3311
3295 def root(ui, repo):
3312 def root(ui, repo):
3296 """print the root (top) of the current working directory
3313 """print the root (top) of the current working directory
3297
3314
3298 Print the root directory of the current repository.
3315 Print the root directory of the current repository.
3299
3316
3300 Returns 0 on success.
3317 Returns 0 on success.
3301 """
3318 """
3302 ui.write(repo.root + "\n")
3319 ui.write(repo.root + "\n")
3303
3320
3304 def serve(ui, repo, **opts):
3321 def serve(ui, repo, **opts):
3305 """start stand-alone webserver
3322 """start stand-alone webserver
3306
3323
3307 Start a local HTTP repository browser and pull server. You can use
3324 Start a local HTTP repository browser and pull server. You can use
3308 this for ad-hoc sharing and browing of repositories. It is
3325 this for ad-hoc sharing and browing of repositories. It is
3309 recommended to use a real web server to serve a repository for
3326 recommended to use a real web server to serve a repository for
3310 longer periods of time.
3327 longer periods of time.
3311
3328
3312 Please note that the server does not implement access control.
3329 Please note that the server does not implement access control.
3313 This means that, by default, anybody can read from the server and
3330 This means that, by default, anybody can read from the server and
3314 nobody can write to it by default. Set the ``web.allow_push``
3331 nobody can write to it by default. Set the ``web.allow_push``
3315 option to ``*`` to allow everybody to push to the server. You
3332 option to ``*`` to allow everybody to push to the server. You
3316 should use a real web server if you need to authenticate users.
3333 should use a real web server if you need to authenticate users.
3317
3334
3318 By default, the server logs accesses to stdout and errors to
3335 By default, the server logs accesses to stdout and errors to
3319 stderr. Use the -A/--accesslog and -E/--errorlog options to log to
3336 stderr. Use the -A/--accesslog and -E/--errorlog options to log to
3320 files.
3337 files.
3321
3338
3322 To have the server choose a free port number to listen on, specify
3339 To have the server choose a free port number to listen on, specify
3323 a port number of 0; in this case, the server will print the port
3340 a port number of 0; in this case, the server will print the port
3324 number it uses.
3341 number it uses.
3325
3342
3326 Returns 0 on success.
3343 Returns 0 on success.
3327 """
3344 """
3328
3345
3329 if opts["stdio"]:
3346 if opts["stdio"]:
3330 if repo is None:
3347 if repo is None:
3331 raise error.RepoError(_("There is no Mercurial repository here"
3348 raise error.RepoError(_("There is no Mercurial repository here"
3332 " (.hg not found)"))
3349 " (.hg not found)"))
3333 s = sshserver.sshserver(ui, repo)
3350 s = sshserver.sshserver(ui, repo)
3334 s.serve_forever()
3351 s.serve_forever()
3335
3352
3336 # this way we can check if something was given in the command-line
3353 # this way we can check if something was given in the command-line
3337 if opts.get('port'):
3354 if opts.get('port'):
3338 opts['port'] = util.getport(opts.get('port'))
3355 opts['port'] = util.getport(opts.get('port'))
3339
3356
3340 baseui = repo and repo.baseui or ui
3357 baseui = repo and repo.baseui or ui
3341 optlist = ("name templates style address port prefix ipv6"
3358 optlist = ("name templates style address port prefix ipv6"
3342 " accesslog errorlog certificate encoding")
3359 " accesslog errorlog certificate encoding")
3343 for o in optlist.split():
3360 for o in optlist.split():
3344 val = opts.get(o, '')
3361 val = opts.get(o, '')
3345 if val in (None, ''): # should check against default options instead
3362 if val in (None, ''): # should check against default options instead
3346 continue
3363 continue
3347 baseui.setconfig("web", o, val)
3364 baseui.setconfig("web", o, val)
3348 if repo and repo.ui != baseui:
3365 if repo and repo.ui != baseui:
3349 repo.ui.setconfig("web", o, val)
3366 repo.ui.setconfig("web", o, val)
3350
3367
3351 o = opts.get('web_conf') or opts.get('webdir_conf')
3368 o = opts.get('web_conf') or opts.get('webdir_conf')
3352 if not o:
3369 if not o:
3353 if not repo:
3370 if not repo:
3354 raise error.RepoError(_("There is no Mercurial repository"
3371 raise error.RepoError(_("There is no Mercurial repository"
3355 " here (.hg not found)"))
3372 " here (.hg not found)"))
3356 o = repo.root
3373 o = repo.root
3357
3374
3358 app = hgweb.hgweb(o, baseui=ui)
3375 app = hgweb.hgweb(o, baseui=ui)
3359
3376
3360 class service(object):
3377 class service(object):
3361 def init(self):
3378 def init(self):
3362 util.set_signal_handler()
3379 util.set_signal_handler()
3363 self.httpd = hgweb.server.create_server(ui, app)
3380 self.httpd = hgweb.server.create_server(ui, app)
3364
3381
3365 if opts['port'] and not ui.verbose:
3382 if opts['port'] and not ui.verbose:
3366 return
3383 return
3367
3384
3368 if self.httpd.prefix:
3385 if self.httpd.prefix:
3369 prefix = self.httpd.prefix.strip('/') + '/'
3386 prefix = self.httpd.prefix.strip('/') + '/'
3370 else:
3387 else:
3371 prefix = ''
3388 prefix = ''
3372
3389
3373 port = ':%d' % self.httpd.port
3390 port = ':%d' % self.httpd.port
3374 if port == ':80':
3391 if port == ':80':
3375 port = ''
3392 port = ''
3376
3393
3377 bindaddr = self.httpd.addr
3394 bindaddr = self.httpd.addr
3378 if bindaddr == '0.0.0.0':
3395 if bindaddr == '0.0.0.0':
3379 bindaddr = '*'
3396 bindaddr = '*'
3380 elif ':' in bindaddr: # IPv6
3397 elif ':' in bindaddr: # IPv6
3381 bindaddr = '[%s]' % bindaddr
3398 bindaddr = '[%s]' % bindaddr
3382
3399
3383 fqaddr = self.httpd.fqaddr
3400 fqaddr = self.httpd.fqaddr
3384 if ':' in fqaddr:
3401 if ':' in fqaddr:
3385 fqaddr = '[%s]' % fqaddr
3402 fqaddr = '[%s]' % fqaddr
3386 if opts['port']:
3403 if opts['port']:
3387 write = ui.status
3404 write = ui.status
3388 else:
3405 else:
3389 write = ui.write
3406 write = ui.write
3390 write(_('listening at http://%s%s/%s (bound to %s:%d)\n') %
3407 write(_('listening at http://%s%s/%s (bound to %s:%d)\n') %
3391 (fqaddr, port, prefix, bindaddr, self.httpd.port))
3408 (fqaddr, port, prefix, bindaddr, self.httpd.port))
3392
3409
3393 def run(self):
3410 def run(self):
3394 self.httpd.serve_forever()
3411 self.httpd.serve_forever()
3395
3412
3396 service = service()
3413 service = service()
3397
3414
3398 cmdutil.service(opts, initfn=service.init, runfn=service.run)
3415 cmdutil.service(opts, initfn=service.init, runfn=service.run)
3399
3416
3400 def status(ui, repo, *pats, **opts):
3417 def status(ui, repo, *pats, **opts):
3401 """show changed files in the working directory
3418 """show changed files in the working directory
3402
3419
3403 Show status of files in the repository. If names are given, only
3420 Show status of files in the repository. If names are given, only
3404 files that match are shown. Files that are clean or ignored or
3421 files that match are shown. Files that are clean or ignored or
3405 the source of a copy/move operation, are not listed unless
3422 the source of a copy/move operation, are not listed unless
3406 -c/--clean, -i/--ignored, -C/--copies or -A/--all are given.
3423 -c/--clean, -i/--ignored, -C/--copies or -A/--all are given.
3407 Unless options described with "show only ..." are given, the
3424 Unless options described with "show only ..." are given, the
3408 options -mardu are used.
3425 options -mardu are used.
3409
3426
3410 Option -q/--quiet hides untracked (unknown and ignored) files
3427 Option -q/--quiet hides untracked (unknown and ignored) files
3411 unless explicitly requested with -u/--unknown or -i/--ignored.
3428 unless explicitly requested with -u/--unknown or -i/--ignored.
3412
3429
3413 .. note::
3430 .. note::
3414 status may appear to disagree with diff if permissions have
3431 status may appear to disagree with diff if permissions have
3415 changed or a merge has occurred. The standard diff format does
3432 changed or a merge has occurred. The standard diff format does
3416 not report permission changes and diff only reports changes
3433 not report permission changes and diff only reports changes
3417 relative to one merge parent.
3434 relative to one merge parent.
3418
3435
3419 If one revision is given, it is used as the base revision.
3436 If one revision is given, it is used as the base revision.
3420 If two revisions are given, the differences between them are
3437 If two revisions are given, the differences between them are
3421 shown. The --change option can also be used as a shortcut to list
3438 shown. The --change option can also be used as a shortcut to list
3422 the changed files of a revision from its first parent.
3439 the changed files of a revision from its first parent.
3423
3440
3424 The codes used to show the status of files are::
3441 The codes used to show the status of files are::
3425
3442
3426 M = modified
3443 M = modified
3427 A = added
3444 A = added
3428 R = removed
3445 R = removed
3429 C = clean
3446 C = clean
3430 ! = missing (deleted by non-hg command, but still tracked)
3447 ! = missing (deleted by non-hg command, but still tracked)
3431 ? = not tracked
3448 ? = not tracked
3432 I = ignored
3449 I = ignored
3433 = origin of the previous file listed as A (added)
3450 = origin of the previous file listed as A (added)
3434
3451
3435 Returns 0 on success.
3452 Returns 0 on success.
3436 """
3453 """
3437
3454
3438 revs = opts.get('rev')
3455 revs = opts.get('rev')
3439 change = opts.get('change')
3456 change = opts.get('change')
3440
3457
3441 if revs and change:
3458 if revs and change:
3442 msg = _('cannot specify --rev and --change at the same time')
3459 msg = _('cannot specify --rev and --change at the same time')
3443 raise util.Abort(msg)
3460 raise util.Abort(msg)
3444 elif change:
3461 elif change:
3445 node2 = repo.lookup(change)
3462 node2 = repo.lookup(change)
3446 node1 = repo[node2].parents()[0].node()
3463 node1 = repo[node2].parents()[0].node()
3447 else:
3464 else:
3448 node1, node2 = cmdutil.revpair(repo, revs)
3465 node1, node2 = cmdutil.revpair(repo, revs)
3449
3466
3450 cwd = (pats and repo.getcwd()) or ''
3467 cwd = (pats and repo.getcwd()) or ''
3451 end = opts.get('print0') and '\0' or '\n'
3468 end = opts.get('print0') and '\0' or '\n'
3452 copy = {}
3469 copy = {}
3453 states = 'modified added removed deleted unknown ignored clean'.split()
3470 states = 'modified added removed deleted unknown ignored clean'.split()
3454 show = [k for k in states if opts.get(k)]
3471 show = [k for k in states if opts.get(k)]
3455 if opts.get('all'):
3472 if opts.get('all'):
3456 show += ui.quiet and (states[:4] + ['clean']) or states
3473 show += ui.quiet and (states[:4] + ['clean']) or states
3457 if not show:
3474 if not show:
3458 show = ui.quiet and states[:4] or states[:5]
3475 show = ui.quiet and states[:4] or states[:5]
3459
3476
3460 stat = repo.status(node1, node2, cmdutil.match(repo, pats, opts),
3477 stat = repo.status(node1, node2, cmdutil.match(repo, pats, opts),
3461 'ignored' in show, 'clean' in show, 'unknown' in show,
3478 'ignored' in show, 'clean' in show, 'unknown' in show,
3462 opts.get('subrepos'))
3479 opts.get('subrepos'))
3463 changestates = zip(states, 'MAR!?IC', stat)
3480 changestates = zip(states, 'MAR!?IC', stat)
3464
3481
3465 if (opts.get('all') or opts.get('copies')) and not opts.get('no_status'):
3482 if (opts.get('all') or opts.get('copies')) and not opts.get('no_status'):
3466 ctxn = repo[nullid]
3483 ctxn = repo[nullid]
3467 ctx1 = repo[node1]
3484 ctx1 = repo[node1]
3468 ctx2 = repo[node2]
3485 ctx2 = repo[node2]
3469 added = stat[1]
3486 added = stat[1]
3470 if node2 is None:
3487 if node2 is None:
3471 added = stat[0] + stat[1] # merged?
3488 added = stat[0] + stat[1] # merged?
3472
3489
3473 for k, v in copies.copies(repo, ctx1, ctx2, ctxn)[0].iteritems():
3490 for k, v in copies.copies(repo, ctx1, ctx2, ctxn)[0].iteritems():
3474 if k in added:
3491 if k in added:
3475 copy[k] = v
3492 copy[k] = v
3476 elif v in added:
3493 elif v in added:
3477 copy[v] = k
3494 copy[v] = k
3478
3495
3479 for state, char, files in changestates:
3496 for state, char, files in changestates:
3480 if state in show:
3497 if state in show:
3481 format = "%s %%s%s" % (char, end)
3498 format = "%s %%s%s" % (char, end)
3482 if opts.get('no_status'):
3499 if opts.get('no_status'):
3483 format = "%%s%s" % end
3500 format = "%%s%s" % end
3484
3501
3485 for f in files:
3502 for f in files:
3486 ui.write(format % repo.pathto(f, cwd),
3503 ui.write(format % repo.pathto(f, cwd),
3487 label='status.' + state)
3504 label='status.' + state)
3488 if f in copy:
3505 if f in copy:
3489 ui.write(' %s%s' % (repo.pathto(copy[f], cwd), end),
3506 ui.write(' %s%s' % (repo.pathto(copy[f], cwd), end),
3490 label='status.copied')
3507 label='status.copied')
3491
3508
3492 def summary(ui, repo, **opts):
3509 def summary(ui, repo, **opts):
3493 """summarize working directory state
3510 """summarize working directory state
3494
3511
3495 This generates a brief summary of the working directory state,
3512 This generates a brief summary of the working directory state,
3496 including parents, branch, commit status, and available updates.
3513 including parents, branch, commit status, and available updates.
3497
3514
3498 With the --remote option, this will check the default paths for
3515 With the --remote option, this will check the default paths for
3499 incoming and outgoing changes. This can be time-consuming.
3516 incoming and outgoing changes. This can be time-consuming.
3500
3517
3501 Returns 0 on success.
3518 Returns 0 on success.
3502 """
3519 """
3503
3520
3504 ctx = repo[None]
3521 ctx = repo[None]
3505 parents = ctx.parents()
3522 parents = ctx.parents()
3506 pnode = parents[0].node()
3523 pnode = parents[0].node()
3507
3524
3508 for p in parents:
3525 for p in parents:
3509 # label with log.changeset (instead of log.parent) since this
3526 # label with log.changeset (instead of log.parent) since this
3510 # shows a working directory parent *changeset*:
3527 # shows a working directory parent *changeset*:
3511 ui.write(_('parent: %d:%s ') % (p.rev(), str(p)),
3528 ui.write(_('parent: %d:%s ') % (p.rev(), str(p)),
3512 label='log.changeset')
3529 label='log.changeset')
3513 ui.write(' '.join(p.tags()), label='log.tag')
3530 ui.write(' '.join(p.tags()), label='log.tag')
3514 if p.rev() == -1:
3531 if p.rev() == -1:
3515 if not len(repo):
3532 if not len(repo):
3516 ui.write(_(' (empty repository)'))
3533 ui.write(_(' (empty repository)'))
3517 else:
3534 else:
3518 ui.write(_(' (no revision checked out)'))
3535 ui.write(_(' (no revision checked out)'))
3519 ui.write('\n')
3536 ui.write('\n')
3520 if p.description():
3537 if p.description():
3521 ui.status(' ' + p.description().splitlines()[0].strip() + '\n',
3538 ui.status(' ' + p.description().splitlines()[0].strip() + '\n',
3522 label='log.summary')
3539 label='log.summary')
3523
3540
3524 branch = ctx.branch()
3541 branch = ctx.branch()
3525 bheads = repo.branchheads(branch)
3542 bheads = repo.branchheads(branch)
3526 m = _('branch: %s\n') % branch
3543 m = _('branch: %s\n') % branch
3527 if branch != 'default':
3544 if branch != 'default':
3528 ui.write(m, label='log.branch')
3545 ui.write(m, label='log.branch')
3529 else:
3546 else:
3530 ui.status(m, label='log.branch')
3547 ui.status(m, label='log.branch')
3531
3548
3532 st = list(repo.status(unknown=True))[:6]
3549 st = list(repo.status(unknown=True))[:6]
3533
3550
3534 c = repo.dirstate.copies()
3551 c = repo.dirstate.copies()
3535 copied, renamed = [], []
3552 copied, renamed = [], []
3536 for d, s in c.iteritems():
3553 for d, s in c.iteritems():
3537 if s in st[2]:
3554 if s in st[2]:
3538 st[2].remove(s)
3555 st[2].remove(s)
3539 renamed.append(d)
3556 renamed.append(d)
3540 else:
3557 else:
3541 copied.append(d)
3558 copied.append(d)
3542 if d in st[1]:
3559 if d in st[1]:
3543 st[1].remove(d)
3560 st[1].remove(d)
3544 st.insert(3, renamed)
3561 st.insert(3, renamed)
3545 st.insert(4, copied)
3562 st.insert(4, copied)
3546
3563
3547 ms = mergemod.mergestate(repo)
3564 ms = mergemod.mergestate(repo)
3548 st.append([f for f in ms if ms[f] == 'u'])
3565 st.append([f for f in ms if ms[f] == 'u'])
3549
3566
3550 subs = [s for s in ctx.substate if ctx.sub(s).dirty()]
3567 subs = [s for s in ctx.substate if ctx.sub(s).dirty()]
3551 st.append(subs)
3568 st.append(subs)
3552
3569
3553 labels = [ui.label(_('%d modified'), 'status.modified'),
3570 labels = [ui.label(_('%d modified'), 'status.modified'),
3554 ui.label(_('%d added'), 'status.added'),
3571 ui.label(_('%d added'), 'status.added'),
3555 ui.label(_('%d removed'), 'status.removed'),
3572 ui.label(_('%d removed'), 'status.removed'),
3556 ui.label(_('%d renamed'), 'status.copied'),
3573 ui.label(_('%d renamed'), 'status.copied'),
3557 ui.label(_('%d copied'), 'status.copied'),
3574 ui.label(_('%d copied'), 'status.copied'),
3558 ui.label(_('%d deleted'), 'status.deleted'),
3575 ui.label(_('%d deleted'), 'status.deleted'),
3559 ui.label(_('%d unknown'), 'status.unknown'),
3576 ui.label(_('%d unknown'), 'status.unknown'),
3560 ui.label(_('%d ignored'), 'status.ignored'),
3577 ui.label(_('%d ignored'), 'status.ignored'),
3561 ui.label(_('%d unresolved'), 'resolve.unresolved'),
3578 ui.label(_('%d unresolved'), 'resolve.unresolved'),
3562 ui.label(_('%d subrepos'), 'status.modified')]
3579 ui.label(_('%d subrepos'), 'status.modified')]
3563 t = []
3580 t = []
3564 for s, l in zip(st, labels):
3581 for s, l in zip(st, labels):
3565 if s:
3582 if s:
3566 t.append(l % len(s))
3583 t.append(l % len(s))
3567
3584
3568 t = ', '.join(t)
3585 t = ', '.join(t)
3569 cleanworkdir = False
3586 cleanworkdir = False
3570
3587
3571 if len(parents) > 1:
3588 if len(parents) > 1:
3572 t += _(' (merge)')
3589 t += _(' (merge)')
3573 elif branch != parents[0].branch():
3590 elif branch != parents[0].branch():
3574 t += _(' (new branch)')
3591 t += _(' (new branch)')
3575 elif (parents[0].extra().get('close') and
3592 elif (parents[0].extra().get('close') and
3576 pnode in repo.branchheads(branch, closed=True)):
3593 pnode in repo.branchheads(branch, closed=True)):
3577 t += _(' (head closed)')
3594 t += _(' (head closed)')
3578 elif not (st[0] or st[1] or st[2] or st[3] or st[4] or st[9]):
3595 elif not (st[0] or st[1] or st[2] or st[3] or st[4] or st[9]):
3579 t += _(' (clean)')
3596 t += _(' (clean)')
3580 cleanworkdir = True
3597 cleanworkdir = True
3581 elif pnode not in bheads:
3598 elif pnode not in bheads:
3582 t += _(' (new branch head)')
3599 t += _(' (new branch head)')
3583
3600
3584 if cleanworkdir:
3601 if cleanworkdir:
3585 ui.status(_('commit: %s\n') % t.strip())
3602 ui.status(_('commit: %s\n') % t.strip())
3586 else:
3603 else:
3587 ui.write(_('commit: %s\n') % t.strip())
3604 ui.write(_('commit: %s\n') % t.strip())
3588
3605
3589 # all ancestors of branch heads - all ancestors of parent = new csets
3606 # all ancestors of branch heads - all ancestors of parent = new csets
3590 new = [0] * len(repo)
3607 new = [0] * len(repo)
3591 cl = repo.changelog
3608 cl = repo.changelog
3592 for a in [cl.rev(n) for n in bheads]:
3609 for a in [cl.rev(n) for n in bheads]:
3593 new[a] = 1
3610 new[a] = 1
3594 for a in cl.ancestors(*[cl.rev(n) for n in bheads]):
3611 for a in cl.ancestors(*[cl.rev(n) for n in bheads]):
3595 new[a] = 1
3612 new[a] = 1
3596 for a in [p.rev() for p in parents]:
3613 for a in [p.rev() for p in parents]:
3597 if a >= 0:
3614 if a >= 0:
3598 new[a] = 0
3615 new[a] = 0
3599 for a in cl.ancestors(*[p.rev() for p in parents]):
3616 for a in cl.ancestors(*[p.rev() for p in parents]):
3600 new[a] = 0
3617 new[a] = 0
3601 new = sum(new)
3618 new = sum(new)
3602
3619
3603 if new == 0:
3620 if new == 0:
3604 ui.status(_('update: (current)\n'))
3621 ui.status(_('update: (current)\n'))
3605 elif pnode not in bheads:
3622 elif pnode not in bheads:
3606 ui.write(_('update: %d new changesets (update)\n') % new)
3623 ui.write(_('update: %d new changesets (update)\n') % new)
3607 else:
3624 else:
3608 ui.write(_('update: %d new changesets, %d branch heads (merge)\n') %
3625 ui.write(_('update: %d new changesets, %d branch heads (merge)\n') %
3609 (new, len(bheads)))
3626 (new, len(bheads)))
3610
3627
3611 if opts.get('remote'):
3628 if opts.get('remote'):
3612 t = []
3629 t = []
3613 source, branches = hg.parseurl(ui.expandpath('default'))
3630 source, branches = hg.parseurl(ui.expandpath('default'))
3614 other = hg.repository(hg.remoteui(repo, {}), source)
3631 other = hg.repository(hg.remoteui(repo, {}), source)
3615 revs, checkout = hg.addbranchrevs(repo, other, branches, opts.get('rev'))
3632 revs, checkout = hg.addbranchrevs(repo, other, branches, opts.get('rev'))
3616 ui.debug('comparing with %s\n' % url.hidepassword(source))
3633 ui.debug('comparing with %s\n' % url.hidepassword(source))
3617 repo.ui.pushbuffer()
3634 repo.ui.pushbuffer()
3618 common, incoming, rheads = discovery.findcommonincoming(repo, other)
3635 common, incoming, rheads = discovery.findcommonincoming(repo, other)
3619 repo.ui.popbuffer()
3636 repo.ui.popbuffer()
3620 if incoming:
3637 if incoming:
3621 t.append(_('1 or more incoming'))
3638 t.append(_('1 or more incoming'))
3622
3639
3623 dest, branches = hg.parseurl(ui.expandpath('default-push', 'default'))
3640 dest, branches = hg.parseurl(ui.expandpath('default-push', 'default'))
3624 revs, checkout = hg.addbranchrevs(repo, repo, branches, None)
3641 revs, checkout = hg.addbranchrevs(repo, repo, branches, None)
3625 other = hg.repository(hg.remoteui(repo, {}), dest)
3642 other = hg.repository(hg.remoteui(repo, {}), dest)
3626 ui.debug('comparing with %s\n' % url.hidepassword(dest))
3643 ui.debug('comparing with %s\n' % url.hidepassword(dest))
3627 repo.ui.pushbuffer()
3644 repo.ui.pushbuffer()
3628 o = discovery.findoutgoing(repo, other)
3645 o = discovery.findoutgoing(repo, other)
3629 repo.ui.popbuffer()
3646 repo.ui.popbuffer()
3630 o = repo.changelog.nodesbetween(o, None)[0]
3647 o = repo.changelog.nodesbetween(o, None)[0]
3631 if o:
3648 if o:
3632 t.append(_('%d outgoing') % len(o))
3649 t.append(_('%d outgoing') % len(o))
3633
3650
3634 if t:
3651 if t:
3635 ui.write(_('remote: %s\n') % (', '.join(t)))
3652 ui.write(_('remote: %s\n') % (', '.join(t)))
3636 else:
3653 else:
3637 ui.status(_('remote: (synced)\n'))
3654 ui.status(_('remote: (synced)\n'))
3638
3655
3639 def tag(ui, repo, name1, *names, **opts):
3656 def tag(ui, repo, name1, *names, **opts):
3640 """add one or more tags for the current or given revision
3657 """add one or more tags for the current or given revision
3641
3658
3642 Name a particular revision using <name>.
3659 Name a particular revision using <name>.
3643
3660
3644 Tags are used to name particular revisions of the repository and are
3661 Tags are used to name particular revisions of the repository and are
3645 very useful to compare different revisions, to go back to significant
3662 very useful to compare different revisions, to go back to significant
3646 earlier versions or to mark branch points as releases, etc.
3663 earlier versions or to mark branch points as releases, etc.
3647
3664
3648 If no revision is given, the parent of the working directory is
3665 If no revision is given, the parent of the working directory is
3649 used, or tip if no revision is checked out.
3666 used, or tip if no revision is checked out.
3650
3667
3651 To facilitate version control, distribution, and merging of tags,
3668 To facilitate version control, distribution, and merging of tags,
3652 they are stored as a file named ".hgtags" which is managed
3669 they are stored as a file named ".hgtags" which is managed
3653 similarly to other project files and can be hand-edited if
3670 similarly to other project files and can be hand-edited if
3654 necessary. The file '.hg/localtags' is used for local tags (not
3671 necessary. The file '.hg/localtags' is used for local tags (not
3655 shared among repositories).
3672 shared among repositories).
3656
3673
3657 See :hg:`help dates` for a list of formats valid for -d/--date.
3674 See :hg:`help dates` for a list of formats valid for -d/--date.
3658
3675
3659 Since tag names have priority over branch names during revision
3676 Since tag names have priority over branch names during revision
3660 lookup, using an existing branch name as a tag name is discouraged.
3677 lookup, using an existing branch name as a tag name is discouraged.
3661
3678
3662 Returns 0 on success.
3679 Returns 0 on success.
3663 """
3680 """
3664
3681
3665 rev_ = "."
3682 rev_ = "."
3666 names = [t.strip() for t in (name1,) + names]
3683 names = [t.strip() for t in (name1,) + names]
3667 if len(names) != len(set(names)):
3684 if len(names) != len(set(names)):
3668 raise util.Abort(_('tag names must be unique'))
3685 raise util.Abort(_('tag names must be unique'))
3669 for n in names:
3686 for n in names:
3670 if n in ['tip', '.', 'null']:
3687 if n in ['tip', '.', 'null']:
3671 raise util.Abort(_('the name \'%s\' is reserved') % n)
3688 raise util.Abort(_('the name \'%s\' is reserved') % n)
3672 if not n:
3689 if not n:
3673 raise util.Abort(_('tag names cannot consist entirely of whitespace'))
3690 raise util.Abort(_('tag names cannot consist entirely of whitespace'))
3674 if opts.get('rev') and opts.get('remove'):
3691 if opts.get('rev') and opts.get('remove'):
3675 raise util.Abort(_("--rev and --remove are incompatible"))
3692 raise util.Abort(_("--rev and --remove are incompatible"))
3676 if opts.get('rev'):
3693 if opts.get('rev'):
3677 rev_ = opts['rev']
3694 rev_ = opts['rev']
3678 message = opts.get('message')
3695 message = opts.get('message')
3679 if opts.get('remove'):
3696 if opts.get('remove'):
3680 expectedtype = opts.get('local') and 'local' or 'global'
3697 expectedtype = opts.get('local') and 'local' or 'global'
3681 for n in names:
3698 for n in names:
3682 if not repo.tagtype(n):
3699 if not repo.tagtype(n):
3683 raise util.Abort(_('tag \'%s\' does not exist') % n)
3700 raise util.Abort(_('tag \'%s\' does not exist') % n)
3684 if repo.tagtype(n) != expectedtype:
3701 if repo.tagtype(n) != expectedtype:
3685 if expectedtype == 'global':
3702 if expectedtype == 'global':
3686 raise util.Abort(_('tag \'%s\' is not a global tag') % n)
3703 raise util.Abort(_('tag \'%s\' is not a global tag') % n)
3687 else:
3704 else:
3688 raise util.Abort(_('tag \'%s\' is not a local tag') % n)
3705 raise util.Abort(_('tag \'%s\' is not a local tag') % n)
3689 rev_ = nullid
3706 rev_ = nullid
3690 if not message:
3707 if not message:
3691 # we don't translate commit messages
3708 # we don't translate commit messages
3692 message = 'Removed tag %s' % ', '.join(names)
3709 message = 'Removed tag %s' % ', '.join(names)
3693 elif not opts.get('force'):
3710 elif not opts.get('force'):
3694 for n in names:
3711 for n in names:
3695 if n in repo.tags():
3712 if n in repo.tags():
3696 raise util.Abort(_('tag \'%s\' already exists '
3713 raise util.Abort(_('tag \'%s\' already exists '
3697 '(use -f to force)') % n)
3714 '(use -f to force)') % n)
3698 if not rev_ and repo.dirstate.parents()[1] != nullid:
3715 if not rev_ and repo.dirstate.parents()[1] != nullid:
3699 raise util.Abort(_('uncommitted merge - please provide a '
3716 raise util.Abort(_('uncommitted merge - please provide a '
3700 'specific revision'))
3717 'specific revision'))
3701 r = repo[rev_].node()
3718 r = repo[rev_].node()
3702
3719
3703 if not message:
3720 if not message:
3704 # we don't translate commit messages
3721 # we don't translate commit messages
3705 message = ('Added tag %s for changeset %s' %
3722 message = ('Added tag %s for changeset %s' %
3706 (', '.join(names), short(r)))
3723 (', '.join(names), short(r)))
3707
3724
3708 date = opts.get('date')
3725 date = opts.get('date')
3709 if date:
3726 if date:
3710 date = util.parsedate(date)
3727 date = util.parsedate(date)
3711
3728
3712 if opts.get('edit'):
3729 if opts.get('edit'):
3713 message = ui.edit(message, ui.username())
3730 message = ui.edit(message, ui.username())
3714
3731
3715 repo.tag(names, r, message, opts.get('local'), opts.get('user'), date)
3732 repo.tag(names, r, message, opts.get('local'), opts.get('user'), date)
3716
3733
3717 def tags(ui, repo):
3734 def tags(ui, repo):
3718 """list repository tags
3735 """list repository tags
3719
3736
3720 This lists both regular and local tags. When the -v/--verbose
3737 This lists both regular and local tags. When the -v/--verbose
3721 switch is used, a third column "local" is printed for local tags.
3738 switch is used, a third column "local" is printed for local tags.
3722
3739
3723 Returns 0 on success.
3740 Returns 0 on success.
3724 """
3741 """
3725
3742
3726 hexfunc = ui.debugflag and hex or short
3743 hexfunc = ui.debugflag and hex or short
3727 tagtype = ""
3744 tagtype = ""
3728
3745
3729 for t, n in reversed(repo.tagslist()):
3746 for t, n in reversed(repo.tagslist()):
3730 if ui.quiet:
3747 if ui.quiet:
3731 ui.write("%s\n" % t)
3748 ui.write("%s\n" % t)
3732 continue
3749 continue
3733
3750
3734 try:
3751 try:
3735 hn = hexfunc(n)
3752 hn = hexfunc(n)
3736 r = "%5d:%s" % (repo.changelog.rev(n), hn)
3753 r = "%5d:%s" % (repo.changelog.rev(n), hn)
3737 except error.LookupError:
3754 except error.LookupError:
3738 r = " ?:%s" % hn
3755 r = " ?:%s" % hn
3739 else:
3756 else:
3740 spaces = " " * (30 - encoding.colwidth(t))
3757 spaces = " " * (30 - encoding.colwidth(t))
3741 if ui.verbose:
3758 if ui.verbose:
3742 if repo.tagtype(t) == 'local':
3759 if repo.tagtype(t) == 'local':
3743 tagtype = " local"
3760 tagtype = " local"
3744 else:
3761 else:
3745 tagtype = ""
3762 tagtype = ""
3746 ui.write("%s%s %s%s\n" % (t, spaces, r, tagtype))
3763 ui.write("%s%s %s%s\n" % (t, spaces, r, tagtype))
3747
3764
3748 def tip(ui, repo, **opts):
3765 def tip(ui, repo, **opts):
3749 """show the tip revision
3766 """show the tip revision
3750
3767
3751 The tip revision (usually just called the tip) is the changeset
3768 The tip revision (usually just called the tip) is the changeset
3752 most recently added to the repository (and therefore the most
3769 most recently added to the repository (and therefore the most
3753 recently changed head).
3770 recently changed head).
3754
3771
3755 If you have just made a commit, that commit will be the tip. If
3772 If you have just made a commit, that commit will be the tip. If
3756 you have just pulled changes from another repository, the tip of
3773 you have just pulled changes from another repository, the tip of
3757 that repository becomes the current tip. The "tip" tag is special
3774 that repository becomes the current tip. The "tip" tag is special
3758 and cannot be renamed or assigned to a different changeset.
3775 and cannot be renamed or assigned to a different changeset.
3759
3776
3760 Returns 0 on success.
3777 Returns 0 on success.
3761 """
3778 """
3762 displayer = cmdutil.show_changeset(ui, repo, opts)
3779 displayer = cmdutil.show_changeset(ui, repo, opts)
3763 displayer.show(repo[len(repo) - 1])
3780 displayer.show(repo[len(repo) - 1])
3764 displayer.close()
3781 displayer.close()
3765
3782
3766 def unbundle(ui, repo, fname1, *fnames, **opts):
3783 def unbundle(ui, repo, fname1, *fnames, **opts):
3767 """apply one or more changegroup files
3784 """apply one or more changegroup files
3768
3785
3769 Apply one or more compressed changegroup files generated by the
3786 Apply one or more compressed changegroup files generated by the
3770 bundle command.
3787 bundle command.
3771
3788
3772 Returns 0 on success, 1 if an update has unresolved files.
3789 Returns 0 on success, 1 if an update has unresolved files.
3773 """
3790 """
3774 fnames = (fname1,) + fnames
3791 fnames = (fname1,) + fnames
3775
3792
3776 lock = repo.lock()
3793 lock = repo.lock()
3777 try:
3794 try:
3778 for fname in fnames:
3795 for fname in fnames:
3779 f = url.open(ui, fname)
3796 f = url.open(ui, fname)
3780 gen = changegroup.readbundle(f, fname)
3797 gen = changegroup.readbundle(f, fname)
3781 modheads = repo.addchangegroup(gen, 'unbundle', 'bundle:' + fname,
3798 modheads = repo.addchangegroup(gen, 'unbundle', 'bundle:' + fname,
3782 lock=lock)
3799 lock=lock)
3783 finally:
3800 finally:
3784 lock.release()
3801 lock.release()
3785
3802
3786 return postincoming(ui, repo, modheads, opts.get('update'), None)
3803 return postincoming(ui, repo, modheads, opts.get('update'), None)
3787
3804
3788 def update(ui, repo, node=None, rev=None, clean=False, date=None, check=False):
3805 def update(ui, repo, node=None, rev=None, clean=False, date=None, check=False):
3789 """update working directory (or switch revisions)
3806 """update working directory (or switch revisions)
3790
3807
3791 Update the repository's working directory to the specified
3808 Update the repository's working directory to the specified
3792 changeset. If no changeset is specified, update to the tip of the
3809 changeset. If no changeset is specified, update to the tip of the
3793 current named branch.
3810 current named branch.
3794
3811
3795 If the changeset is not a descendant of the working directory's
3812 If the changeset is not a descendant of the working directory's
3796 parent, the update is aborted. With the -c/--check option, the
3813 parent, the update is aborted. With the -c/--check option, the
3797 working directory is checked for uncommitted changes; if none are
3814 working directory is checked for uncommitted changes; if none are
3798 found, the working directory is updated to the specified
3815 found, the working directory is updated to the specified
3799 changeset.
3816 changeset.
3800
3817
3801 The following rules apply when the working directory contains
3818 The following rules apply when the working directory contains
3802 uncommitted changes:
3819 uncommitted changes:
3803
3820
3804 1. If neither -c/--check nor -C/--clean is specified, and if
3821 1. If neither -c/--check nor -C/--clean is specified, and if
3805 the requested changeset is an ancestor or descendant of
3822 the requested changeset is an ancestor or descendant of
3806 the working directory's parent, the uncommitted changes
3823 the working directory's parent, the uncommitted changes
3807 are merged into the requested changeset and the merged
3824 are merged into the requested changeset and the merged
3808 result is left uncommitted. If the requested changeset is
3825 result is left uncommitted. If the requested changeset is
3809 not an ancestor or descendant (that is, it is on another
3826 not an ancestor or descendant (that is, it is on another
3810 branch), the update is aborted and the uncommitted changes
3827 branch), the update is aborted and the uncommitted changes
3811 are preserved.
3828 are preserved.
3812
3829
3813 2. With the -c/--check option, the update is aborted and the
3830 2. With the -c/--check option, the update is aborted and the
3814 uncommitted changes are preserved.
3831 uncommitted changes are preserved.
3815
3832
3816 3. With the -C/--clean option, uncommitted changes are discarded and
3833 3. With the -C/--clean option, uncommitted changes are discarded and
3817 the working directory is updated to the requested changeset.
3834 the working directory is updated to the requested changeset.
3818
3835
3819 Use null as the changeset to remove the working directory (like
3836 Use null as the changeset to remove the working directory (like
3820 :hg:`clone -U`).
3837 :hg:`clone -U`).
3821
3838
3822 If you want to update just one file to an older changeset, use
3839 If you want to update just one file to an older changeset, use
3823 :hg:`revert`.
3840 :hg:`revert`.
3824
3841
3825 See :hg:`help dates` for a list of formats valid for -d/--date.
3842 See :hg:`help dates` for a list of formats valid for -d/--date.
3826
3843
3827 Returns 0 on success, 1 if there are unresolved files.
3844 Returns 0 on success, 1 if there are unresolved files.
3828 """
3845 """
3829 if rev and node:
3846 if rev and node:
3830 raise util.Abort(_("please specify just one revision"))
3847 raise util.Abort(_("please specify just one revision"))
3831
3848
3832 if not rev:
3849 if not rev:
3833 rev = node
3850 rev = node
3834
3851
3835 rev = cmdutil.revsingle(repo, rev, rev).rev()
3852 rev = cmdutil.revsingle(repo, rev, rev).rev()
3836
3853
3837 if check and clean:
3854 if check and clean:
3838 raise util.Abort(_("cannot specify both -c/--check and -C/--clean"))
3855 raise util.Abort(_("cannot specify both -c/--check and -C/--clean"))
3839
3856
3840 if check:
3857 if check:
3841 # we could use dirty() but we can ignore merge and branch trivia
3858 # we could use dirty() but we can ignore merge and branch trivia
3842 c = repo[None]
3859 c = repo[None]
3843 if c.modified() or c.added() or c.removed():
3860 if c.modified() or c.added() or c.removed():
3844 raise util.Abort(_("uncommitted local changes"))
3861 raise util.Abort(_("uncommitted local changes"))
3845
3862
3846 if date:
3863 if date:
3847 if rev:
3864 if rev:
3848 raise util.Abort(_("you can't specify a revision and a date"))
3865 raise util.Abort(_("you can't specify a revision and a date"))
3849 rev = cmdutil.finddate(ui, repo, date)
3866 rev = cmdutil.finddate(ui, repo, date)
3850
3867
3851 if clean or check:
3868 if clean or check:
3852 return hg.clean(repo, rev)
3869 return hg.clean(repo, rev)
3853 else:
3870 else:
3854 return hg.update(repo, rev)
3871 return hg.update(repo, rev)
3855
3872
3856 def verify(ui, repo):
3873 def verify(ui, repo):
3857 """verify the integrity of the repository
3874 """verify the integrity of the repository
3858
3875
3859 Verify the integrity of the current repository.
3876 Verify the integrity of the current repository.
3860
3877
3861 This will perform an extensive check of the repository's
3878 This will perform an extensive check of the repository's
3862 integrity, validating the hashes and checksums of each entry in
3879 integrity, validating the hashes and checksums of each entry in
3863 the changelog, manifest, and tracked files, as well as the
3880 the changelog, manifest, and tracked files, as well as the
3864 integrity of their crosslinks and indices.
3881 integrity of their crosslinks and indices.
3865
3882
3866 Returns 0 on success, 1 if errors are encountered.
3883 Returns 0 on success, 1 if errors are encountered.
3867 """
3884 """
3868 return hg.verify(repo)
3885 return hg.verify(repo)
3869
3886
3870 def version_(ui):
3887 def version_(ui):
3871 """output version and copyright information"""
3888 """output version and copyright information"""
3872 ui.write(_("Mercurial Distributed SCM (version %s)\n")
3889 ui.write(_("Mercurial Distributed SCM (version %s)\n")
3873 % util.version())
3890 % util.version())
3874 ui.status(_(
3891 ui.status(_(
3875 "(see http://mercurial.selenic.com for more information)\n"
3892 "(see http://mercurial.selenic.com for more information)\n"
3876 "\nCopyright (C) 2005-2010 Matt Mackall and others\n"
3893 "\nCopyright (C) 2005-2010 Matt Mackall and others\n"
3877 "This is free software; see the source for copying conditions. "
3894 "This is free software; see the source for copying conditions. "
3878 "There is NO\nwarranty; "
3895 "There is NO\nwarranty; "
3879 "not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n"
3896 "not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n"
3880 ))
3897 ))
3881
3898
3882 # Command options and aliases are listed here, alphabetically
3899 # Command options and aliases are listed here, alphabetically
3883
3900
3884 globalopts = [
3901 globalopts = [
3885 ('R', 'repository', '',
3902 ('R', 'repository', '',
3886 _('repository root directory or name of overlay bundle file'),
3903 _('repository root directory or name of overlay bundle file'),
3887 _('REPO')),
3904 _('REPO')),
3888 ('', 'cwd', '',
3905 ('', 'cwd', '',
3889 _('change working directory'), _('DIR')),
3906 _('change working directory'), _('DIR')),
3890 ('y', 'noninteractive', None,
3907 ('y', 'noninteractive', None,
3891 _('do not prompt, assume \'yes\' for any required answers')),
3908 _('do not prompt, assume \'yes\' for any required answers')),
3892 ('q', 'quiet', None, _('suppress output')),
3909 ('q', 'quiet', None, _('suppress output')),
3893 ('v', 'verbose', None, _('enable additional output')),
3910 ('v', 'verbose', None, _('enable additional output')),
3894 ('', 'config', [],
3911 ('', 'config', [],
3895 _('set/override config option (use \'section.name=value\')'),
3912 _('set/override config option (use \'section.name=value\')'),
3896 _('CONFIG')),
3913 _('CONFIG')),
3897 ('', 'debug', None, _('enable debugging output')),
3914 ('', 'debug', None, _('enable debugging output')),
3898 ('', 'debugger', None, _('start debugger')),
3915 ('', 'debugger', None, _('start debugger')),
3899 ('', 'encoding', encoding.encoding, _('set the charset encoding'),
3916 ('', 'encoding', encoding.encoding, _('set the charset encoding'),
3900 _('ENCODE')),
3917 _('ENCODE')),
3901 ('', 'encodingmode', encoding.encodingmode,
3918 ('', 'encodingmode', encoding.encodingmode,
3902 _('set the charset encoding mode'), _('MODE')),
3919 _('set the charset encoding mode'), _('MODE')),
3903 ('', 'traceback', None, _('always print a traceback on exception')),
3920 ('', 'traceback', None, _('always print a traceback on exception')),
3904 ('', 'time', None, _('time how long the command takes')),
3921 ('', 'time', None, _('time how long the command takes')),
3905 ('', 'profile', None, _('print command execution profile')),
3922 ('', 'profile', None, _('print command execution profile')),
3906 ('', 'version', None, _('output version information and exit')),
3923 ('', 'version', None, _('output version information and exit')),
3907 ('h', 'help', None, _('display help and exit')),
3924 ('h', 'help', None, _('display help and exit')),
3908 ]
3925 ]
3909
3926
3910 dryrunopts = [('n', 'dry-run', None,
3927 dryrunopts = [('n', 'dry-run', None,
3911 _('do not perform actions, just print output'))]
3928 _('do not perform actions, just print output'))]
3912
3929
3913 remoteopts = [
3930 remoteopts = [
3914 ('e', 'ssh', '',
3931 ('e', 'ssh', '',
3915 _('specify ssh command to use'), _('CMD')),
3932 _('specify ssh command to use'), _('CMD')),
3916 ('', 'remotecmd', '',
3933 ('', 'remotecmd', '',
3917 _('specify hg command to run on the remote side'), _('CMD')),
3934 _('specify hg command to run on the remote side'), _('CMD')),
3918 ]
3935 ]
3919
3936
3920 walkopts = [
3937 walkopts = [
3921 ('I', 'include', [],
3938 ('I', 'include', [],
3922 _('include names matching the given patterns'), _('PATTERN')),
3939 _('include names matching the given patterns'), _('PATTERN')),
3923 ('X', 'exclude', [],
3940 ('X', 'exclude', [],
3924 _('exclude names matching the given patterns'), _('PATTERN')),
3941 _('exclude names matching the given patterns'), _('PATTERN')),
3925 ]
3942 ]
3926
3943
3927 commitopts = [
3944 commitopts = [
3928 ('m', 'message', '',
3945 ('m', 'message', '',
3929 _('use text as commit message'), _('TEXT')),
3946 _('use text as commit message'), _('TEXT')),
3930 ('l', 'logfile', '',
3947 ('l', 'logfile', '',
3931 _('read commit message from file'), _('FILE')),
3948 _('read commit message from file'), _('FILE')),
3932 ]
3949 ]
3933
3950
3934 commitopts2 = [
3951 commitopts2 = [
3935 ('d', 'date', '',
3952 ('d', 'date', '',
3936 _('record datecode as commit date'), _('DATE')),
3953 _('record datecode as commit date'), _('DATE')),
3937 ('u', 'user', '',
3954 ('u', 'user', '',
3938 _('record the specified user as committer'), _('USER')),
3955 _('record the specified user as committer'), _('USER')),
3939 ]
3956 ]
3940
3957
3941 templateopts = [
3958 templateopts = [
3942 ('', 'style', '',
3959 ('', 'style', '',
3943 _('display using template map file'), _('STYLE')),
3960 _('display using template map file'), _('STYLE')),
3944 ('', 'template', '',
3961 ('', 'template', '',
3945 _('display with template'), _('TEMPLATE')),
3962 _('display with template'), _('TEMPLATE')),
3946 ]
3963 ]
3947
3964
3948 logopts = [
3965 logopts = [
3949 ('p', 'patch', None, _('show patch')),
3966 ('p', 'patch', None, _('show patch')),
3950 ('g', 'git', None, _('use git extended diff format')),
3967 ('g', 'git', None, _('use git extended diff format')),
3951 ('l', 'limit', '',
3968 ('l', 'limit', '',
3952 _('limit number of changes displayed'), _('NUM')),
3969 _('limit number of changes displayed'), _('NUM')),
3953 ('M', 'no-merges', None, _('do not show merges')),
3970 ('M', 'no-merges', None, _('do not show merges')),
3954 ('', 'stat', None, _('output diffstat-style summary of changes')),
3971 ('', 'stat', None, _('output diffstat-style summary of changes')),
3955 ] + templateopts
3972 ] + templateopts
3956
3973
3957 diffopts = [
3974 diffopts = [
3958 ('a', 'text', None, _('treat all files as text')),
3975 ('a', 'text', None, _('treat all files as text')),
3959 ('g', 'git', None, _('use git extended diff format')),
3976 ('g', 'git', None, _('use git extended diff format')),
3960 ('', 'nodates', None, _('omit dates from diff headers'))
3977 ('', 'nodates', None, _('omit dates from diff headers'))
3961 ]
3978 ]
3962
3979
3963 diffopts2 = [
3980 diffopts2 = [
3964 ('p', 'show-function', None, _('show which function each change is in')),
3981 ('p', 'show-function', None, _('show which function each change is in')),
3965 ('', 'reverse', None, _('produce a diff that undoes the changes')),
3982 ('', 'reverse', None, _('produce a diff that undoes the changes')),
3966 ('w', 'ignore-all-space', None,
3983 ('w', 'ignore-all-space', None,
3967 _('ignore white space when comparing lines')),
3984 _('ignore white space when comparing lines')),
3968 ('b', 'ignore-space-change', None,
3985 ('b', 'ignore-space-change', None,
3969 _('ignore changes in the amount of white space')),
3986 _('ignore changes in the amount of white space')),
3970 ('B', 'ignore-blank-lines', None,
3987 ('B', 'ignore-blank-lines', None,
3971 _('ignore changes whose lines are all blank')),
3988 _('ignore changes whose lines are all blank')),
3972 ('U', 'unified', '',
3989 ('U', 'unified', '',
3973 _('number of lines of context to show'), _('NUM')),
3990 _('number of lines of context to show'), _('NUM')),
3974 ('', 'stat', None, _('output diffstat-style summary of changes')),
3991 ('', 'stat', None, _('output diffstat-style summary of changes')),
3975 ]
3992 ]
3976
3993
3977 similarityopts = [
3994 similarityopts = [
3978 ('s', 'similarity', '',
3995 ('s', 'similarity', '',
3979 _('guess renamed files by similarity (0<=s<=100)'), _('SIMILARITY'))
3996 _('guess renamed files by similarity (0<=s<=100)'), _('SIMILARITY'))
3980 ]
3997 ]
3981
3998
3982 subrepoopts = [
3999 subrepoopts = [
3983 ('S', 'subrepos', None,
4000 ('S', 'subrepos', None,
3984 _('recurse into subrepositories'))
4001 _('recurse into subrepositories'))
3985 ]
4002 ]
3986
4003
3987 table = {
4004 table = {
3988 "^add": (add, walkopts + subrepoopts + dryrunopts,
4005 "^add": (add, walkopts + subrepoopts + dryrunopts,
3989 _('[OPTION]... [FILE]...')),
4006 _('[OPTION]... [FILE]...')),
3990 "addremove":
4007 "addremove":
3991 (addremove, similarityopts + walkopts + dryrunopts,
4008 (addremove, similarityopts + walkopts + dryrunopts,
3992 _('[OPTION]... [FILE]...')),
4009 _('[OPTION]... [FILE]...')),
3993 "^annotate|blame":
4010 "^annotate|blame":
3994 (annotate,
4011 (annotate,
3995 [('r', 'rev', '',
4012 [('r', 'rev', '',
3996 _('annotate the specified revision'), _('REV')),
4013 _('annotate the specified revision'), _('REV')),
3997 ('', 'follow', None,
4014 ('', 'follow', None,
3998 _('follow copies/renames and list the filename (DEPRECATED)')),
4015 _('follow copies/renames and list the filename (DEPRECATED)')),
3999 ('', 'no-follow', None, _("don't follow copies and renames")),
4016 ('', 'no-follow', None, _("don't follow copies and renames")),
4000 ('a', 'text', None, _('treat all files as text')),
4017 ('a', 'text', None, _('treat all files as text')),
4001 ('u', 'user', None, _('list the author (long with -v)')),
4018 ('u', 'user', None, _('list the author (long with -v)')),
4002 ('f', 'file', None, _('list the filename')),
4019 ('f', 'file', None, _('list the filename')),
4003 ('d', 'date', None, _('list the date (short with -q)')),
4020 ('d', 'date', None, _('list the date (short with -q)')),
4004 ('n', 'number', None, _('list the revision number (default)')),
4021 ('n', 'number', None, _('list the revision number (default)')),
4005 ('c', 'changeset', None, _('list the changeset')),
4022 ('c', 'changeset', None, _('list the changeset')),
4006 ('l', 'line-number', None,
4023 ('l', 'line-number', None,
4007 _('show line number at the first appearance'))
4024 _('show line number at the first appearance'))
4008 ] + walkopts,
4025 ] + walkopts,
4009 _('[-r REV] [-f] [-a] [-u] [-d] [-n] [-c] [-l] FILE...')),
4026 _('[-r REV] [-f] [-a] [-u] [-d] [-n] [-c] [-l] FILE...')),
4010 "archive":
4027 "archive":
4011 (archive,
4028 (archive,
4012 [('', 'no-decode', None, _('do not pass files through decoders')),
4029 [('', 'no-decode', None, _('do not pass files through decoders')),
4013 ('p', 'prefix', '',
4030 ('p', 'prefix', '',
4014 _('directory prefix for files in archive'), _('PREFIX')),
4031 _('directory prefix for files in archive'), _('PREFIX')),
4015 ('r', 'rev', '',
4032 ('r', 'rev', '',
4016 _('revision to distribute'), _('REV')),
4033 _('revision to distribute'), _('REV')),
4017 ('t', 'type', '',
4034 ('t', 'type', '',
4018 _('type of distribution to create'), _('TYPE')),
4035 _('type of distribution to create'), _('TYPE')),
4019 ] + subrepoopts + walkopts,
4036 ] + subrepoopts + walkopts,
4020 _('[OPTION]... DEST')),
4037 _('[OPTION]... DEST')),
4021 "backout":
4038 "backout":
4022 (backout,
4039 (backout,
4023 [('', 'merge', None,
4040 [('', 'merge', None,
4024 _('merge with old dirstate parent after backout')),
4041 _('merge with old dirstate parent after backout')),
4025 ('', 'parent', '',
4042 ('', 'parent', '',
4026 _('parent to choose when backing out merge'), _('REV')),
4043 _('parent to choose when backing out merge'), _('REV')),
4027 ('t', 'tool', '',
4044 ('t', 'tool', '',
4028 _('specify merge tool')),
4045 _('specify merge tool')),
4029 ('r', 'rev', '',
4046 ('r', 'rev', '',
4030 _('revision to backout'), _('REV')),
4047 _('revision to backout'), _('REV')),
4031 ] + walkopts + commitopts + commitopts2,
4048 ] + walkopts + commitopts + commitopts2,
4032 _('[OPTION]... [-r] REV')),
4049 _('[OPTION]... [-r] REV')),
4033 "bisect":
4050 "bisect":
4034 (bisect,
4051 (bisect,
4035 [('r', 'reset', False, _('reset bisect state')),
4052 [('r', 'reset', False, _('reset bisect state')),
4036 ('g', 'good', False, _('mark changeset good')),
4053 ('g', 'good', False, _('mark changeset good')),
4037 ('b', 'bad', False, _('mark changeset bad')),
4054 ('b', 'bad', False, _('mark changeset bad')),
4038 ('s', 'skip', False, _('skip testing changeset')),
4055 ('s', 'skip', False, _('skip testing changeset')),
4039 ('c', 'command', '',
4056 ('c', 'command', '',
4040 _('use command to check changeset state'), _('CMD')),
4057 _('use command to check changeset state'), _('CMD')),
4041 ('U', 'noupdate', False, _('do not update to target'))],
4058 ('U', 'noupdate', False, _('do not update to target'))],
4042 _("[-gbsr] [-U] [-c CMD] [REV]")),
4059 _("[-gbsr] [-U] [-c CMD] [REV]")),
4043 "branch":
4060 "branch":
4044 (branch,
4061 (branch,
4045 [('f', 'force', None,
4062 [('f', 'force', None,
4046 _('set branch name even if it shadows an existing branch')),
4063 _('set branch name even if it shadows an existing branch')),
4047 ('C', 'clean', None, _('reset branch name to parent branch name'))],
4064 ('C', 'clean', None, _('reset branch name to parent branch name'))],
4048 _('[-fC] [NAME]')),
4065 _('[-fC] [NAME]')),
4049 "branches":
4066 "branches":
4050 (branches,
4067 (branches,
4051 [('a', 'active', False,
4068 [('a', 'active', False,
4052 _('show only branches that have unmerged heads')),
4069 _('show only branches that have unmerged heads')),
4053 ('c', 'closed', False,
4070 ('c', 'closed', False,
4054 _('show normal and closed branches'))],
4071 _('show normal and closed branches'))],
4055 _('[-ac]')),
4072 _('[-ac]')),
4056 "bundle":
4073 "bundle":
4057 (bundle,
4074 (bundle,
4058 [('f', 'force', None,
4075 [('f', 'force', None,
4059 _('run even when the destination is unrelated')),
4076 _('run even when the destination is unrelated')),
4060 ('r', 'rev', [],
4077 ('r', 'rev', [],
4061 _('a changeset intended to be added to the destination'),
4078 _('a changeset intended to be added to the destination'),
4062 _('REV')),
4079 _('REV')),
4063 ('b', 'branch', [],
4080 ('b', 'branch', [],
4064 _('a specific branch you would like to bundle'),
4081 _('a specific branch you would like to bundle'),
4065 _('BRANCH')),
4082 _('BRANCH')),
4066 ('', 'base', [],
4083 ('', 'base', [],
4067 _('a base changeset assumed to be available at the destination'),
4084 _('a base changeset assumed to be available at the destination'),
4068 _('REV')),
4085 _('REV')),
4069 ('a', 'all', None, _('bundle all changesets in the repository')),
4086 ('a', 'all', None, _('bundle all changesets in the repository')),
4070 ('t', 'type', 'bzip2',
4087 ('t', 'type', 'bzip2',
4071 _('bundle compression type to use'), _('TYPE')),
4088 _('bundle compression type to use'), _('TYPE')),
4072 ] + remoteopts,
4089 ] + remoteopts,
4073 _('[-f] [-t TYPE] [-a] [-r REV]... [--base REV]... FILE [DEST]')),
4090 _('[-f] [-t TYPE] [-a] [-r REV]... [--base REV]... FILE [DEST]')),
4074 "cat":
4091 "cat":
4075 (cat,
4092 (cat,
4076 [('o', 'output', '',
4093 [('o', 'output', '',
4077 _('print output to file with formatted name'), _('FORMAT')),
4094 _('print output to file with formatted name'), _('FORMAT')),
4078 ('r', 'rev', '',
4095 ('r', 'rev', '',
4079 _('print the given revision'), _('REV')),
4096 _('print the given revision'), _('REV')),
4080 ('', 'decode', None, _('apply any matching decode filter')),
4097 ('', 'decode', None, _('apply any matching decode filter')),
4081 ] + walkopts,
4098 ] + walkopts,
4082 _('[OPTION]... FILE...')),
4099 _('[OPTION]... FILE...')),
4083 "^clone":
4100 "^clone":
4084 (clone,
4101 (clone,
4085 [('U', 'noupdate', None,
4102 [('U', 'noupdate', None,
4086 _('the clone will include an empty working copy (only a repository)')),
4103 _('the clone will include an empty working copy (only a repository)')),
4087 ('u', 'updaterev', '',
4104 ('u', 'updaterev', '',
4088 _('revision, tag or branch to check out'), _('REV')),
4105 _('revision, tag or branch to check out'), _('REV')),
4089 ('r', 'rev', [],
4106 ('r', 'rev', [],
4090 _('include the specified changeset'), _('REV')),
4107 _('include the specified changeset'), _('REV')),
4091 ('b', 'branch', [],
4108 ('b', 'branch', [],
4092 _('clone only the specified branch'), _('BRANCH')),
4109 _('clone only the specified branch'), _('BRANCH')),
4093 ('', 'pull', None, _('use pull protocol to copy metadata')),
4110 ('', 'pull', None, _('use pull protocol to copy metadata')),
4094 ('', 'uncompressed', None,
4111 ('', 'uncompressed', None,
4095 _('use uncompressed transfer (fast over LAN)')),
4112 _('use uncompressed transfer (fast over LAN)')),
4096 ] + remoteopts,
4113 ] + remoteopts,
4097 _('[OPTION]... SOURCE [DEST]')),
4114 _('[OPTION]... SOURCE [DEST]')),
4098 "^commit|ci":
4115 "^commit|ci":
4099 (commit,
4116 (commit,
4100 [('A', 'addremove', None,
4117 [('A', 'addremove', None,
4101 _('mark new/missing files as added/removed before committing')),
4118 _('mark new/missing files as added/removed before committing')),
4102 ('', 'close-branch', None,
4119 ('', 'close-branch', None,
4103 _('mark a branch as closed, hiding it from the branch list')),
4120 _('mark a branch as closed, hiding it from the branch list')),
4104 ] + walkopts + commitopts + commitopts2,
4121 ] + walkopts + commitopts + commitopts2,
4105 _('[OPTION]... [FILE]...')),
4122 _('[OPTION]... [FILE]...')),
4106 "copy|cp":
4123 "copy|cp":
4107 (copy,
4124 (copy,
4108 [('A', 'after', None, _('record a copy that has already occurred')),
4125 [('A', 'after', None, _('record a copy that has already occurred')),
4109 ('f', 'force', None,
4126 ('f', 'force', None,
4110 _('forcibly copy over an existing managed file')),
4127 _('forcibly copy over an existing managed file')),
4111 ] + walkopts + dryrunopts,
4128 ] + walkopts + dryrunopts,
4112 _('[OPTION]... [SOURCE]... DEST')),
4129 _('[OPTION]... [SOURCE]... DEST')),
4113 "debugancestor": (debugancestor, [], _('[INDEX] REV1 REV2')),
4130 "debugancestor": (debugancestor, [], _('[INDEX] REV1 REV2')),
4114 "debugbuilddag":
4131 "debugbuilddag":
4115 (debugbuilddag,
4132 (debugbuilddag,
4116 [('m', 'mergeable-file', None, _('add single file mergeable changes')),
4133 [('m', 'mergeable-file', None, _('add single file mergeable changes')),
4117 ('a', 'appended-file', None, _('add single file all revs append to')),
4134 ('a', 'appended-file', None, _('add single file all revs append to')),
4118 ('o', 'overwritten-file', None, _('add single file all revs overwrite')),
4135 ('o', 'overwritten-file', None, _('add single file all revs overwrite')),
4119 ('n', 'new-file', None, _('add new file at each rev')),
4136 ('n', 'new-file', None, _('add new file at each rev')),
4120 ],
4137 ],
4121 _('[OPTION]... TEXT')),
4138 _('[OPTION]... TEXT')),
4122 "debugcheckstate": (debugcheckstate, [], ''),
4139 "debugcheckstate": (debugcheckstate, [], ''),
4123 "debugcommands": (debugcommands, [], _('[COMMAND]')),
4140 "debugcommands": (debugcommands, [], _('[COMMAND]')),
4124 "debugcomplete":
4141 "debugcomplete":
4125 (debugcomplete,
4142 (debugcomplete,
4126 [('o', 'options', None, _('show the command options'))],
4143 [('o', 'options', None, _('show the command options'))],
4127 _('[-o] CMD')),
4144 _('[-o] CMD')),
4128 "debugdag":
4145 "debugdag":
4129 (debugdag,
4146 (debugdag,
4130 [('t', 'tags', None, _('use tags as labels')),
4147 [('t', 'tags', None, _('use tags as labels')),
4131 ('b', 'branches', None, _('annotate with branch names')),
4148 ('b', 'branches', None, _('annotate with branch names')),
4132 ('', 'dots', None, _('use dots for runs')),
4149 ('', 'dots', None, _('use dots for runs')),
4133 ('s', 'spaces', None, _('separate elements by spaces')),
4150 ('s', 'spaces', None, _('separate elements by spaces')),
4134 ],
4151 ],
4135 _('[OPTION]... [FILE [REV]...]')),
4152 _('[OPTION]... [FILE [REV]...]')),
4136 "debugdate":
4153 "debugdate":
4137 (debugdate,
4154 (debugdate,
4138 [('e', 'extended', None, _('try extended date formats'))],
4155 [('e', 'extended', None, _('try extended date formats'))],
4139 _('[-e] DATE [RANGE]')),
4156 _('[-e] DATE [RANGE]')),
4140 "debugdata": (debugdata, [], _('FILE REV')),
4157 "debugdata": (debugdata, [], _('FILE REV')),
4141 "debugfsinfo": (debugfsinfo, [], _('[PATH]')),
4158 "debugfsinfo": (debugfsinfo, [], _('[PATH]')),
4142 "debugindex": (debugindex, [], _('FILE')),
4159 "debugindex": (debugindex,
4160 [('f', 'format', 0, _('revlog format'), _('FORMAT'))],
4161 _('FILE')),
4143 "debugindexdot": (debugindexdot, [], _('FILE')),
4162 "debugindexdot": (debugindexdot, [], _('FILE')),
4144 "debuginstall": (debuginstall, [], ''),
4163 "debuginstall": (debuginstall, [], ''),
4145 "debugpushkey": (debugpushkey, [], _('REPO NAMESPACE [KEY OLD NEW]')),
4164 "debugpushkey": (debugpushkey, [], _('REPO NAMESPACE [KEY OLD NEW]')),
4146 "debugrebuildstate":
4165 "debugrebuildstate":
4147 (debugrebuildstate,
4166 (debugrebuildstate,
4148 [('r', 'rev', '',
4167 [('r', 'rev', '',
4149 _('revision to rebuild to'), _('REV'))],
4168 _('revision to rebuild to'), _('REV'))],
4150 _('[-r REV] [REV]')),
4169 _('[-r REV] [REV]')),
4151 "debugrename":
4170 "debugrename":
4152 (debugrename,
4171 (debugrename,
4153 [('r', 'rev', '',
4172 [('r', 'rev', '',
4154 _('revision to debug'), _('REV'))],
4173 _('revision to debug'), _('REV'))],
4155 _('[-r REV] FILE')),
4174 _('[-r REV] FILE')),
4156 "debugrevspec":
4175 "debugrevspec":
4157 (debugrevspec, [], ('REVSPEC')),
4176 (debugrevspec, [], ('REVSPEC')),
4158 "debugsetparents":
4177 "debugsetparents":
4159 (debugsetparents, [], _('REV1 [REV2]')),
4178 (debugsetparents, [], _('REV1 [REV2]')),
4160 "debugstate":
4179 "debugstate":
4161 (debugstate,
4180 (debugstate,
4162 [('', 'nodates', None, _('do not display the saved mtime'))],
4181 [('', 'nodates', None, _('do not display the saved mtime'))],
4163 _('[OPTION]...')),
4182 _('[OPTION]...')),
4164 "debugsub":
4183 "debugsub":
4165 (debugsub,
4184 (debugsub,
4166 [('r', 'rev', '',
4185 [('r', 'rev', '',
4167 _('revision to check'), _('REV'))],
4186 _('revision to check'), _('REV'))],
4168 _('[-r REV] [REV]')),
4187 _('[-r REV] [REV]')),
4169 "debugwalk": (debugwalk, walkopts, _('[OPTION]... [FILE]...')),
4188 "debugwalk": (debugwalk, walkopts, _('[OPTION]... [FILE]...')),
4170 "^diff":
4189 "^diff":
4171 (diff,
4190 (diff,
4172 [('r', 'rev', [],
4191 [('r', 'rev', [],
4173 _('revision'), _('REV')),
4192 _('revision'), _('REV')),
4174 ('c', 'change', '',
4193 ('c', 'change', '',
4175 _('change made by revision'), _('REV'))
4194 _('change made by revision'), _('REV'))
4176 ] + diffopts + diffopts2 + walkopts + subrepoopts,
4195 ] + diffopts + diffopts2 + walkopts + subrepoopts,
4177 _('[OPTION]... ([-c REV] | [-r REV1 [-r REV2]]) [FILE]...')),
4196 _('[OPTION]... ([-c REV] | [-r REV1 [-r REV2]]) [FILE]...')),
4178 "^export":
4197 "^export":
4179 (export,
4198 (export,
4180 [('o', 'output', '',
4199 [('o', 'output', '',
4181 _('print output to file with formatted name'), _('FORMAT')),
4200 _('print output to file with formatted name'), _('FORMAT')),
4182 ('', 'switch-parent', None, _('diff against the second parent')),
4201 ('', 'switch-parent', None, _('diff against the second parent')),
4183 ('r', 'rev', [],
4202 ('r', 'rev', [],
4184 _('revisions to export'), _('REV')),
4203 _('revisions to export'), _('REV')),
4185 ] + diffopts,
4204 ] + diffopts,
4186 _('[OPTION]... [-o OUTFILESPEC] REV...')),
4205 _('[OPTION]... [-o OUTFILESPEC] REV...')),
4187 "^forget":
4206 "^forget":
4188 (forget,
4207 (forget,
4189 [] + walkopts,
4208 [] + walkopts,
4190 _('[OPTION]... FILE...')),
4209 _('[OPTION]... FILE...')),
4191 "grep":
4210 "grep":
4192 (grep,
4211 (grep,
4193 [('0', 'print0', None, _('end fields with NUL')),
4212 [('0', 'print0', None, _('end fields with NUL')),
4194 ('', 'all', None, _('print all revisions that match')),
4213 ('', 'all', None, _('print all revisions that match')),
4195 ('f', 'follow', None,
4214 ('f', 'follow', None,
4196 _('follow changeset history,'
4215 _('follow changeset history,'
4197 ' or file history across copies and renames')),
4216 ' or file history across copies and renames')),
4198 ('i', 'ignore-case', None, _('ignore case when matching')),
4217 ('i', 'ignore-case', None, _('ignore case when matching')),
4199 ('l', 'files-with-matches', None,
4218 ('l', 'files-with-matches', None,
4200 _('print only filenames and revisions that match')),
4219 _('print only filenames and revisions that match')),
4201 ('n', 'line-number', None, _('print matching line numbers')),
4220 ('n', 'line-number', None, _('print matching line numbers')),
4202 ('r', 'rev', [],
4221 ('r', 'rev', [],
4203 _('only search files changed within revision range'), _('REV')),
4222 _('only search files changed within revision range'), _('REV')),
4204 ('u', 'user', None, _('list the author (long with -v)')),
4223 ('u', 'user', None, _('list the author (long with -v)')),
4205 ('d', 'date', None, _('list the date (short with -q)')),
4224 ('d', 'date', None, _('list the date (short with -q)')),
4206 ] + walkopts,
4225 ] + walkopts,
4207 _('[OPTION]... PATTERN [FILE]...')),
4226 _('[OPTION]... PATTERN [FILE]...')),
4208 "heads":
4227 "heads":
4209 (heads,
4228 (heads,
4210 [('r', 'rev', '',
4229 [('r', 'rev', '',
4211 _('show only heads which are descendants of STARTREV'),
4230 _('show only heads which are descendants of STARTREV'),
4212 _('STARTREV')),
4231 _('STARTREV')),
4213 ('t', 'topo', False, _('show topological heads only')),
4232 ('t', 'topo', False, _('show topological heads only')),
4214 ('a', 'active', False,
4233 ('a', 'active', False,
4215 _('show active branchheads only (DEPRECATED)')),
4234 _('show active branchheads only (DEPRECATED)')),
4216 ('c', 'closed', False,
4235 ('c', 'closed', False,
4217 _('show normal and closed branch heads')),
4236 _('show normal and closed branch heads')),
4218 ] + templateopts,
4237 ] + templateopts,
4219 _('[-ac] [-r STARTREV] [REV]...')),
4238 _('[-ac] [-r STARTREV] [REV]...')),
4220 "help": (help_, [], _('[TOPIC]')),
4239 "help": (help_, [], _('[TOPIC]')),
4221 "identify|id":
4240 "identify|id":
4222 (identify,
4241 (identify,
4223 [('r', 'rev', '',
4242 [('r', 'rev', '',
4224 _('identify the specified revision'), _('REV')),
4243 _('identify the specified revision'), _('REV')),
4225 ('n', 'num', None, _('show local revision number')),
4244 ('n', 'num', None, _('show local revision number')),
4226 ('i', 'id', None, _('show global revision id')),
4245 ('i', 'id', None, _('show global revision id')),
4227 ('b', 'branch', None, _('show branch')),
4246 ('b', 'branch', None, _('show branch')),
4228 ('t', 'tags', None, _('show tags'))],
4247 ('t', 'tags', None, _('show tags'))],
4229 _('[-nibt] [-r REV] [SOURCE]')),
4248 _('[-nibt] [-r REV] [SOURCE]')),
4230 "import|patch":
4249 "import|patch":
4231 (import_,
4250 (import_,
4232 [('p', 'strip', 1,
4251 [('p', 'strip', 1,
4233 _('directory strip option for patch. This has the same '
4252 _('directory strip option for patch. This has the same '
4234 'meaning as the corresponding patch option'),
4253 'meaning as the corresponding patch option'),
4235 _('NUM')),
4254 _('NUM')),
4236 ('b', 'base', '',
4255 ('b', 'base', '',
4237 _('base path'), _('PATH')),
4256 _('base path'), _('PATH')),
4238 ('f', 'force', None,
4257 ('f', 'force', None,
4239 _('skip check for outstanding uncommitted changes')),
4258 _('skip check for outstanding uncommitted changes')),
4240 ('', 'no-commit', None,
4259 ('', 'no-commit', None,
4241 _("don't commit, just update the working directory")),
4260 _("don't commit, just update the working directory")),
4242 ('', 'exact', None,
4261 ('', 'exact', None,
4243 _('apply patch to the nodes from which it was generated')),
4262 _('apply patch to the nodes from which it was generated')),
4244 ('', 'import-branch', None,
4263 ('', 'import-branch', None,
4245 _('use any branch information in patch (implied by --exact)'))] +
4264 _('use any branch information in patch (implied by --exact)'))] +
4246 commitopts + commitopts2 + similarityopts,
4265 commitopts + commitopts2 + similarityopts,
4247 _('[OPTION]... PATCH...')),
4266 _('[OPTION]... PATCH...')),
4248 "incoming|in":
4267 "incoming|in":
4249 (incoming,
4268 (incoming,
4250 [('f', 'force', None,
4269 [('f', 'force', None,
4251 _('run even if remote repository is unrelated')),
4270 _('run even if remote repository is unrelated')),
4252 ('n', 'newest-first', None, _('show newest record first')),
4271 ('n', 'newest-first', None, _('show newest record first')),
4253 ('', 'bundle', '',
4272 ('', 'bundle', '',
4254 _('file to store the bundles into'), _('FILE')),
4273 _('file to store the bundles into'), _('FILE')),
4255 ('r', 'rev', [],
4274 ('r', 'rev', [],
4256 _('a remote changeset intended to be added'), _('REV')),
4275 _('a remote changeset intended to be added'), _('REV')),
4257 ('b', 'branch', [],
4276 ('b', 'branch', [],
4258 _('a specific branch you would like to pull'), _('BRANCH')),
4277 _('a specific branch you would like to pull'), _('BRANCH')),
4259 ] + logopts + remoteopts + subrepoopts,
4278 ] + logopts + remoteopts + subrepoopts,
4260 _('[-p] [-n] [-M] [-f] [-r REV]...'
4279 _('[-p] [-n] [-M] [-f] [-r REV]...'
4261 ' [--bundle FILENAME] [SOURCE]')),
4280 ' [--bundle FILENAME] [SOURCE]')),
4262 "^init":
4281 "^init":
4263 (init,
4282 (init,
4264 remoteopts,
4283 remoteopts,
4265 _('[-e CMD] [--remotecmd CMD] [DEST]')),
4284 _('[-e CMD] [--remotecmd CMD] [DEST]')),
4266 "locate":
4285 "locate":
4267 (locate,
4286 (locate,
4268 [('r', 'rev', '',
4287 [('r', 'rev', '',
4269 _('search the repository as it is in REV'), _('REV')),
4288 _('search the repository as it is in REV'), _('REV')),
4270 ('0', 'print0', None,
4289 ('0', 'print0', None,
4271 _('end filenames with NUL, for use with xargs')),
4290 _('end filenames with NUL, for use with xargs')),
4272 ('f', 'fullpath', None,
4291 ('f', 'fullpath', None,
4273 _('print complete paths from the filesystem root')),
4292 _('print complete paths from the filesystem root')),
4274 ] + walkopts,
4293 ] + walkopts,
4275 _('[OPTION]... [PATTERN]...')),
4294 _('[OPTION]... [PATTERN]...')),
4276 "^log|history":
4295 "^log|history":
4277 (log,
4296 (log,
4278 [('f', 'follow', None,
4297 [('f', 'follow', None,
4279 _('follow changeset history,'
4298 _('follow changeset history,'
4280 ' or file history across copies and renames')),
4299 ' or file history across copies and renames')),
4281 ('', 'follow-first', None,
4300 ('', 'follow-first', None,
4282 _('only follow the first parent of merge changesets')),
4301 _('only follow the first parent of merge changesets')),
4283 ('d', 'date', '',
4302 ('d', 'date', '',
4284 _('show revisions matching date spec'), _('DATE')),
4303 _('show revisions matching date spec'), _('DATE')),
4285 ('C', 'copies', None, _('show copied files')),
4304 ('C', 'copies', None, _('show copied files')),
4286 ('k', 'keyword', [],
4305 ('k', 'keyword', [],
4287 _('do case-insensitive search for a given text'), _('TEXT')),
4306 _('do case-insensitive search for a given text'), _('TEXT')),
4288 ('r', 'rev', [],
4307 ('r', 'rev', [],
4289 _('show the specified revision or range'), _('REV')),
4308 _('show the specified revision or range'), _('REV')),
4290 ('', 'removed', None, _('include revisions where files were removed')),
4309 ('', 'removed', None, _('include revisions where files were removed')),
4291 ('m', 'only-merges', None, _('show only merges')),
4310 ('m', 'only-merges', None, _('show only merges')),
4292 ('u', 'user', [],
4311 ('u', 'user', [],
4293 _('revisions committed by user'), _('USER')),
4312 _('revisions committed by user'), _('USER')),
4294 ('', 'only-branch', [],
4313 ('', 'only-branch', [],
4295 _('show only changesets within the given named branch (DEPRECATED)'),
4314 _('show only changesets within the given named branch (DEPRECATED)'),
4296 _('BRANCH')),
4315 _('BRANCH')),
4297 ('b', 'branch', [],
4316 ('b', 'branch', [],
4298 _('show changesets within the given named branch'), _('BRANCH')),
4317 _('show changesets within the given named branch'), _('BRANCH')),
4299 ('P', 'prune', [],
4318 ('P', 'prune', [],
4300 _('do not display revision or any of its ancestors'), _('REV')),
4319 _('do not display revision or any of its ancestors'), _('REV')),
4301 ] + logopts + walkopts,
4320 ] + logopts + walkopts,
4302 _('[OPTION]... [FILE]')),
4321 _('[OPTION]... [FILE]')),
4303 "manifest":
4322 "manifest":
4304 (manifest,
4323 (manifest,
4305 [('r', 'rev', '',
4324 [('r', 'rev', '',
4306 _('revision to display'), _('REV'))],
4325 _('revision to display'), _('REV'))],
4307 _('[-r REV]')),
4326 _('[-r REV]')),
4308 "^merge":
4327 "^merge":
4309 (merge,
4328 (merge,
4310 [('f', 'force', None, _('force a merge with outstanding changes')),
4329 [('f', 'force', None, _('force a merge with outstanding changes')),
4311 ('t', 'tool', '', _('specify merge tool')),
4330 ('t', 'tool', '', _('specify merge tool')),
4312 ('r', 'rev', '',
4331 ('r', 'rev', '',
4313 _('revision to merge'), _('REV')),
4332 _('revision to merge'), _('REV')),
4314 ('P', 'preview', None,
4333 ('P', 'preview', None,
4315 _('review revisions to merge (no merge is performed)'))],
4334 _('review revisions to merge (no merge is performed)'))],
4316 _('[-P] [-f] [[-r] REV]')),
4335 _('[-P] [-f] [[-r] REV]')),
4317 "outgoing|out":
4336 "outgoing|out":
4318 (outgoing,
4337 (outgoing,
4319 [('f', 'force', None,
4338 [('f', 'force', None,
4320 _('run even when the destination is unrelated')),
4339 _('run even when the destination is unrelated')),
4321 ('r', 'rev', [],
4340 ('r', 'rev', [],
4322 _('a changeset intended to be included in the destination'),
4341 _('a changeset intended to be included in the destination'),
4323 _('REV')),
4342 _('REV')),
4324 ('n', 'newest-first', None, _('show newest record first')),
4343 ('n', 'newest-first', None, _('show newest record first')),
4325 ('b', 'branch', [],
4344 ('b', 'branch', [],
4326 _('a specific branch you would like to push'), _('BRANCH')),
4345 _('a specific branch you would like to push'), _('BRANCH')),
4327 ] + logopts + remoteopts + subrepoopts,
4346 ] + logopts + remoteopts + subrepoopts,
4328 _('[-M] [-p] [-n] [-f] [-r REV]... [DEST]')),
4347 _('[-M] [-p] [-n] [-f] [-r REV]... [DEST]')),
4329 "parents":
4348 "parents":
4330 (parents,
4349 (parents,
4331 [('r', 'rev', '',
4350 [('r', 'rev', '',
4332 _('show parents of the specified revision'), _('REV')),
4351 _('show parents of the specified revision'), _('REV')),
4333 ] + templateopts,
4352 ] + templateopts,
4334 _('[-r REV] [FILE]')),
4353 _('[-r REV] [FILE]')),
4335 "paths": (paths, [], _('[NAME]')),
4354 "paths": (paths, [], _('[NAME]')),
4336 "^pull":
4355 "^pull":
4337 (pull,
4356 (pull,
4338 [('u', 'update', None,
4357 [('u', 'update', None,
4339 _('update to new branch head if changesets were pulled')),
4358 _('update to new branch head if changesets were pulled')),
4340 ('f', 'force', None,
4359 ('f', 'force', None,
4341 _('run even when remote repository is unrelated')),
4360 _('run even when remote repository is unrelated')),
4342 ('r', 'rev', [],
4361 ('r', 'rev', [],
4343 _('a remote changeset intended to be added'), _('REV')),
4362 _('a remote changeset intended to be added'), _('REV')),
4344 ('b', 'branch', [],
4363 ('b', 'branch', [],
4345 _('a specific branch you would like to pull'), _('BRANCH')),
4364 _('a specific branch you would like to pull'), _('BRANCH')),
4346 ] + remoteopts,
4365 ] + remoteopts,
4347 _('[-u] [-f] [-r REV]... [-e CMD] [--remotecmd CMD] [SOURCE]')),
4366 _('[-u] [-f] [-r REV]... [-e CMD] [--remotecmd CMD] [SOURCE]')),
4348 "^push":
4367 "^push":
4349 (push,
4368 (push,
4350 [('f', 'force', None, _('force push')),
4369 [('f', 'force', None, _('force push')),
4351 ('r', 'rev', [],
4370 ('r', 'rev', [],
4352 _('a changeset intended to be included in the destination'),
4371 _('a changeset intended to be included in the destination'),
4353 _('REV')),
4372 _('REV')),
4354 ('b', 'branch', [],
4373 ('b', 'branch', [],
4355 _('a specific branch you would like to push'), _('BRANCH')),
4374 _('a specific branch you would like to push'), _('BRANCH')),
4356 ('', 'new-branch', False, _('allow pushing a new branch')),
4375 ('', 'new-branch', False, _('allow pushing a new branch')),
4357 ] + remoteopts,
4376 ] + remoteopts,
4358 _('[-f] [-r REV]... [-e CMD] [--remotecmd CMD] [DEST]')),
4377 _('[-f] [-r REV]... [-e CMD] [--remotecmd CMD] [DEST]')),
4359 "recover": (recover, []),
4378 "recover": (recover, []),
4360 "^remove|rm":
4379 "^remove|rm":
4361 (remove,
4380 (remove,
4362 [('A', 'after', None, _('record delete for missing files')),
4381 [('A', 'after', None, _('record delete for missing files')),
4363 ('f', 'force', None,
4382 ('f', 'force', None,
4364 _('remove (and delete) file even if added or modified')),
4383 _('remove (and delete) file even if added or modified')),
4365 ] + walkopts,
4384 ] + walkopts,
4366 _('[OPTION]... FILE...')),
4385 _('[OPTION]... FILE...')),
4367 "rename|move|mv":
4386 "rename|move|mv":
4368 (rename,
4387 (rename,
4369 [('A', 'after', None, _('record a rename that has already occurred')),
4388 [('A', 'after', None, _('record a rename that has already occurred')),
4370 ('f', 'force', None,
4389 ('f', 'force', None,
4371 _('forcibly copy over an existing managed file')),
4390 _('forcibly copy over an existing managed file')),
4372 ] + walkopts + dryrunopts,
4391 ] + walkopts + dryrunopts,
4373 _('[OPTION]... SOURCE... DEST')),
4392 _('[OPTION]... SOURCE... DEST')),
4374 "resolve":
4393 "resolve":
4375 (resolve,
4394 (resolve,
4376 [('a', 'all', None, _('select all unresolved files')),
4395 [('a', 'all', None, _('select all unresolved files')),
4377 ('l', 'list', None, _('list state of files needing merge')),
4396 ('l', 'list', None, _('list state of files needing merge')),
4378 ('m', 'mark', None, _('mark files as resolved')),
4397 ('m', 'mark', None, _('mark files as resolved')),
4379 ('u', 'unmark', None, _('mark files as unresolved')),
4398 ('u', 'unmark', None, _('mark files as unresolved')),
4380 ('t', 'tool', '', _('specify merge tool')),
4399 ('t', 'tool', '', _('specify merge tool')),
4381 ('n', 'no-status', None, _('hide status prefix'))]
4400 ('n', 'no-status', None, _('hide status prefix'))]
4382 + walkopts,
4401 + walkopts,
4383 _('[OPTION]... [FILE]...')),
4402 _('[OPTION]... [FILE]...')),
4384 "revert":
4403 "revert":
4385 (revert,
4404 (revert,
4386 [('a', 'all', None, _('revert all changes when no arguments given')),
4405 [('a', 'all', None, _('revert all changes when no arguments given')),
4387 ('d', 'date', '',
4406 ('d', 'date', '',
4388 _('tipmost revision matching date'), _('DATE')),
4407 _('tipmost revision matching date'), _('DATE')),
4389 ('r', 'rev', '',
4408 ('r', 'rev', '',
4390 _('revert to the specified revision'), _('REV')),
4409 _('revert to the specified revision'), _('REV')),
4391 ('', 'no-backup', None, _('do not save backup copies of files')),
4410 ('', 'no-backup', None, _('do not save backup copies of files')),
4392 ] + walkopts + dryrunopts,
4411 ] + walkopts + dryrunopts,
4393 _('[OPTION]... [-r REV] [NAME]...')),
4412 _('[OPTION]... [-r REV] [NAME]...')),
4394 "rollback": (rollback, dryrunopts),
4413 "rollback": (rollback, dryrunopts),
4395 "root": (root, []),
4414 "root": (root, []),
4396 "^serve":
4415 "^serve":
4397 (serve,
4416 (serve,
4398 [('A', 'accesslog', '',
4417 [('A', 'accesslog', '',
4399 _('name of access log file to write to'), _('FILE')),
4418 _('name of access log file to write to'), _('FILE')),
4400 ('d', 'daemon', None, _('run server in background')),
4419 ('d', 'daemon', None, _('run server in background')),
4401 ('', 'daemon-pipefds', '',
4420 ('', 'daemon-pipefds', '',
4402 _('used internally by daemon mode'), _('NUM')),
4421 _('used internally by daemon mode'), _('NUM')),
4403 ('E', 'errorlog', '',
4422 ('E', 'errorlog', '',
4404 _('name of error log file to write to'), _('FILE')),
4423 _('name of error log file to write to'), _('FILE')),
4405 # use string type, then we can check if something was passed
4424 # use string type, then we can check if something was passed
4406 ('p', 'port', '',
4425 ('p', 'port', '',
4407 _('port to listen on (default: 8000)'), _('PORT')),
4426 _('port to listen on (default: 8000)'), _('PORT')),
4408 ('a', 'address', '',
4427 ('a', 'address', '',
4409 _('address to listen on (default: all interfaces)'), _('ADDR')),
4428 _('address to listen on (default: all interfaces)'), _('ADDR')),
4410 ('', 'prefix', '',
4429 ('', 'prefix', '',
4411 _('prefix path to serve from (default: server root)'), _('PREFIX')),
4430 _('prefix path to serve from (default: server root)'), _('PREFIX')),
4412 ('n', 'name', '',
4431 ('n', 'name', '',
4413 _('name to show in web pages (default: working directory)'),
4432 _('name to show in web pages (default: working directory)'),
4414 _('NAME')),
4433 _('NAME')),
4415 ('', 'web-conf', '',
4434 ('', 'web-conf', '',
4416 _('name of the hgweb config file (see "hg help hgweb")'),
4435 _('name of the hgweb config file (see "hg help hgweb")'),
4417 _('FILE')),
4436 _('FILE')),
4418 ('', 'webdir-conf', '',
4437 ('', 'webdir-conf', '',
4419 _('name of the hgweb config file (DEPRECATED)'), _('FILE')),
4438 _('name of the hgweb config file (DEPRECATED)'), _('FILE')),
4420 ('', 'pid-file', '',
4439 ('', 'pid-file', '',
4421 _('name of file to write process ID to'), _('FILE')),
4440 _('name of file to write process ID to'), _('FILE')),
4422 ('', 'stdio', None, _('for remote clients')),
4441 ('', 'stdio', None, _('for remote clients')),
4423 ('t', 'templates', '',
4442 ('t', 'templates', '',
4424 _('web templates to use'), _('TEMPLATE')),
4443 _('web templates to use'), _('TEMPLATE')),
4425 ('', 'style', '',
4444 ('', 'style', '',
4426 _('template style to use'), _('STYLE')),
4445 _('template style to use'), _('STYLE')),
4427 ('6', 'ipv6', None, _('use IPv6 in addition to IPv4')),
4446 ('6', 'ipv6', None, _('use IPv6 in addition to IPv4')),
4428 ('', 'certificate', '',
4447 ('', 'certificate', '',
4429 _('SSL certificate file'), _('FILE'))],
4448 _('SSL certificate file'), _('FILE'))],
4430 _('[OPTION]...')),
4449 _('[OPTION]...')),
4431 "showconfig|debugconfig":
4450 "showconfig|debugconfig":
4432 (showconfig,
4451 (showconfig,
4433 [('u', 'untrusted', None, _('show untrusted configuration options'))],
4452 [('u', 'untrusted', None, _('show untrusted configuration options'))],
4434 _('[-u] [NAME]...')),
4453 _('[-u] [NAME]...')),
4435 "^summary|sum":
4454 "^summary|sum":
4436 (summary,
4455 (summary,
4437 [('', 'remote', None, _('check for push and pull'))], '[--remote]'),
4456 [('', 'remote', None, _('check for push and pull'))], '[--remote]'),
4438 "^status|st":
4457 "^status|st":
4439 (status,
4458 (status,
4440 [('A', 'all', None, _('show status of all files')),
4459 [('A', 'all', None, _('show status of all files')),
4441 ('m', 'modified', None, _('show only modified files')),
4460 ('m', 'modified', None, _('show only modified files')),
4442 ('a', 'added', None, _('show only added files')),
4461 ('a', 'added', None, _('show only added files')),
4443 ('r', 'removed', None, _('show only removed files')),
4462 ('r', 'removed', None, _('show only removed files')),
4444 ('d', 'deleted', None, _('show only deleted (but tracked) files')),
4463 ('d', 'deleted', None, _('show only deleted (but tracked) files')),
4445 ('c', 'clean', None, _('show only files without changes')),
4464 ('c', 'clean', None, _('show only files without changes')),
4446 ('u', 'unknown', None, _('show only unknown (not tracked) files')),
4465 ('u', 'unknown', None, _('show only unknown (not tracked) files')),
4447 ('i', 'ignored', None, _('show only ignored files')),
4466 ('i', 'ignored', None, _('show only ignored files')),
4448 ('n', 'no-status', None, _('hide status prefix')),
4467 ('n', 'no-status', None, _('hide status prefix')),
4449 ('C', 'copies', None, _('show source of copied files')),
4468 ('C', 'copies', None, _('show source of copied files')),
4450 ('0', 'print0', None,
4469 ('0', 'print0', None,
4451 _('end filenames with NUL, for use with xargs')),
4470 _('end filenames with NUL, for use with xargs')),
4452 ('', 'rev', [],
4471 ('', 'rev', [],
4453 _('show difference from revision'), _('REV')),
4472 _('show difference from revision'), _('REV')),
4454 ('', 'change', '',
4473 ('', 'change', '',
4455 _('list the changed files of a revision'), _('REV')),
4474 _('list the changed files of a revision'), _('REV')),
4456 ] + walkopts + subrepoopts,
4475 ] + walkopts + subrepoopts,
4457 _('[OPTION]... [FILE]...')),
4476 _('[OPTION]... [FILE]...')),
4458 "tag":
4477 "tag":
4459 (tag,
4478 (tag,
4460 [('f', 'force', None, _('replace existing tag')),
4479 [('f', 'force', None, _('replace existing tag')),
4461 ('l', 'local', None, _('make the tag local')),
4480 ('l', 'local', None, _('make the tag local')),
4462 ('r', 'rev', '',
4481 ('r', 'rev', '',
4463 _('revision to tag'), _('REV')),
4482 _('revision to tag'), _('REV')),
4464 ('', 'remove', None, _('remove a tag')),
4483 ('', 'remove', None, _('remove a tag')),
4465 # -l/--local is already there, commitopts cannot be used
4484 # -l/--local is already there, commitopts cannot be used
4466 ('e', 'edit', None, _('edit commit message')),
4485 ('e', 'edit', None, _('edit commit message')),
4467 ('m', 'message', '',
4486 ('m', 'message', '',
4468 _('use <text> as commit message'), _('TEXT')),
4487 _('use <text> as commit message'), _('TEXT')),
4469 ] + commitopts2,
4488 ] + commitopts2,
4470 _('[-f] [-l] [-m TEXT] [-d DATE] [-u USER] [-r REV] NAME...')),
4489 _('[-f] [-l] [-m TEXT] [-d DATE] [-u USER] [-r REV] NAME...')),
4471 "tags": (tags, [], ''),
4490 "tags": (tags, [], ''),
4472 "tip":
4491 "tip":
4473 (tip,
4492 (tip,
4474 [('p', 'patch', None, _('show patch')),
4493 [('p', 'patch', None, _('show patch')),
4475 ('g', 'git', None, _('use git extended diff format')),
4494 ('g', 'git', None, _('use git extended diff format')),
4476 ] + templateopts,
4495 ] + templateopts,
4477 _('[-p] [-g]')),
4496 _('[-p] [-g]')),
4478 "unbundle":
4497 "unbundle":
4479 (unbundle,
4498 (unbundle,
4480 [('u', 'update', None,
4499 [('u', 'update', None,
4481 _('update to new branch head if changesets were unbundled'))],
4500 _('update to new branch head if changesets were unbundled'))],
4482 _('[-u] FILE...')),
4501 _('[-u] FILE...')),
4483 "^update|up|checkout|co":
4502 "^update|up|checkout|co":
4484 (update,
4503 (update,
4485 [('C', 'clean', None, _('discard uncommitted changes (no backup)')),
4504 [('C', 'clean', None, _('discard uncommitted changes (no backup)')),
4486 ('c', 'check', None,
4505 ('c', 'check', None,
4487 _('update across branches if no uncommitted changes')),
4506 _('update across branches if no uncommitted changes')),
4488 ('d', 'date', '',
4507 ('d', 'date', '',
4489 _('tipmost revision matching date'), _('DATE')),
4508 _('tipmost revision matching date'), _('DATE')),
4490 ('r', 'rev', '',
4509 ('r', 'rev', '',
4491 _('revision'), _('REV'))],
4510 _('revision'), _('REV'))],
4492 _('[-c] [-C] [-d DATE] [[-r] REV]')),
4511 _('[-c] [-C] [-d DATE] [[-r] REV]')),
4493 "verify": (verify, []),
4512 "verify": (verify, []),
4494 "version": (version_, []),
4513 "version": (version_, []),
4495 }
4514 }
4496
4515
4497 norepo = ("clone init version help debugcommands debugcomplete"
4516 norepo = ("clone init version help debugcommands debugcomplete"
4498 " debugdate debuginstall debugfsinfo debugpushkey")
4517 " debugdate debuginstall debugfsinfo debugpushkey")
4499 optionalrepo = ("identify paths serve showconfig debugancestor debugdag"
4518 optionalrepo = ("identify paths serve showconfig debugancestor debugdag"
4500 " debugdata debugindex debugindexdot")
4519 " debugdata debugindex debugindexdot")
@@ -1,220 +1,220
1 $ hg init test
1 $ hg init test
2 $ cd test
2 $ cd test
3
3
4 $ echo 0 >> afile
4 $ echo 0 >> afile
5 $ hg add afile
5 $ hg add afile
6 $ hg commit -m "0.0"
6 $ hg commit -m "0.0"
7
7
8 $ echo 1 >> afile
8 $ echo 1 >> afile
9 $ hg commit -m "0.1"
9 $ hg commit -m "0.1"
10
10
11 $ echo 2 >> afile
11 $ echo 2 >> afile
12 $ hg commit -m "0.2"
12 $ hg commit -m "0.2"
13
13
14 $ echo 3 >> afile
14 $ echo 3 >> afile
15 $ hg commit -m "0.3"
15 $ hg commit -m "0.3"
16
16
17 $ hg update -C 0
17 $ hg update -C 0
18 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
18 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
19
19
20 $ echo 1 >> afile
20 $ echo 1 >> afile
21 $ hg commit -m "1.1"
21 $ hg commit -m "1.1"
22 created new head
22 created new head
23
23
24 $ echo 2 >> afile
24 $ echo 2 >> afile
25 $ hg commit -m "1.2"
25 $ hg commit -m "1.2"
26
26
27 $ echo a line > fred
27 $ echo a line > fred
28 $ echo 3 >> afile
28 $ echo 3 >> afile
29 $ hg add fred
29 $ hg add fred
30 $ hg commit -m "1.3"
30 $ hg commit -m "1.3"
31 $ hg mv afile adifferentfile
31 $ hg mv afile adifferentfile
32 $ hg commit -m "1.3m"
32 $ hg commit -m "1.3m"
33
33
34 $ hg update -C 3
34 $ hg update -C 3
35 1 files updated, 0 files merged, 2 files removed, 0 files unresolved
35 1 files updated, 0 files merged, 2 files removed, 0 files unresolved
36
36
37 $ hg mv afile anotherfile
37 $ hg mv afile anotherfile
38 $ hg commit -m "0.3m"
38 $ hg commit -m "0.3m"
39
39
40 $ hg debugindex .hg/store/data/afile.i
40 $ hg debugindex -f 1 .hg/store/data/afile.i
41 rev offset length base linkrev nodeid p1 p2
41 rev flag offset length size base link p1 p2 nodeid
42 0 0 3 0 0 362fef284ce2 000000000000 000000000000
42 0 0000 0 3 2 0 0 -1 -1 362fef284ce2
43 1 3 5 1 1 125144f7e028 362fef284ce2 000000000000
43 1 0000 3 5 4 1 1 0 -1 125144f7e028
44 2 8 7 2 2 4c982badb186 125144f7e028 000000000000
44 2 0000 8 7 6 2 2 1 -1 4c982badb186
45 3 15 9 3 3 19b1fc555737 4c982badb186 000000000000
45 3 0000 15 9 8 3 3 2 -1 19b1fc555737
46
46
47 $ hg debugindex .hg/store/data/adifferentfile.i
47 $ hg debugindex .hg/store/data/adifferentfile.i
48 rev offset length base linkrev nodeid p1 p2
48 rev offset length base linkrev nodeid p1 p2
49 0 0 75 0 7 2565f3199a74 000000000000 000000000000
49 0 0 75 0 7 2565f3199a74 000000000000 000000000000
50
50
51 $ hg debugindex .hg/store/data/anotherfile.i
51 $ hg debugindex .hg/store/data/anotherfile.i
52 rev offset length base linkrev nodeid p1 p2
52 rev offset length base linkrev nodeid p1 p2
53 0 0 75 0 8 2565f3199a74 000000000000 000000000000
53 0 0 75 0 8 2565f3199a74 000000000000 000000000000
54
54
55 $ hg debugindex .hg/store/data/fred.i
55 $ hg debugindex .hg/store/data/fred.i
56 rev offset length base linkrev nodeid p1 p2
56 rev offset length base linkrev nodeid p1 p2
57 0 0 8 0 6 12ab3bcc5ea4 000000000000 000000000000
57 0 0 8 0 6 12ab3bcc5ea4 000000000000 000000000000
58
58
59 $ hg debugindex .hg/store/00manifest.i
59 $ hg debugindex .hg/store/00manifest.i
60 rev offset length base linkrev nodeid p1 p2
60 rev offset length base linkrev nodeid p1 p2
61 0 0 48 0 0 43eadb1d2d06 000000000000 000000000000
61 0 0 48 0 0 43eadb1d2d06 000000000000 000000000000
62 1 48 48 1 1 8b89697eba2c 43eadb1d2d06 000000000000
62 1 48 48 1 1 8b89697eba2c 43eadb1d2d06 000000000000
63 2 96 48 2 2 626a32663c2f 8b89697eba2c 000000000000
63 2 96 48 2 2 626a32663c2f 8b89697eba2c 000000000000
64 3 144 48 3 3 f54c32f13478 626a32663c2f 000000000000
64 3 144 48 3 3 f54c32f13478 626a32663c2f 000000000000
65 4 192 58 3 6 de68e904d169 626a32663c2f 000000000000
65 4 192 58 3 6 de68e904d169 626a32663c2f 000000000000
66 5 250 68 3 7 09bb521d218d de68e904d169 000000000000
66 5 250 68 3 7 09bb521d218d de68e904d169 000000000000
67 6 318 54 6 8 1fde233dfb0f f54c32f13478 000000000000
67 6 318 54 6 8 1fde233dfb0f f54c32f13478 000000000000
68
68
69 $ hg verify
69 $ hg verify
70 checking changesets
70 checking changesets
71 checking manifests
71 checking manifests
72 crosschecking files in changesets and manifests
72 crosschecking files in changesets and manifests
73 checking files
73 checking files
74 4 files, 9 changesets, 7 total revisions
74 4 files, 9 changesets, 7 total revisions
75
75
76 $ cd ..
76 $ cd ..
77
77
78 $ for i in 0 1 2 3 4 5 6 7 8; do
78 $ for i in 0 1 2 3 4 5 6 7 8; do
79 > echo
79 > echo
80 > echo ---- hg clone -r "$i" test test-"$i"
80 > echo ---- hg clone -r "$i" test test-"$i"
81 > hg clone -r "$i" test test-"$i"
81 > hg clone -r "$i" test test-"$i"
82 > cd test-"$i"
82 > cd test-"$i"
83 > hg verify
83 > hg verify
84 > cd ..
84 > cd ..
85 > done
85 > done
86
86
87 ---- hg clone -r 0 test test-0
87 ---- hg clone -r 0 test test-0
88 adding changesets
88 adding changesets
89 adding manifests
89 adding manifests
90 adding file changes
90 adding file changes
91 added 1 changesets with 1 changes to 1 files
91 added 1 changesets with 1 changes to 1 files
92 updating to branch default
92 updating to branch default
93 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
93 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
94 checking changesets
94 checking changesets
95 checking manifests
95 checking manifests
96 crosschecking files in changesets and manifests
96 crosschecking files in changesets and manifests
97 checking files
97 checking files
98 1 files, 1 changesets, 1 total revisions
98 1 files, 1 changesets, 1 total revisions
99
99
100 ---- hg clone -r 1 test test-1
100 ---- hg clone -r 1 test test-1
101 adding changesets
101 adding changesets
102 adding manifests
102 adding manifests
103 adding file changes
103 adding file changes
104 added 2 changesets with 2 changes to 1 files
104 added 2 changesets with 2 changes to 1 files
105 updating to branch default
105 updating to branch default
106 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
106 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
107 checking changesets
107 checking changesets
108 checking manifests
108 checking manifests
109 crosschecking files in changesets and manifests
109 crosschecking files in changesets and manifests
110 checking files
110 checking files
111 1 files, 2 changesets, 2 total revisions
111 1 files, 2 changesets, 2 total revisions
112
112
113 ---- hg clone -r 2 test test-2
113 ---- hg clone -r 2 test test-2
114 adding changesets
114 adding changesets
115 adding manifests
115 adding manifests
116 adding file changes
116 adding file changes
117 added 3 changesets with 3 changes to 1 files
117 added 3 changesets with 3 changes to 1 files
118 updating to branch default
118 updating to branch default
119 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
119 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
120 checking changesets
120 checking changesets
121 checking manifests
121 checking manifests
122 crosschecking files in changesets and manifests
122 crosschecking files in changesets and manifests
123 checking files
123 checking files
124 1 files, 3 changesets, 3 total revisions
124 1 files, 3 changesets, 3 total revisions
125
125
126 ---- hg clone -r 3 test test-3
126 ---- hg clone -r 3 test test-3
127 adding changesets
127 adding changesets
128 adding manifests
128 adding manifests
129 adding file changes
129 adding file changes
130 added 4 changesets with 4 changes to 1 files
130 added 4 changesets with 4 changes to 1 files
131 updating to branch default
131 updating to branch default
132 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
132 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
133 checking changesets
133 checking changesets
134 checking manifests
134 checking manifests
135 crosschecking files in changesets and manifests
135 crosschecking files in changesets and manifests
136 checking files
136 checking files
137 1 files, 4 changesets, 4 total revisions
137 1 files, 4 changesets, 4 total revisions
138
138
139 ---- hg clone -r 4 test test-4
139 ---- hg clone -r 4 test test-4
140 adding changesets
140 adding changesets
141 adding manifests
141 adding manifests
142 adding file changes
142 adding file changes
143 added 2 changesets with 2 changes to 1 files
143 added 2 changesets with 2 changes to 1 files
144 updating to branch default
144 updating to branch default
145 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
145 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
146 checking changesets
146 checking changesets
147 checking manifests
147 checking manifests
148 crosschecking files in changesets and manifests
148 crosschecking files in changesets and manifests
149 checking files
149 checking files
150 1 files, 2 changesets, 2 total revisions
150 1 files, 2 changesets, 2 total revisions
151
151
152 ---- hg clone -r 5 test test-5
152 ---- hg clone -r 5 test test-5
153 adding changesets
153 adding changesets
154 adding manifests
154 adding manifests
155 adding file changes
155 adding file changes
156 added 3 changesets with 3 changes to 1 files
156 added 3 changesets with 3 changes to 1 files
157 updating to branch default
157 updating to branch default
158 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
158 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
159 checking changesets
159 checking changesets
160 checking manifests
160 checking manifests
161 crosschecking files in changesets and manifests
161 crosschecking files in changesets and manifests
162 checking files
162 checking files
163 1 files, 3 changesets, 3 total revisions
163 1 files, 3 changesets, 3 total revisions
164
164
165 ---- hg clone -r 6 test test-6
165 ---- hg clone -r 6 test test-6
166 adding changesets
166 adding changesets
167 adding manifests
167 adding manifests
168 adding file changes
168 adding file changes
169 added 4 changesets with 5 changes to 2 files
169 added 4 changesets with 5 changes to 2 files
170 updating to branch default
170 updating to branch default
171 2 files updated, 0 files merged, 0 files removed, 0 files unresolved
171 2 files updated, 0 files merged, 0 files removed, 0 files unresolved
172 checking changesets
172 checking changesets
173 checking manifests
173 checking manifests
174 crosschecking files in changesets and manifests
174 crosschecking files in changesets and manifests
175 checking files
175 checking files
176 2 files, 4 changesets, 5 total revisions
176 2 files, 4 changesets, 5 total revisions
177
177
178 ---- hg clone -r 7 test test-7
178 ---- hg clone -r 7 test test-7
179 adding changesets
179 adding changesets
180 adding manifests
180 adding manifests
181 adding file changes
181 adding file changes
182 added 5 changesets with 6 changes to 3 files
182 added 5 changesets with 6 changes to 3 files
183 updating to branch default
183 updating to branch default
184 2 files updated, 0 files merged, 0 files removed, 0 files unresolved
184 2 files updated, 0 files merged, 0 files removed, 0 files unresolved
185 checking changesets
185 checking changesets
186 checking manifests
186 checking manifests
187 crosschecking files in changesets and manifests
187 crosschecking files in changesets and manifests
188 checking files
188 checking files
189 3 files, 5 changesets, 6 total revisions
189 3 files, 5 changesets, 6 total revisions
190
190
191 ---- hg clone -r 8 test test-8
191 ---- hg clone -r 8 test test-8
192 adding changesets
192 adding changesets
193 adding manifests
193 adding manifests
194 adding file changes
194 adding file changes
195 added 5 changesets with 5 changes to 2 files
195 added 5 changesets with 5 changes to 2 files
196 updating to branch default
196 updating to branch default
197 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
197 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
198 checking changesets
198 checking changesets
199 checking manifests
199 checking manifests
200 crosschecking files in changesets and manifests
200 crosschecking files in changesets and manifests
201 checking files
201 checking files
202 2 files, 5 changesets, 5 total revisions
202 2 files, 5 changesets, 5 total revisions
203
203
204 $ cd test-8
204 $ cd test-8
205 $ hg pull ../test-7
205 $ hg pull ../test-7
206 pulling from ../test-7
206 pulling from ../test-7
207 searching for changes
207 searching for changes
208 adding changesets
208 adding changesets
209 adding manifests
209 adding manifests
210 adding file changes
210 adding file changes
211 added 4 changesets with 2 changes to 3 files (+1 heads)
211 added 4 changesets with 2 changes to 3 files (+1 heads)
212 (run 'hg heads' to see heads, 'hg merge' to merge)
212 (run 'hg heads' to see heads, 'hg merge' to merge)
213 $ hg verify
213 $ hg verify
214 checking changesets
214 checking changesets
215 checking manifests
215 checking manifests
216 crosschecking files in changesets and manifests
216 crosschecking files in changesets and manifests
217 checking files
217 checking files
218 4 files, 9 changesets, 7 total revisions
218 4 files, 9 changesets, 7 total revisions
219 $ cd ..
219 $ cd ..
220
220
@@ -1,249 +1,249
1 Show all commands except debug commands
1 Show all commands except debug commands
2 $ hg debugcomplete
2 $ hg debugcomplete
3 add
3 add
4 addremove
4 addremove
5 annotate
5 annotate
6 archive
6 archive
7 backout
7 backout
8 bisect
8 bisect
9 branch
9 branch
10 branches
10 branches
11 bundle
11 bundle
12 cat
12 cat
13 clone
13 clone
14 commit
14 commit
15 copy
15 copy
16 diff
16 diff
17 export
17 export
18 forget
18 forget
19 grep
19 grep
20 heads
20 heads
21 help
21 help
22 identify
22 identify
23 import
23 import
24 incoming
24 incoming
25 init
25 init
26 locate
26 locate
27 log
27 log
28 manifest
28 manifest
29 merge
29 merge
30 outgoing
30 outgoing
31 parents
31 parents
32 paths
32 paths
33 pull
33 pull
34 push
34 push
35 recover
35 recover
36 remove
36 remove
37 rename
37 rename
38 resolve
38 resolve
39 revert
39 revert
40 rollback
40 rollback
41 root
41 root
42 serve
42 serve
43 showconfig
43 showconfig
44 status
44 status
45 summary
45 summary
46 tag
46 tag
47 tags
47 tags
48 tip
48 tip
49 unbundle
49 unbundle
50 update
50 update
51 verify
51 verify
52 version
52 version
53
53
54 Show all commands that start with "a"
54 Show all commands that start with "a"
55 $ hg debugcomplete a
55 $ hg debugcomplete a
56 add
56 add
57 addremove
57 addremove
58 annotate
58 annotate
59 archive
59 archive
60
60
61 Do not show debug commands if there are other candidates
61 Do not show debug commands if there are other candidates
62 $ hg debugcomplete d
62 $ hg debugcomplete d
63 diff
63 diff
64
64
65 Show debug commands if there are no other candidates
65 Show debug commands if there are no other candidates
66 $ hg debugcomplete debug
66 $ hg debugcomplete debug
67 debugancestor
67 debugancestor
68 debugbuilddag
68 debugbuilddag
69 debugcheckstate
69 debugcheckstate
70 debugcommands
70 debugcommands
71 debugcomplete
71 debugcomplete
72 debugconfig
72 debugconfig
73 debugdag
73 debugdag
74 debugdata
74 debugdata
75 debugdate
75 debugdate
76 debugfsinfo
76 debugfsinfo
77 debugindex
77 debugindex
78 debugindexdot
78 debugindexdot
79 debuginstall
79 debuginstall
80 debugpushkey
80 debugpushkey
81 debugrebuildstate
81 debugrebuildstate
82 debugrename
82 debugrename
83 debugrevspec
83 debugrevspec
84 debugsetparents
84 debugsetparents
85 debugstate
85 debugstate
86 debugsub
86 debugsub
87 debugwalk
87 debugwalk
88
88
89 Do not show the alias of a debug command if there are other candidates
89 Do not show the alias of a debug command if there are other candidates
90 (this should hide rawcommit)
90 (this should hide rawcommit)
91 $ hg debugcomplete r
91 $ hg debugcomplete r
92 recover
92 recover
93 remove
93 remove
94 rename
94 rename
95 resolve
95 resolve
96 revert
96 revert
97 rollback
97 rollback
98 root
98 root
99 Show the alias of a debug command if there are no other candidates
99 Show the alias of a debug command if there are no other candidates
100 $ hg debugcomplete rawc
100 $ hg debugcomplete rawc
101
101
102
102
103 Show the global options
103 Show the global options
104 $ hg debugcomplete --options | sort
104 $ hg debugcomplete --options | sort
105 --config
105 --config
106 --cwd
106 --cwd
107 --debug
107 --debug
108 --debugger
108 --debugger
109 --encoding
109 --encoding
110 --encodingmode
110 --encodingmode
111 --help
111 --help
112 --noninteractive
112 --noninteractive
113 --profile
113 --profile
114 --quiet
114 --quiet
115 --repository
115 --repository
116 --time
116 --time
117 --traceback
117 --traceback
118 --verbose
118 --verbose
119 --version
119 --version
120 -R
120 -R
121 -h
121 -h
122 -q
122 -q
123 -v
123 -v
124 -y
124 -y
125
125
126 Show the options for the "serve" command
126 Show the options for the "serve" command
127 $ hg debugcomplete --options serve | sort
127 $ hg debugcomplete --options serve | sort
128 --accesslog
128 --accesslog
129 --address
129 --address
130 --certificate
130 --certificate
131 --config
131 --config
132 --cwd
132 --cwd
133 --daemon
133 --daemon
134 --daemon-pipefds
134 --daemon-pipefds
135 --debug
135 --debug
136 --debugger
136 --debugger
137 --encoding
137 --encoding
138 --encodingmode
138 --encodingmode
139 --errorlog
139 --errorlog
140 --help
140 --help
141 --ipv6
141 --ipv6
142 --name
142 --name
143 --noninteractive
143 --noninteractive
144 --pid-file
144 --pid-file
145 --port
145 --port
146 --prefix
146 --prefix
147 --profile
147 --profile
148 --quiet
148 --quiet
149 --repository
149 --repository
150 --stdio
150 --stdio
151 --style
151 --style
152 --templates
152 --templates
153 --time
153 --time
154 --traceback
154 --traceback
155 --verbose
155 --verbose
156 --version
156 --version
157 --web-conf
157 --web-conf
158 -6
158 -6
159 -A
159 -A
160 -E
160 -E
161 -R
161 -R
162 -a
162 -a
163 -d
163 -d
164 -h
164 -h
165 -n
165 -n
166 -p
166 -p
167 -q
167 -q
168 -t
168 -t
169 -v
169 -v
170 -y
170 -y
171
171
172 Show an error if we use --options with an ambiguous abbreviation
172 Show an error if we use --options with an ambiguous abbreviation
173 $ hg debugcomplete --options s
173 $ hg debugcomplete --options s
174 hg: command 's' is ambiguous:
174 hg: command 's' is ambiguous:
175 serve showconfig status summary
175 serve showconfig status summary
176 [255]
176 [255]
177
177
178 Show all commands + options
178 Show all commands + options
179 $ hg debugcommands
179 $ hg debugcommands
180 add: include, exclude, subrepos, dry-run
180 add: include, exclude, subrepos, dry-run
181 annotate: rev, follow, no-follow, text, user, file, date, number, changeset, line-number, include, exclude
181 annotate: rev, follow, no-follow, text, user, file, date, number, changeset, line-number, include, exclude
182 clone: noupdate, updaterev, rev, branch, pull, uncompressed, ssh, remotecmd
182 clone: noupdate, updaterev, rev, branch, pull, uncompressed, ssh, remotecmd
183 commit: addremove, close-branch, include, exclude, message, logfile, date, user
183 commit: addremove, close-branch, include, exclude, message, logfile, date, user
184 diff: rev, change, text, git, nodates, show-function, reverse, ignore-all-space, ignore-space-change, ignore-blank-lines, unified, stat, include, exclude, subrepos
184 diff: rev, change, text, git, nodates, show-function, reverse, ignore-all-space, ignore-space-change, ignore-blank-lines, unified, stat, include, exclude, subrepos
185 export: output, switch-parent, rev, text, git, nodates
185 export: output, switch-parent, rev, text, git, nodates
186 forget: include, exclude
186 forget: include, exclude
187 init: ssh, remotecmd
187 init: ssh, remotecmd
188 log: follow, follow-first, date, copies, keyword, rev, removed, only-merges, user, only-branch, branch, prune, patch, git, limit, no-merges, stat, style, template, include, exclude
188 log: follow, follow-first, date, copies, keyword, rev, removed, only-merges, user, only-branch, branch, prune, patch, git, limit, no-merges, stat, style, template, include, exclude
189 merge: force, tool, rev, preview
189 merge: force, tool, rev, preview
190 pull: update, force, rev, branch, ssh, remotecmd
190 pull: update, force, rev, branch, ssh, remotecmd
191 push: force, rev, branch, new-branch, ssh, remotecmd
191 push: force, rev, branch, new-branch, ssh, remotecmd
192 remove: after, force, include, exclude
192 remove: after, force, include, exclude
193 serve: accesslog, daemon, daemon-pipefds, errorlog, port, address, prefix, name, web-conf, webdir-conf, pid-file, stdio, templates, style, ipv6, certificate
193 serve: accesslog, daemon, daemon-pipefds, errorlog, port, address, prefix, name, web-conf, webdir-conf, pid-file, stdio, templates, style, ipv6, certificate
194 status: all, modified, added, removed, deleted, clean, unknown, ignored, no-status, copies, print0, rev, change, include, exclude, subrepos
194 status: all, modified, added, removed, deleted, clean, unknown, ignored, no-status, copies, print0, rev, change, include, exclude, subrepos
195 summary: remote
195 summary: remote
196 update: clean, check, date, rev
196 update: clean, check, date, rev
197 addremove: similarity, include, exclude, dry-run
197 addremove: similarity, include, exclude, dry-run
198 archive: no-decode, prefix, rev, type, subrepos, include, exclude
198 archive: no-decode, prefix, rev, type, subrepos, include, exclude
199 backout: merge, parent, tool, rev, include, exclude, message, logfile, date, user
199 backout: merge, parent, tool, rev, include, exclude, message, logfile, date, user
200 bisect: reset, good, bad, skip, command, noupdate
200 bisect: reset, good, bad, skip, command, noupdate
201 branch: force, clean
201 branch: force, clean
202 branches: active, closed
202 branches: active, closed
203 bundle: force, rev, branch, base, all, type, ssh, remotecmd
203 bundle: force, rev, branch, base, all, type, ssh, remotecmd
204 cat: output, rev, decode, include, exclude
204 cat: output, rev, decode, include, exclude
205 copy: after, force, include, exclude, dry-run
205 copy: after, force, include, exclude, dry-run
206 debugancestor:
206 debugancestor:
207 debugbuilddag: mergeable-file, appended-file, overwritten-file, new-file
207 debugbuilddag: mergeable-file, appended-file, overwritten-file, new-file
208 debugcheckstate:
208 debugcheckstate:
209 debugcommands:
209 debugcommands:
210 debugcomplete: options
210 debugcomplete: options
211 debugdag: tags, branches, dots, spaces
211 debugdag: tags, branches, dots, spaces
212 debugdata:
212 debugdata:
213 debugdate: extended
213 debugdate: extended
214 debugfsinfo:
214 debugfsinfo:
215 debugindex:
215 debugindex: format
216 debugindexdot:
216 debugindexdot:
217 debuginstall:
217 debuginstall:
218 debugpushkey:
218 debugpushkey:
219 debugrebuildstate: rev
219 debugrebuildstate: rev
220 debugrename: rev
220 debugrename: rev
221 debugrevspec:
221 debugrevspec:
222 debugsetparents:
222 debugsetparents:
223 debugstate: nodates
223 debugstate: nodates
224 debugsub: rev
224 debugsub: rev
225 debugwalk: include, exclude
225 debugwalk: include, exclude
226 grep: print0, all, follow, ignore-case, files-with-matches, line-number, rev, user, date, include, exclude
226 grep: print0, all, follow, ignore-case, files-with-matches, line-number, rev, user, date, include, exclude
227 heads: rev, topo, active, closed, style, template
227 heads: rev, topo, active, closed, style, template
228 help:
228 help:
229 identify: rev, num, id, branch, tags
229 identify: rev, num, id, branch, tags
230 import: strip, base, force, no-commit, exact, import-branch, message, logfile, date, user, similarity
230 import: strip, base, force, no-commit, exact, import-branch, message, logfile, date, user, similarity
231 incoming: force, newest-first, bundle, rev, branch, patch, git, limit, no-merges, stat, style, template, ssh, remotecmd, subrepos
231 incoming: force, newest-first, bundle, rev, branch, patch, git, limit, no-merges, stat, style, template, ssh, remotecmd, subrepos
232 locate: rev, print0, fullpath, include, exclude
232 locate: rev, print0, fullpath, include, exclude
233 manifest: rev
233 manifest: rev
234 outgoing: force, rev, newest-first, branch, patch, git, limit, no-merges, stat, style, template, ssh, remotecmd, subrepos
234 outgoing: force, rev, newest-first, branch, patch, git, limit, no-merges, stat, style, template, ssh, remotecmd, subrepos
235 parents: rev, style, template
235 parents: rev, style, template
236 paths:
236 paths:
237 recover:
237 recover:
238 rename: after, force, include, exclude, dry-run
238 rename: after, force, include, exclude, dry-run
239 resolve: all, list, mark, unmark, tool, no-status, include, exclude
239 resolve: all, list, mark, unmark, tool, no-status, include, exclude
240 revert: all, date, rev, no-backup, include, exclude, dry-run
240 revert: all, date, rev, no-backup, include, exclude, dry-run
241 rollback: dry-run
241 rollback: dry-run
242 root:
242 root:
243 showconfig: untrusted
243 showconfig: untrusted
244 tag: force, local, rev, remove, edit, message, date, user
244 tag: force, local, rev, remove, edit, message, date, user
245 tags:
245 tags:
246 tip: patch, git, style, template
246 tip: patch, git, style, template
247 unbundle: update
247 unbundle: update
248 verify:
248 verify:
249 version:
249 version:
General Comments 0
You need to be logged in to leave comments. Login now