##// END OF EJS Templates
merge with crew
Matt Mackall -
r20175:5ff0fd02 merge default
parent child Browse files
Show More
@@ -1,681 +1,682
1 # record.py
1 # record.py
2 #
2 #
3 # Copyright 2007 Bryan O'Sullivan <bos@serpentine.com>
3 # Copyright 2007 Bryan O'Sullivan <bos@serpentine.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 '''commands to interactively select changes for commit/qrefresh'''
8 '''commands to interactively select changes for commit/qrefresh'''
9
9
10 from mercurial.i18n import gettext, _
10 from mercurial.i18n import gettext, _
11 from mercurial import cmdutil, commands, extensions, hg, patch
11 from mercurial import cmdutil, commands, extensions, hg, patch
12 from mercurial import util
12 from mercurial import util
13 import copy, cStringIO, errno, os, re, shutil, tempfile
13 import copy, cStringIO, errno, os, re, shutil, tempfile
14
14
15 cmdtable = {}
15 cmdtable = {}
16 command = cmdutil.command(cmdtable)
16 command = cmdutil.command(cmdtable)
17 testedwith = 'internal'
17 testedwith = 'internal'
18
18
19 lines_re = re.compile(r'@@ -(\d+),(\d+) \+(\d+),(\d+) @@\s*(.*)')
19 lines_re = re.compile(r'@@ -(\d+),(\d+) \+(\d+),(\d+) @@\s*(.*)')
20
20
21 diffopts = [
21 diffopts = [
22 ('w', 'ignore-all-space', False,
22 ('w', 'ignore-all-space', False,
23 _('ignore white space when comparing lines')),
23 _('ignore white space when comparing lines')),
24 ('b', 'ignore-space-change', None,
24 ('b', 'ignore-space-change', None,
25 _('ignore changes in the amount of white space')),
25 _('ignore changes in the amount of white space')),
26 ('B', 'ignore-blank-lines', None,
26 ('B', 'ignore-blank-lines', None,
27 _('ignore changes whose lines are all blank')),
27 _('ignore changes whose lines are all blank')),
28 ]
28 ]
29
29
30 def scanpatch(fp):
30 def scanpatch(fp):
31 """like patch.iterhunks, but yield different events
31 """like patch.iterhunks, but yield different events
32
32
33 - ('file', [header_lines + fromfile + tofile])
33 - ('file', [header_lines + fromfile + tofile])
34 - ('context', [context_lines])
34 - ('context', [context_lines])
35 - ('hunk', [hunk_lines])
35 - ('hunk', [hunk_lines])
36 - ('range', (-start,len, +start,len, proc))
36 - ('range', (-start,len, +start,len, proc))
37 """
37 """
38 lr = patch.linereader(fp)
38 lr = patch.linereader(fp)
39
39
40 def scanwhile(first, p):
40 def scanwhile(first, p):
41 """scan lr while predicate holds"""
41 """scan lr while predicate holds"""
42 lines = [first]
42 lines = [first]
43 while True:
43 while True:
44 line = lr.readline()
44 line = lr.readline()
45 if not line:
45 if not line:
46 break
46 break
47 if p(line):
47 if p(line):
48 lines.append(line)
48 lines.append(line)
49 else:
49 else:
50 lr.push(line)
50 lr.push(line)
51 break
51 break
52 return lines
52 return lines
53
53
54 while True:
54 while True:
55 line = lr.readline()
55 line = lr.readline()
56 if not line:
56 if not line:
57 break
57 break
58 if line.startswith('diff --git a/') or line.startswith('diff -r '):
58 if line.startswith('diff --git a/') or line.startswith('diff -r '):
59 def notheader(line):
59 def notheader(line):
60 s = line.split(None, 1)
60 s = line.split(None, 1)
61 return not s or s[0] not in ('---', 'diff')
61 return not s or s[0] not in ('---', 'diff')
62 header = scanwhile(line, notheader)
62 header = scanwhile(line, notheader)
63 fromfile = lr.readline()
63 fromfile = lr.readline()
64 if fromfile.startswith('---'):
64 if fromfile.startswith('---'):
65 tofile = lr.readline()
65 tofile = lr.readline()
66 header += [fromfile, tofile]
66 header += [fromfile, tofile]
67 else:
67 else:
68 lr.push(fromfile)
68 lr.push(fromfile)
69 yield 'file', header
69 yield 'file', header
70 elif line[0] == ' ':
70 elif line[0] == ' ':
71 yield 'context', scanwhile(line, lambda l: l[0] in ' \\')
71 yield 'context', scanwhile(line, lambda l: l[0] in ' \\')
72 elif line[0] in '-+':
72 elif line[0] in '-+':
73 yield 'hunk', scanwhile(line, lambda l: l[0] in '-+\\')
73 yield 'hunk', scanwhile(line, lambda l: l[0] in '-+\\')
74 else:
74 else:
75 m = lines_re.match(line)
75 m = lines_re.match(line)
76 if m:
76 if m:
77 yield 'range', m.groups()
77 yield 'range', m.groups()
78 else:
78 else:
79 yield 'other', line
79 yield 'other', line
80
80
81 class header(object):
81 class header(object):
82 """patch header
82 """patch header
83
83
84 XXX shouldn't we move this to mercurial/patch.py ?
84 XXX shouldn't we move this to mercurial/patch.py ?
85 """
85 """
86 diffgit_re = re.compile('diff --git a/(.*) b/(.*)$')
86 diffgit_re = re.compile('diff --git a/(.*) b/(.*)$')
87 diff_re = re.compile('diff -r .* (.*)$')
87 diff_re = re.compile('diff -r .* (.*)$')
88 allhunks_re = re.compile('(?:index|new file|deleted file) ')
88 allhunks_re = re.compile('(?:index|new file|deleted file) ')
89 pretty_re = re.compile('(?:new file|deleted file) ')
89 pretty_re = re.compile('(?:new file|deleted file) ')
90 special_re = re.compile('(?:index|new|deleted|copy|rename) ')
90 special_re = re.compile('(?:index|new|deleted|copy|rename) ')
91
91
92 def __init__(self, header):
92 def __init__(self, header):
93 self.header = header
93 self.header = header
94 self.hunks = []
94 self.hunks = []
95
95
96 def binary(self):
96 def binary(self):
97 return util.any(h.startswith('index ') for h in self.header)
97 return util.any(h.startswith('index ') for h in self.header)
98
98
99 def pretty(self, fp):
99 def pretty(self, fp):
100 for h in self.header:
100 for h in self.header:
101 if h.startswith('index '):
101 if h.startswith('index '):
102 fp.write(_('this modifies a binary file (all or nothing)\n'))
102 fp.write(_('this modifies a binary file (all or nothing)\n'))
103 break
103 break
104 if self.pretty_re.match(h):
104 if self.pretty_re.match(h):
105 fp.write(h)
105 fp.write(h)
106 if self.binary():
106 if self.binary():
107 fp.write(_('this is a binary file\n'))
107 fp.write(_('this is a binary file\n'))
108 break
108 break
109 if h.startswith('---'):
109 if h.startswith('---'):
110 fp.write(_('%d hunks, %d lines changed\n') %
110 fp.write(_('%d hunks, %d lines changed\n') %
111 (len(self.hunks),
111 (len(self.hunks),
112 sum([max(h.added, h.removed) for h in self.hunks])))
112 sum([max(h.added, h.removed) for h in self.hunks])))
113 break
113 break
114 fp.write(h)
114 fp.write(h)
115
115
116 def write(self, fp):
116 def write(self, fp):
117 fp.write(''.join(self.header))
117 fp.write(''.join(self.header))
118
118
119 def allhunks(self):
119 def allhunks(self):
120 return util.any(self.allhunks_re.match(h) for h in self.header)
120 return util.any(self.allhunks_re.match(h) for h in self.header)
121
121
122 def files(self):
122 def files(self):
123 match = self.diffgit_re.match(self.header[0])
123 match = self.diffgit_re.match(self.header[0])
124 if match:
124 if match:
125 fromfile, tofile = match.groups()
125 fromfile, tofile = match.groups()
126 if fromfile == tofile:
126 if fromfile == tofile:
127 return [fromfile]
127 return [fromfile]
128 return [fromfile, tofile]
128 return [fromfile, tofile]
129 else:
129 else:
130 return self.diff_re.match(self.header[0]).groups()
130 return self.diff_re.match(self.header[0]).groups()
131
131
132 def filename(self):
132 def filename(self):
133 return self.files()[-1]
133 return self.files()[-1]
134
134
135 def __repr__(self):
135 def __repr__(self):
136 return '<header %s>' % (' '.join(map(repr, self.files())))
136 return '<header %s>' % (' '.join(map(repr, self.files())))
137
137
138 def special(self):
138 def special(self):
139 return util.any(self.special_re.match(h) for h in self.header)
139 return util.any(self.special_re.match(h) for h in self.header)
140
140
141 def countchanges(hunk):
141 def countchanges(hunk):
142 """hunk -> (n+,n-)"""
142 """hunk -> (n+,n-)"""
143 add = len([h for h in hunk if h[0] == '+'])
143 add = len([h for h in hunk if h[0] == '+'])
144 rem = len([h for h in hunk if h[0] == '-'])
144 rem = len([h for h in hunk if h[0] == '-'])
145 return add, rem
145 return add, rem
146
146
147 class hunk(object):
147 class hunk(object):
148 """patch hunk
148 """patch hunk
149
149
150 XXX shouldn't we merge this with patch.hunk ?
150 XXX shouldn't we merge this with patch.hunk ?
151 """
151 """
152 maxcontext = 3
152 maxcontext = 3
153
153
154 def __init__(self, header, fromline, toline, proc, before, hunk, after):
154 def __init__(self, header, fromline, toline, proc, before, hunk, after):
155 def trimcontext(number, lines):
155 def trimcontext(number, lines):
156 delta = len(lines) - self.maxcontext
156 delta = len(lines) - self.maxcontext
157 if False and delta > 0:
157 if False and delta > 0:
158 return number + delta, lines[:self.maxcontext]
158 return number + delta, lines[:self.maxcontext]
159 return number, lines
159 return number, lines
160
160
161 self.header = header
161 self.header = header
162 self.fromline, self.before = trimcontext(fromline, before)
162 self.fromline, self.before = trimcontext(fromline, before)
163 self.toline, self.after = trimcontext(toline, after)
163 self.toline, self.after = trimcontext(toline, after)
164 self.proc = proc
164 self.proc = proc
165 self.hunk = hunk
165 self.hunk = hunk
166 self.added, self.removed = countchanges(self.hunk)
166 self.added, self.removed = countchanges(self.hunk)
167
167
168 def write(self, fp):
168 def write(self, fp):
169 delta = len(self.before) + len(self.after)
169 delta = len(self.before) + len(self.after)
170 if self.after and self.after[-1] == '\\ No newline at end of file\n':
170 if self.after and self.after[-1] == '\\ No newline at end of file\n':
171 delta -= 1
171 delta -= 1
172 fromlen = delta + self.removed
172 fromlen = delta + self.removed
173 tolen = delta + self.added
173 tolen = delta + self.added
174 fp.write('@@ -%d,%d +%d,%d @@%s\n' %
174 fp.write('@@ -%d,%d +%d,%d @@%s\n' %
175 (self.fromline, fromlen, self.toline, tolen,
175 (self.fromline, fromlen, self.toline, tolen,
176 self.proc and (' ' + self.proc)))
176 self.proc and (' ' + self.proc)))
177 fp.write(''.join(self.before + self.hunk + self.after))
177 fp.write(''.join(self.before + self.hunk + self.after))
178
178
179 pretty = write
179 pretty = write
180
180
181 def filename(self):
181 def filename(self):
182 return self.header.filename()
182 return self.header.filename()
183
183
184 def __repr__(self):
184 def __repr__(self):
185 return '<hunk %r@%d>' % (self.filename(), self.fromline)
185 return '<hunk %r@%d>' % (self.filename(), self.fromline)
186
186
187 def parsepatch(fp):
187 def parsepatch(fp):
188 """patch -> [] of headers -> [] of hunks """
188 """patch -> [] of headers -> [] of hunks """
189 class parser(object):
189 class parser(object):
190 """patch parsing state machine"""
190 """patch parsing state machine"""
191 def __init__(self):
191 def __init__(self):
192 self.fromline = 0
192 self.fromline = 0
193 self.toline = 0
193 self.toline = 0
194 self.proc = ''
194 self.proc = ''
195 self.header = None
195 self.header = None
196 self.context = []
196 self.context = []
197 self.before = []
197 self.before = []
198 self.hunk = []
198 self.hunk = []
199 self.headers = []
199 self.headers = []
200
200
201 def addrange(self, limits):
201 def addrange(self, limits):
202 fromstart, fromend, tostart, toend, proc = limits
202 fromstart, fromend, tostart, toend, proc = limits
203 self.fromline = int(fromstart)
203 self.fromline = int(fromstart)
204 self.toline = int(tostart)
204 self.toline = int(tostart)
205 self.proc = proc
205 self.proc = proc
206
206
207 def addcontext(self, context):
207 def addcontext(self, context):
208 if self.hunk:
208 if self.hunk:
209 h = hunk(self.header, self.fromline, self.toline, self.proc,
209 h = hunk(self.header, self.fromline, self.toline, self.proc,
210 self.before, self.hunk, context)
210 self.before, self.hunk, context)
211 self.header.hunks.append(h)
211 self.header.hunks.append(h)
212 self.fromline += len(self.before) + h.removed
212 self.fromline += len(self.before) + h.removed
213 self.toline += len(self.before) + h.added
213 self.toline += len(self.before) + h.added
214 self.before = []
214 self.before = []
215 self.hunk = []
215 self.hunk = []
216 self.proc = ''
216 self.proc = ''
217 self.context = context
217 self.context = context
218
218
219 def addhunk(self, hunk):
219 def addhunk(self, hunk):
220 if self.context:
220 if self.context:
221 self.before = self.context
221 self.before = self.context
222 self.context = []
222 self.context = []
223 self.hunk = hunk
223 self.hunk = hunk
224
224
225 def newfile(self, hdr):
225 def newfile(self, hdr):
226 self.addcontext([])
226 self.addcontext([])
227 h = header(hdr)
227 h = header(hdr)
228 self.headers.append(h)
228 self.headers.append(h)
229 self.header = h
229 self.header = h
230
230
231 def addother(self, line):
231 def addother(self, line):
232 pass # 'other' lines are ignored
232 pass # 'other' lines are ignored
233
233
234 def finished(self):
234 def finished(self):
235 self.addcontext([])
235 self.addcontext([])
236 return self.headers
236 return self.headers
237
237
238 transitions = {
238 transitions = {
239 'file': {'context': addcontext,
239 'file': {'context': addcontext,
240 'file': newfile,
240 'file': newfile,
241 'hunk': addhunk,
241 'hunk': addhunk,
242 'range': addrange},
242 'range': addrange},
243 'context': {'file': newfile,
243 'context': {'file': newfile,
244 'hunk': addhunk,
244 'hunk': addhunk,
245 'range': addrange,
245 'range': addrange,
246 'other': addother},
246 'other': addother},
247 'hunk': {'context': addcontext,
247 'hunk': {'context': addcontext,
248 'file': newfile,
248 'file': newfile,
249 'range': addrange},
249 'range': addrange},
250 'range': {'context': addcontext,
250 'range': {'context': addcontext,
251 'hunk': addhunk},
251 'hunk': addhunk},
252 'other': {'other': addother},
252 'other': {'other': addother},
253 }
253 }
254
254
255 p = parser()
255 p = parser()
256
256
257 state = 'context'
257 state = 'context'
258 for newstate, data in scanpatch(fp):
258 for newstate, data in scanpatch(fp):
259 try:
259 try:
260 p.transitions[state][newstate](p, data)
260 p.transitions[state][newstate](p, data)
261 except KeyError:
261 except KeyError:
262 raise patch.PatchError('unhandled transition: %s -> %s' %
262 raise patch.PatchError('unhandled transition: %s -> %s' %
263 (state, newstate))
263 (state, newstate))
264 state = newstate
264 state = newstate
265 return p.finished()
265 return p.finished()
266
266
267 def filterpatch(ui, headers):
267 def filterpatch(ui, headers):
268 """Interactively filter patch chunks into applied-only chunks"""
268 """Interactively filter patch chunks into applied-only chunks"""
269
269
270 def prompt(skipfile, skipall, query, chunk):
270 def prompt(skipfile, skipall, query, chunk):
271 """prompt query, and process base inputs
271 """prompt query, and process base inputs
272
272
273 - y/n for the rest of file
273 - y/n for the rest of file
274 - y/n for the rest
274 - y/n for the rest
275 - ? (help)
275 - ? (help)
276 - q (quit)
276 - q (quit)
277
277
278 Return True/False and possibly updated skipfile and skipall.
278 Return True/False and possibly updated skipfile and skipall.
279 """
279 """
280 newpatches = None
280 newpatches = None
281 if skipall is not None:
281 if skipall is not None:
282 return skipall, skipfile, skipall, newpatches
282 return skipall, skipfile, skipall, newpatches
283 if skipfile is not None:
283 if skipfile is not None:
284 return skipfile, skipfile, skipall, newpatches
284 return skipfile, skipfile, skipall, newpatches
285 while True:
285 while True:
286 resps = _('[Ynesfdaq?]'
286 resps = _('[Ynesfdaq?]'
287 '$$ &Yes, record this change'
287 '$$ &Yes, record this change'
288 '$$ &No, skip this change'
288 '$$ &No, skip this change'
289 '$$ &Edit the change manually'
289 '$$ &Edit the change manually'
290 '$$ &Skip remaining changes to this file'
290 '$$ &Skip remaining changes to this file'
291 '$$ Record remaining changes to this &file'
291 '$$ Record remaining changes to this &file'
292 '$$ &Done, skip remaining changes and files'
292 '$$ &Done, skip remaining changes and files'
293 '$$ Record &all changes to all remaining files'
293 '$$ Record &all changes to all remaining files'
294 '$$ &Quit, recording no changes'
294 '$$ &Quit, recording no changes'
295 '$$ &?')
295 '$$ &?')
296 r = ui.promptchoice("%s %s" % (query, resps))
296 r = ui.promptchoice("%s %s" % (query, resps))
297 ui.write("\n")
297 ui.write("\n")
298 if r == 8: # ?
298 if r == 8: # ?
299 doc = gettext(record.__doc__)
299 doc = gettext(record.__doc__)
300 c = doc.find('::') + 2
300 c = doc.find('::') + 2
301 for l in doc[c:].splitlines():
301 for l in doc[c:].splitlines():
302 if l.startswith(' '):
302 if l.startswith(' '):
303 ui.write(l.strip(), '\n')
303 ui.write(l.strip(), '\n')
304 continue
304 continue
305 elif r == 0: # yes
305 elif r == 0: # yes
306 ret = True
306 ret = True
307 elif r == 1: # no
307 elif r == 1: # no
308 ret = False
308 ret = False
309 elif r == 2: # Edit patch
309 elif r == 2: # Edit patch
310 if chunk is None:
310 if chunk is None:
311 ui.write(_('cannot edit patch for whole file'))
311 ui.write(_('cannot edit patch for whole file'))
312 ui.write("\n")
312 ui.write("\n")
313 continue
313 continue
314 if chunk.header.binary():
314 if chunk.header.binary():
315 ui.write(_('cannot edit patch for binary file'))
315 ui.write(_('cannot edit patch for binary file'))
316 ui.write("\n")
316 ui.write("\n")
317 continue
317 continue
318 # Patch comment based on the Git one (based on comment at end of
318 # Patch comment based on the Git one (based on comment at end of
319 # http://mercurial.selenic.com/wiki/RecordExtension)
319 # http://mercurial.selenic.com/wiki/RecordExtension)
320 phelp = '---' + _("""
320 phelp = '---' + _("""
321 To remove '-' lines, make them ' ' lines (context).
321 To remove '-' lines, make them ' ' lines (context).
322 To remove '+' lines, delete them.
322 To remove '+' lines, delete them.
323 Lines starting with # will be removed from the patch.
323 Lines starting with # will be removed from the patch.
324
324
325 If the patch applies cleanly, the edited hunk will immediately be
325 If the patch applies cleanly, the edited hunk will immediately be
326 added to the record list. If it does not apply cleanly, a rejects
326 added to the record list. If it does not apply cleanly, a rejects
327 file will be generated: you can use that when you try again. If
327 file will be generated: you can use that when you try again. If
328 all lines of the hunk are removed, then the edit is aborted and
328 all lines of the hunk are removed, then the edit is aborted and
329 the hunk is left unchanged.
329 the hunk is left unchanged.
330 """)
330 """)
331 (patchfd, patchfn) = tempfile.mkstemp(prefix="hg-editor-",
331 (patchfd, patchfn) = tempfile.mkstemp(prefix="hg-editor-",
332 suffix=".diff", text=True)
332 suffix=".diff", text=True)
333 ncpatchfp = None
333 ncpatchfp = None
334 try:
334 try:
335 # Write the initial patch
335 # Write the initial patch
336 f = os.fdopen(patchfd, "w")
336 f = os.fdopen(patchfd, "w")
337 chunk.header.write(f)
337 chunk.header.write(f)
338 chunk.write(f)
338 chunk.write(f)
339 f.write('\n'.join(['# ' + i for i in phelp.splitlines()]))
339 f.write('\n'.join(['# ' + i for i in phelp.splitlines()]))
340 f.close()
340 f.close()
341 # Start the editor and wait for it to complete
341 # Start the editor and wait for it to complete
342 editor = ui.geteditor()
342 editor = ui.geteditor()
343 util.system("%s \"%s\"" % (editor, patchfn),
343 util.system("%s \"%s\"" % (editor, patchfn),
344 environ={'HGUSER': ui.username()},
344 environ={'HGUSER': ui.username()},
345 onerr=util.Abort, errprefix=_("edit failed"),
345 onerr=util.Abort, errprefix=_("edit failed"),
346 out=ui.fout)
346 out=ui.fout)
347 # Remove comment lines
347 # Remove comment lines
348 patchfp = open(patchfn)
348 patchfp = open(patchfn)
349 ncpatchfp = cStringIO.StringIO()
349 ncpatchfp = cStringIO.StringIO()
350 for line in patchfp:
350 for line in patchfp:
351 if not line.startswith('#'):
351 if not line.startswith('#'):
352 ncpatchfp.write(line)
352 ncpatchfp.write(line)
353 patchfp.close()
353 patchfp.close()
354 ncpatchfp.seek(0)
354 ncpatchfp.seek(0)
355 newpatches = parsepatch(ncpatchfp)
355 newpatches = parsepatch(ncpatchfp)
356 finally:
356 finally:
357 os.unlink(patchfn)
357 os.unlink(patchfn)
358 del ncpatchfp
358 del ncpatchfp
359 # Signal that the chunk shouldn't be applied as-is, but
359 # Signal that the chunk shouldn't be applied as-is, but
360 # provide the new patch to be used instead.
360 # provide the new patch to be used instead.
361 ret = False
361 ret = False
362 elif r == 3: # Skip
362 elif r == 3: # Skip
363 ret = skipfile = False
363 ret = skipfile = False
364 elif r == 4: # file (Record remaining)
364 elif r == 4: # file (Record remaining)
365 ret = skipfile = True
365 ret = skipfile = True
366 elif r == 5: # done, skip remaining
366 elif r == 5: # done, skip remaining
367 ret = skipall = False
367 ret = skipall = False
368 elif r == 6: # all
368 elif r == 6: # all
369 ret = skipall = True
369 ret = skipall = True
370 elif r == 7: # quit
370 elif r == 7: # quit
371 raise util.Abort(_('user quit'))
371 raise util.Abort(_('user quit'))
372 return ret, skipfile, skipall, newpatches
372 return ret, skipfile, skipall, newpatches
373
373
374 seen = set()
374 seen = set()
375 applied = {} # 'filename' -> [] of chunks
375 applied = {} # 'filename' -> [] of chunks
376 skipfile, skipall = None, None
376 skipfile, skipall = None, None
377 pos, total = 1, sum(len(h.hunks) for h in headers)
377 pos, total = 1, sum(len(h.hunks) for h in headers)
378 for h in headers:
378 for h in headers:
379 pos += len(h.hunks)
379 pos += len(h.hunks)
380 skipfile = None
380 skipfile = None
381 fixoffset = 0
381 fixoffset = 0
382 hdr = ''.join(h.header)
382 hdr = ''.join(h.header)
383 if hdr in seen:
383 if hdr in seen:
384 continue
384 continue
385 seen.add(hdr)
385 seen.add(hdr)
386 if skipall is None:
386 if skipall is None:
387 h.pretty(ui)
387 h.pretty(ui)
388 msg = (_('examine changes to %s?') %
388 msg = (_('examine changes to %s?') %
389 _(' and ').join("'%s'" % f for f in h.files()))
389 _(' and ').join("'%s'" % f for f in h.files()))
390 r, skipfile, skipall, np = prompt(skipfile, skipall, msg, None)
390 r, skipfile, skipall, np = prompt(skipfile, skipall, msg, None)
391 if not r:
391 if not r:
392 continue
392 continue
393 applied[h.filename()] = [h]
393 applied[h.filename()] = [h]
394 if h.allhunks():
394 if h.allhunks():
395 applied[h.filename()] += h.hunks
395 applied[h.filename()] += h.hunks
396 continue
396 continue
397 for i, chunk in enumerate(h.hunks):
397 for i, chunk in enumerate(h.hunks):
398 if skipfile is None and skipall is None:
398 if skipfile is None and skipall is None:
399 chunk.pretty(ui)
399 chunk.pretty(ui)
400 if total == 1:
400 if total == 1:
401 msg = _("record this change to '%s'?") % chunk.filename()
401 msg = _("record this change to '%s'?") % chunk.filename()
402 else:
402 else:
403 idx = pos - len(h.hunks) + i
403 idx = pos - len(h.hunks) + i
404 msg = _("record change %d/%d to '%s'?") % (idx, total,
404 msg = _("record change %d/%d to '%s'?") % (idx, total,
405 chunk.filename())
405 chunk.filename())
406 r, skipfile, skipall, newpatches = prompt(skipfile,
406 r, skipfile, skipall, newpatches = prompt(skipfile,
407 skipall, msg, chunk)
407 skipall, msg, chunk)
408 if r:
408 if r:
409 if fixoffset:
409 if fixoffset:
410 chunk = copy.copy(chunk)
410 chunk = copy.copy(chunk)
411 chunk.toline += fixoffset
411 chunk.toline += fixoffset
412 applied[chunk.filename()].append(chunk)
412 applied[chunk.filename()].append(chunk)
413 elif newpatches is not None:
413 elif newpatches is not None:
414 for newpatch in newpatches:
414 for newpatch in newpatches:
415 for newhunk in newpatch.hunks:
415 for newhunk in newpatch.hunks:
416 if fixoffset:
416 if fixoffset:
417 newhunk.toline += fixoffset
417 newhunk.toline += fixoffset
418 applied[newhunk.filename()].append(newhunk)
418 applied[newhunk.filename()].append(newhunk)
419 else:
419 else:
420 fixoffset += chunk.removed - chunk.added
420 fixoffset += chunk.removed - chunk.added
421 return sum([h for h in applied.itervalues()
421 return sum([h for h in applied.itervalues()
422 if h[0].special() or len(h) > 1], [])
422 if h[0].special() or len(h) > 1], [])
423
423
424 @command("record",
424 @command("record",
425 # same options as commit + white space diff options
425 # same options as commit + white space diff options
426 commands.table['^commit|ci'][1][:] + diffopts,
426 commands.table['^commit|ci'][1][:] + diffopts,
427 _('hg record [OPTION]... [FILE]...'))
427 _('hg record [OPTION]... [FILE]...'))
428 def record(ui, repo, *pats, **opts):
428 def record(ui, repo, *pats, **opts):
429 '''interactively select changes to commit
429 '''interactively select changes to commit
430
430
431 If a list of files is omitted, all changes reported by :hg:`status`
431 If a list of files is omitted, all changes reported by :hg:`status`
432 will be candidates for recording.
432 will be candidates for recording.
433
433
434 See :hg:`help dates` for a list of formats valid for -d/--date.
434 See :hg:`help dates` for a list of formats valid for -d/--date.
435
435
436 You will be prompted for whether to record changes to each
436 You will be prompted for whether to record changes to each
437 modified file, and for files with multiple changes, for each
437 modified file, and for files with multiple changes, for each
438 change to use. For each query, the following responses are
438 change to use. For each query, the following responses are
439 possible::
439 possible::
440
440
441 y - record this change
441 y - record this change
442 n - skip this change
442 n - skip this change
443 e - edit this change manually
443 e - edit this change manually
444
444
445 s - skip remaining changes to this file
445 s - skip remaining changes to this file
446 f - record remaining changes to this file
446 f - record remaining changes to this file
447
447
448 d - done, skip remaining changes and files
448 d - done, skip remaining changes and files
449 a - record all changes to all remaining files
449 a - record all changes to all remaining files
450 q - quit, recording no changes
450 q - quit, recording no changes
451
451
452 ? - display help
452 ? - display help
453
453
454 This command is not available when committing a merge.'''
454 This command is not available when committing a merge.'''
455
455
456 dorecord(ui, repo, commands.commit, 'commit', False, *pats, **opts)
456 dorecord(ui, repo, commands.commit, 'commit', False, *pats, **opts)
457
457
458 def qrefresh(origfn, ui, repo, *pats, **opts):
458 def qrefresh(origfn, ui, repo, *pats, **opts):
459 if not opts['interactive']:
459 if not opts['interactive']:
460 return origfn(ui, repo, *pats, **opts)
460 return origfn(ui, repo, *pats, **opts)
461
461
462 mq = extensions.find('mq')
462 mq = extensions.find('mq')
463
463
464 def committomq(ui, repo, *pats, **opts):
464 def committomq(ui, repo, *pats, **opts):
465 # At this point the working copy contains only changes that
465 # At this point the working copy contains only changes that
466 # were accepted. All other changes were reverted.
466 # were accepted. All other changes were reverted.
467 # We can't pass *pats here since qrefresh will undo all other
467 # We can't pass *pats here since qrefresh will undo all other
468 # changed files in the patch that aren't in pats.
468 # changed files in the patch that aren't in pats.
469 mq.refresh(ui, repo, **opts)
469 mq.refresh(ui, repo, **opts)
470
470
471 # backup all changed files
471 # backup all changed files
472 dorecord(ui, repo, committomq, 'qrefresh', True, *pats, **opts)
472 dorecord(ui, repo, committomq, 'qrefresh', True, *pats, **opts)
473
473
474 def qrecord(ui, repo, patch, *pats, **opts):
474 def qrecord(ui, repo, patch, *pats, **opts):
475 '''interactively record a new patch
475 '''interactively record a new patch
476
476
477 See :hg:`help qnew` & :hg:`help record` for more information and
477 See :hg:`help qnew` & :hg:`help record` for more information and
478 usage.
478 usage.
479 '''
479 '''
480
480
481 try:
481 try:
482 mq = extensions.find('mq')
482 mq = extensions.find('mq')
483 except KeyError:
483 except KeyError:
484 raise util.Abort(_("'mq' extension not loaded"))
484 raise util.Abort(_("'mq' extension not loaded"))
485
485
486 repo.mq.checkpatchname(patch)
486 repo.mq.checkpatchname(patch)
487
487
488 def committomq(ui, repo, *pats, **opts):
488 def committomq(ui, repo, *pats, **opts):
489 opts['checkname'] = False
489 opts['checkname'] = False
490 mq.new(ui, repo, patch, *pats, **opts)
490 mq.new(ui, repo, patch, *pats, **opts)
491
491
492 dorecord(ui, repo, committomq, 'qnew', False, *pats, **opts)
492 dorecord(ui, repo, committomq, 'qnew', False, *pats, **opts)
493
493
494 def qnew(origfn, ui, repo, patch, *args, **opts):
494 def qnew(origfn, ui, repo, patch, *args, **opts):
495 if opts['interactive']:
495 if opts['interactive']:
496 return qrecord(ui, repo, patch, *args, **opts)
496 return qrecord(ui, repo, patch, *args, **opts)
497 return origfn(ui, repo, patch, *args, **opts)
497 return origfn(ui, repo, patch, *args, **opts)
498
498
499 def dorecord(ui, repo, commitfunc, cmdsuggest, backupall, *pats, **opts):
499 def dorecord(ui, repo, commitfunc, cmdsuggest, backupall, *pats, **opts):
500 if not ui.interactive():
500 if not ui.interactive():
501 raise util.Abort(_('running non-interactively, use %s instead') %
501 raise util.Abort(_('running non-interactively, use %s instead') %
502 cmdsuggest)
502 cmdsuggest)
503
503
504 # make sure username is set before going interactive
504 # make sure username is set before going interactive
505 ui.username()
505 if not opts.get('user'):
506 ui.username() # raise exception, username not provided
506
507
507 def recordfunc(ui, repo, message, match, opts):
508 def recordfunc(ui, repo, message, match, opts):
508 """This is generic record driver.
509 """This is generic record driver.
509
510
510 Its job is to interactively filter local changes, and
511 Its job is to interactively filter local changes, and
511 accordingly prepare working directory into a state in which the
512 accordingly prepare working directory into a state in which the
512 job can be delegated to a non-interactive commit command such as
513 job can be delegated to a non-interactive commit command such as
513 'commit' or 'qrefresh'.
514 'commit' or 'qrefresh'.
514
515
515 After the actual job is done by non-interactive command, the
516 After the actual job is done by non-interactive command, the
516 working directory is restored to its original state.
517 working directory is restored to its original state.
517
518
518 In the end we'll record interesting changes, and everything else
519 In the end we'll record interesting changes, and everything else
519 will be left in place, so the user can continue working.
520 will be left in place, so the user can continue working.
520 """
521 """
521
522
522 cmdutil.checkunfinished(repo, commit=True)
523 cmdutil.checkunfinished(repo, commit=True)
523 merge = len(repo[None].parents()) > 1
524 merge = len(repo[None].parents()) > 1
524 if merge:
525 if merge:
525 raise util.Abort(_('cannot partially commit a merge '
526 raise util.Abort(_('cannot partially commit a merge '
526 '(use "hg commit" instead)'))
527 '(use "hg commit" instead)'))
527
528
528 changes = repo.status(match=match)[:3]
529 changes = repo.status(match=match)[:3]
529 diffopts = patch.diffopts(ui, opts=dict(
530 diffopts = patch.diffopts(ui, opts=dict(
530 git=True, nodates=True,
531 git=True, nodates=True,
531 ignorews=opts.get('ignore_all_space'),
532 ignorews=opts.get('ignore_all_space'),
532 ignorewsamount=opts.get('ignore_space_change'),
533 ignorewsamount=opts.get('ignore_space_change'),
533 ignoreblanklines=opts.get('ignore_blank_lines')))
534 ignoreblanklines=opts.get('ignore_blank_lines')))
534 chunks = patch.diff(repo, changes=changes, opts=diffopts)
535 chunks = patch.diff(repo, changes=changes, opts=diffopts)
535 fp = cStringIO.StringIO()
536 fp = cStringIO.StringIO()
536 fp.write(''.join(chunks))
537 fp.write(''.join(chunks))
537 fp.seek(0)
538 fp.seek(0)
538
539
539 # 1. filter patch, so we have intending-to apply subset of it
540 # 1. filter patch, so we have intending-to apply subset of it
540 try:
541 try:
541 chunks = filterpatch(ui, parsepatch(fp))
542 chunks = filterpatch(ui, parsepatch(fp))
542 except patch.PatchError, err:
543 except patch.PatchError, err:
543 raise util.Abort(_('error parsing patch: %s') % err)
544 raise util.Abort(_('error parsing patch: %s') % err)
544
545
545 del fp
546 del fp
546
547
547 contenders = set()
548 contenders = set()
548 for h in chunks:
549 for h in chunks:
549 try:
550 try:
550 contenders.update(set(h.files()))
551 contenders.update(set(h.files()))
551 except AttributeError:
552 except AttributeError:
552 pass
553 pass
553
554
554 changed = changes[0] + changes[1] + changes[2]
555 changed = changes[0] + changes[1] + changes[2]
555 newfiles = [f for f in changed if f in contenders]
556 newfiles = [f for f in changed if f in contenders]
556 if not newfiles:
557 if not newfiles:
557 ui.status(_('no changes to record\n'))
558 ui.status(_('no changes to record\n'))
558 return 0
559 return 0
559
560
560 modified = set(changes[0])
561 modified = set(changes[0])
561
562
562 # 2. backup changed files, so we can restore them in the end
563 # 2. backup changed files, so we can restore them in the end
563 if backupall:
564 if backupall:
564 tobackup = changed
565 tobackup = changed
565 else:
566 else:
566 tobackup = [f for f in newfiles if f in modified]
567 tobackup = [f for f in newfiles if f in modified]
567
568
568 backups = {}
569 backups = {}
569 if tobackup:
570 if tobackup:
570 backupdir = repo.join('record-backups')
571 backupdir = repo.join('record-backups')
571 try:
572 try:
572 os.mkdir(backupdir)
573 os.mkdir(backupdir)
573 except OSError, err:
574 except OSError, err:
574 if err.errno != errno.EEXIST:
575 if err.errno != errno.EEXIST:
575 raise
576 raise
576 try:
577 try:
577 # backup continues
578 # backup continues
578 for f in tobackup:
579 for f in tobackup:
579 fd, tmpname = tempfile.mkstemp(prefix=f.replace('/', '_')+'.',
580 fd, tmpname = tempfile.mkstemp(prefix=f.replace('/', '_')+'.',
580 dir=backupdir)
581 dir=backupdir)
581 os.close(fd)
582 os.close(fd)
582 ui.debug('backup %r as %r\n' % (f, tmpname))
583 ui.debug('backup %r as %r\n' % (f, tmpname))
583 util.copyfile(repo.wjoin(f), tmpname)
584 util.copyfile(repo.wjoin(f), tmpname)
584 shutil.copystat(repo.wjoin(f), tmpname)
585 shutil.copystat(repo.wjoin(f), tmpname)
585 backups[f] = tmpname
586 backups[f] = tmpname
586
587
587 fp = cStringIO.StringIO()
588 fp = cStringIO.StringIO()
588 for c in chunks:
589 for c in chunks:
589 if c.filename() in backups:
590 if c.filename() in backups:
590 c.write(fp)
591 c.write(fp)
591 dopatch = fp.tell()
592 dopatch = fp.tell()
592 fp.seek(0)
593 fp.seek(0)
593
594
594 # 3a. apply filtered patch to clean repo (clean)
595 # 3a. apply filtered patch to clean repo (clean)
595 if backups:
596 if backups:
596 hg.revert(repo, repo.dirstate.p1(),
597 hg.revert(repo, repo.dirstate.p1(),
597 lambda key: key in backups)
598 lambda key: key in backups)
598
599
599 # 3b. (apply)
600 # 3b. (apply)
600 if dopatch:
601 if dopatch:
601 try:
602 try:
602 ui.debug('applying patch\n')
603 ui.debug('applying patch\n')
603 ui.debug(fp.getvalue())
604 ui.debug(fp.getvalue())
604 patch.internalpatch(ui, repo, fp, 1, eolmode=None)
605 patch.internalpatch(ui, repo, fp, 1, eolmode=None)
605 except patch.PatchError, err:
606 except patch.PatchError, err:
606 raise util.Abort(str(err))
607 raise util.Abort(str(err))
607 del fp
608 del fp
608
609
609 # 4. We prepared working directory according to filtered
610 # 4. We prepared working directory according to filtered
610 # patch. Now is the time to delegate the job to
611 # patch. Now is the time to delegate the job to
611 # commit/qrefresh or the like!
612 # commit/qrefresh or the like!
612
613
613 # it is important to first chdir to repo root -- we'll call
614 # it is important to first chdir to repo root -- we'll call
614 # a highlevel command with list of pathnames relative to
615 # a highlevel command with list of pathnames relative to
615 # repo root
616 # repo root
616 cwd = os.getcwd()
617 cwd = os.getcwd()
617 os.chdir(repo.root)
618 os.chdir(repo.root)
618 try:
619 try:
619 commitfunc(ui, repo, *newfiles, **opts)
620 commitfunc(ui, repo, *newfiles, **opts)
620 finally:
621 finally:
621 os.chdir(cwd)
622 os.chdir(cwd)
622
623
623 return 0
624 return 0
624 finally:
625 finally:
625 # 5. finally restore backed-up files
626 # 5. finally restore backed-up files
626 try:
627 try:
627 for realname, tmpname in backups.iteritems():
628 for realname, tmpname in backups.iteritems():
628 ui.debug('restoring %r to %r\n' % (tmpname, realname))
629 ui.debug('restoring %r to %r\n' % (tmpname, realname))
629 util.copyfile(tmpname, repo.wjoin(realname))
630 util.copyfile(tmpname, repo.wjoin(realname))
630 # Our calls to copystat() here and above are a
631 # Our calls to copystat() here and above are a
631 # hack to trick any editors that have f open that
632 # hack to trick any editors that have f open that
632 # we haven't modified them.
633 # we haven't modified them.
633 #
634 #
634 # Also note that this racy as an editor could
635 # Also note that this racy as an editor could
635 # notice the file's mtime before we've finished
636 # notice the file's mtime before we've finished
636 # writing it.
637 # writing it.
637 shutil.copystat(tmpname, repo.wjoin(realname))
638 shutil.copystat(tmpname, repo.wjoin(realname))
638 os.unlink(tmpname)
639 os.unlink(tmpname)
639 if tobackup:
640 if tobackup:
640 os.rmdir(backupdir)
641 os.rmdir(backupdir)
641 except OSError:
642 except OSError:
642 pass
643 pass
643
644
644 # wrap ui.write so diff output can be labeled/colorized
645 # wrap ui.write so diff output can be labeled/colorized
645 def wrapwrite(orig, *args, **kw):
646 def wrapwrite(orig, *args, **kw):
646 label = kw.pop('label', '')
647 label = kw.pop('label', '')
647 for chunk, l in patch.difflabel(lambda: args):
648 for chunk, l in patch.difflabel(lambda: args):
648 orig(chunk, label=label + l)
649 orig(chunk, label=label + l)
649 oldwrite = ui.write
650 oldwrite = ui.write
650 extensions.wrapfunction(ui, 'write', wrapwrite)
651 extensions.wrapfunction(ui, 'write', wrapwrite)
651 try:
652 try:
652 return cmdutil.commit(ui, repo, recordfunc, pats, opts)
653 return cmdutil.commit(ui, repo, recordfunc, pats, opts)
653 finally:
654 finally:
654 ui.write = oldwrite
655 ui.write = oldwrite
655
656
656 cmdtable["qrecord"] = \
657 cmdtable["qrecord"] = \
657 (qrecord, [], # placeholder until mq is available
658 (qrecord, [], # placeholder until mq is available
658 _('hg qrecord [OPTION]... PATCH [FILE]...'))
659 _('hg qrecord [OPTION]... PATCH [FILE]...'))
659
660
660 def uisetup(ui):
661 def uisetup(ui):
661 try:
662 try:
662 mq = extensions.find('mq')
663 mq = extensions.find('mq')
663 except KeyError:
664 except KeyError:
664 return
665 return
665
666
666 cmdtable["qrecord"] = \
667 cmdtable["qrecord"] = \
667 (qrecord,
668 (qrecord,
668 # same options as qnew, but copy them so we don't get
669 # same options as qnew, but copy them so we don't get
669 # -i/--interactive for qrecord and add white space diff options
670 # -i/--interactive for qrecord and add white space diff options
670 mq.cmdtable['^qnew'][1][:] + diffopts,
671 mq.cmdtable['^qnew'][1][:] + diffopts,
671 _('hg qrecord [OPTION]... PATCH [FILE]...'))
672 _('hg qrecord [OPTION]... PATCH [FILE]...'))
672
673
673 _wrapcmd('qnew', mq.cmdtable, qnew, _("interactively record a new patch"))
674 _wrapcmd('qnew', mq.cmdtable, qnew, _("interactively record a new patch"))
674 _wrapcmd('qrefresh', mq.cmdtable, qrefresh,
675 _wrapcmd('qrefresh', mq.cmdtable, qrefresh,
675 _("interactively select changes to refresh"))
676 _("interactively select changes to refresh"))
676
677
677 def _wrapcmd(cmd, table, wrapfn, msg):
678 def _wrapcmd(cmd, table, wrapfn, msg):
678 entry = extensions.wrapcommand(table, cmd, wrapfn)
679 entry = extensions.wrapcommand(table, cmd, wrapfn)
679 entry[1].append(('i', 'interactive', None, msg))
680 entry[1].append(('i', 'interactive', None, msg))
680
681
681 commands.inferrepo += " record qrecord"
682 commands.inferrepo += " record qrecord"
@@ -1,108 +1,108
1 Mercurial allows you to customize output of commands through
1 Mercurial allows you to customize output of commands through
2 templates. You can either pass in a template from the command
2 templates. You can either pass in a template from the command
3 line, via the --template option, or select an existing
3 line, via the --template option, or select an existing
4 template-style (--style).
4 template-style (--style).
5
5
6 You can customize output for any "log-like" command: log,
6 You can customize output for any "log-like" command: log,
7 outgoing, incoming, tip, parents, heads and glog.
7 outgoing, incoming, tip, parents, heads and glog.
8
8
9 Five styles are packaged with Mercurial: default (the style used
9 Five styles are packaged with Mercurial: default (the style used
10 when no explicit preference is passed), compact, changelog, phases
10 when no explicit preference is passed), compact, changelog, phases
11 and xml.
11 and xml.
12 Usage::
12 Usage::
13
13
14 $ hg log -r1 --style changelog
14 $ hg log -r1 --style changelog
15
15
16 A template is a piece of text, with markup to invoke variable
16 A template is a piece of text, with markup to invoke variable
17 expansion::
17 expansion::
18
18
19 $ hg log -r1 --template "{node}\n"
19 $ hg log -r1 --template "{node}\n"
20 b56ce7b07c52de7d5fd79fb89701ea538af65746
20 b56ce7b07c52de7d5fd79fb89701ea538af65746
21
21
22 Strings in curly braces are called keywords. The availability of
22 Strings in curly braces are called keywords. The availability of
23 keywords depends on the exact context of the templater. These
23 keywords depends on the exact context of the templater. These
24 keywords are usually available for templating a log-like command:
24 keywords are usually available for templating a log-like command:
25
25
26 .. keywordsmarker
26 .. keywordsmarker
27
27
28 The "date" keyword does not produce human-readable output. If you
28 The "date" keyword does not produce human-readable output. If you
29 want to use a date in your output, you can use a filter to process
29 want to use a date in your output, you can use a filter to process
30 it. Filters are functions which return a string based on the input
30 it. Filters are functions which return a string based on the input
31 variable. Be sure to use the stringify filter first when you're
31 variable. Be sure to use the stringify filter first when you're
32 applying a string-input filter to a list-like input variable.
32 applying a string-input filter to a list-like input variable.
33 You can also use a chain of filters to get the desired output::
33 You can also use a chain of filters to get the desired output::
34
34
35 $ hg tip --template "{date|isodate}\n"
35 $ hg tip --template "{date|isodate}\n"
36 2008-08-21 18:22 +0000
36 2008-08-21 18:22 +0000
37
37
38 List of filters:
38 List of filters:
39
39
40 .. filtersmarker
40 .. filtersmarker
41
41
42 Note that a filter is nothing more than a function call, i.e.
42 Note that a filter is nothing more than a function call, i.e.
43 ``expr|filter`` is equivalent to ``filter(expr)``.
43 ``expr|filter`` is equivalent to ``filter(expr)``.
44
44
45 In addition to filters, there are some basic built-in functions:
45 In addition to filters, there are some basic built-in functions:
46
46
47 - date(date[, fmt])
47 - date(date[, fmt])
48
48
49 - fill(text[, width])
49 - fill(text[, width])
50
50
51 - get(dict, key)
51 - get(dict, key)
52
52
53 - if(expr, then[, else])
53 - if(expr, then[, else])
54
54
55 - ifeq(expr, expr, then[, else])
55 - ifeq(expr, expr, then[, else])
56
56
57 - join(list, sep)
57 - join(list, sep)
58
58
59 - label(label, expr)
59 - label(label, expr)
60
60
61 - rstdoc(text, style)
61 - rstdoc(text, style)
62
62
63 - strip(text[, chars])
63 - strip(text[, chars])
64
64
65 - sub(pat, repl, expr)
65 - sub(pat, repl, expr)
66
66
67 Also, for any expression that returns a list, there is a list operator:
67 Also, for any expression that returns a list, there is a list operator:
68
68
69 - expr % "{template}"
69 - expr % "{template}"
70
70
71 Some sample command line templates:
71 Some sample command line templates:
72
72
73 - Format lists, e.g. files::
73 - Format lists, e.g. files::
74
74
75 $ hg log -r 0 --template "files:\n{files % ' {file}\n'}"
75 $ hg log -r 0 --template "files:\n{files % ' {file}\n'}"
76
76
77 - Join the list of files with a ", "::
77 - Join the list of files with a ", "::
78
78
79 $ hg log -r 0 --template "files: {join(files, ', ')}\n"
79 $ hg log -r 0 --template "files: {join(files, ', ')}\n"
80
80
81 - Format date::
81 - Format date::
82
82
83 $ hg log -r 0 --template "{date(date, '%Y')}\n"
83 $ hg log -r 0 --template "{date(date, '%Y')}\n"
84
84
85 - Output the description set to a fill-width of 30::
85 - Output the description set to a fill-width of 30::
86
86
87 $ hg log -r 0 --template "{fill(desc, '30')}"
87 $ hg log -r 0 --template "{fill(desc, '30')}"
88
88
89 - Use a conditional to test for the default branch::
89 - Use a conditional to test for the default branch::
90
90
91 $ hg log -r 0 --template "{ifeq(branch, 'default', 'on the main branch',
91 $ hg log -r 0 --template "{ifeq(branch, 'default', 'on the main branch',
92 'on branch {branch}')}\n"
92 'on branch {branch}')}\n"
93
93
94 - Append a newline if not empty::
94 - Append a newline if not empty::
95
95
96 $ hg tip --template "{if(author, '{author}\n')}"
96 $ hg tip --template "{if(author, '{author}\n')}"
97
97
98 - Label the output for use with the color extension::
98 - Label the output for use with the color extension::
99
99
100 $ hg log -r 0 --template "{label('changeset.{phase}', node|short)}\n"
100 $ hg log -r 0 --template "{label('changeset.{phase}', node|short)}\n"
101
101
102 - Invert the firstline filter, i.e. everything but the first line::
102 - Invert the firstline filter, i.e. everything but the first line::
103
103
104 $ hg log -r 0 --template "{sub(r'^.*\n?\n?', '', desc)}\n"
104 $ hg log -r 0 --template "{sub(r'^.*\n?\n?', '', desc)}\n"
105
105
106 - Display the contents of the 'extra' field, one per line::
106 - Display the contents of the 'extra' field, one per line::
107
107
108 $ hg log -r 0 --template "{join(extras, '\n')}\n"
108 $ hg log -r 0 --template "{join(extras, '\n')}\n"
@@ -1,39 +1,46
1 This code uses the ast module, which was new in 2.6, so we'll skip
1 This code uses the ast module, which was new in 2.6, so we'll skip
2 this test on anything earlier.
2 this test on anything earlier.
3 $ python -c 'import sys ; assert sys.version_info >= (2, 6)' || exit 80
3 $ python -c 'import sys ; assert sys.version_info >= (2, 6)' || exit 80
4
4
5 Virtualenv has a habit of leaving BaseHTTPServer and other modules in
6 a place where the import checker is confused about their nature as
7 part of the stdlib. Skip the test if BaseHTTPServer's path isn't a
8 subpath of sys.prefix.
9
10 $ python -c 'import sys, BaseHTTPServer; assert BaseHTTPServer.__file__.startswith(sys.prefix)' || exit 80
11
5 $ import_checker="$TESTDIR"/../contrib/import-checker.py
12 $ import_checker="$TESTDIR"/../contrib/import-checker.py
6 Run the doctests from the import checker, and make sure
13 Run the doctests from the import checker, and make sure
7 it's working correctly.
14 it's working correctly.
8 $ TERM=dumb
15 $ TERM=dumb
9 $ export TERM
16 $ export TERM
10 $ python -m doctest $import_checker
17 $ python -m doctest $import_checker
11
18
12 $ cd "$TESTDIR"/..
19 $ cd "$TESTDIR"/..
13 $ if hg identify -q > /dev/null 2>&1; then :
20 $ if hg identify -q > /dev/null 2>&1; then :
14 > else
21 > else
15 > echo "skipped: not a Mercurial working dir" >&2
22 > echo "skipped: not a Mercurial working dir" >&2
16 > exit 80
23 > exit 80
17 > fi
24 > fi
18
25
19 There are a handful of cases here that require renaming a module so it
26 There are a handful of cases here that require renaming a module so it
20 doesn't overlap with a stdlib module name. There are also some cycles
27 doesn't overlap with a stdlib module name. There are also some cycles
21 here that we should still endeavor to fix, and some cycles will be
28 here that we should still endeavor to fix, and some cycles will be
22 hidden by deduplication algorithm in the cycle detector, so fixing
29 hidden by deduplication algorithm in the cycle detector, so fixing
23 these may expose other cycles.
30 these may expose other cycles.
24
31
25 $ hg locate 'mercurial/**.py' | xargs python "$import_checker"
32 $ hg locate 'mercurial/**.py' | xargs python "$import_checker"
26 mercurial/dispatch.py mixed stdlib and relative imports:
33 mercurial/dispatch.py mixed stdlib and relative imports:
27 commands, error, extensions, fancyopts, hg, hook, util
34 commands, error, extensions, fancyopts, hg, hook, util
28 mercurial/fileset.py mixed stdlib and relative imports:
35 mercurial/fileset.py mixed stdlib and relative imports:
29 error, merge, parser, util
36 error, merge, parser, util
30 mercurial/revset.py mixed stdlib and relative imports:
37 mercurial/revset.py mixed stdlib and relative imports:
31 discovery, error, hbisect, parser, phases, util
38 discovery, error, hbisect, parser, phases, util
32 mercurial/templater.py mixed stdlib and relative imports:
39 mercurial/templater.py mixed stdlib and relative imports:
33 config, error, parser, templatefilters, util
40 config, error, parser, templatefilters, util
34 mercurial/ui.py mixed stdlib and relative imports:
41 mercurial/ui.py mixed stdlib and relative imports:
35 config, error, formatter, scmutil, util
42 config, error, formatter, scmutil, util
36 Import cycle: mercurial.cmdutil -> mercurial.subrepo -> mercurial.cmdutil
43 Import cycle: mercurial.cmdutil -> mercurial.subrepo -> mercurial.cmdutil
37 Import cycle: mercurial.repoview -> mercurial.revset -> mercurial.repoview
44 Import cycle: mercurial.repoview -> mercurial.revset -> mercurial.repoview
38 Import cycle: mercurial.fileset -> mercurial.merge -> mercurial.subrepo -> mercurial.match -> mercurial.fileset
45 Import cycle: mercurial.fileset -> mercurial.merge -> mercurial.subrepo -> mercurial.match -> mercurial.fileset
39 Import cycle: mercurial.filemerge -> mercurial.match -> mercurial.fileset -> mercurial.merge -> mercurial.filemerge
46 Import cycle: mercurial.filemerge -> mercurial.match -> mercurial.fileset -> mercurial.merge -> mercurial.filemerge
@@ -1,1281 +1,1301
1 Set up a repo
1 Set up a repo
2
2
3 $ echo "[ui]" >> $HGRCPATH
3 $ echo "[ui]" >> $HGRCPATH
4 $ echo "interactive=true" >> $HGRCPATH
4 $ echo "interactive=true" >> $HGRCPATH
5 $ echo "[extensions]" >> $HGRCPATH
5 $ echo "[extensions]" >> $HGRCPATH
6 $ echo "record=" >> $HGRCPATH
6 $ echo "record=" >> $HGRCPATH
7
7
8 $ hg init a
8 $ hg init a
9 $ cd a
9 $ cd a
10
10
11 Select no files
11 Select no files
12
12
13 $ touch empty-rw
13 $ touch empty-rw
14 $ hg add empty-rw
14 $ hg add empty-rw
15
15
16 $ hg record empty-rw<<EOF
16 $ hg record empty-rw<<EOF
17 > n
17 > n
18 > EOF
18 > EOF
19 diff --git a/empty-rw b/empty-rw
19 diff --git a/empty-rw b/empty-rw
20 new file mode 100644
20 new file mode 100644
21 examine changes to 'empty-rw'? [Ynesfdaq?]
21 examine changes to 'empty-rw'? [Ynesfdaq?]
22 no changes to record
22 no changes to record
23
23
24 $ hg tip -p
24 $ hg tip -p
25 changeset: -1:000000000000
25 changeset: -1:000000000000
26 tag: tip
26 tag: tip
27 user:
27 user:
28 date: Thu Jan 01 00:00:00 1970 +0000
28 date: Thu Jan 01 00:00:00 1970 +0000
29
29
30
30
31
31
32 Select files but no hunks
32 Select files but no hunks
33
33
34 $ hg record empty-rw<<EOF
34 $ hg record empty-rw<<EOF
35 > y
35 > y
36 > n
36 > n
37 > EOF
37 > EOF
38 diff --git a/empty-rw b/empty-rw
38 diff --git a/empty-rw b/empty-rw
39 new file mode 100644
39 new file mode 100644
40 examine changes to 'empty-rw'? [Ynesfdaq?]
40 examine changes to 'empty-rw'? [Ynesfdaq?]
41 abort: empty commit message
41 abort: empty commit message
42 [255]
42 [255]
43
43
44 $ hg tip -p
44 $ hg tip -p
45 changeset: -1:000000000000
45 changeset: -1:000000000000
46 tag: tip
46 tag: tip
47 user:
47 user:
48 date: Thu Jan 01 00:00:00 1970 +0000
48 date: Thu Jan 01 00:00:00 1970 +0000
49
49
50
50
51
51
52 Record empty file
52 Record empty file
53
53
54 $ hg record -d '0 0' -m empty empty-rw<<EOF
54 $ hg record -d '0 0' -m empty empty-rw<<EOF
55 > y
55 > y
56 > y
56 > y
57 > EOF
57 > EOF
58 diff --git a/empty-rw b/empty-rw
58 diff --git a/empty-rw b/empty-rw
59 new file mode 100644
59 new file mode 100644
60 examine changes to 'empty-rw'? [Ynesfdaq?]
60 examine changes to 'empty-rw'? [Ynesfdaq?]
61
61
62 $ hg tip -p
62 $ hg tip -p
63 changeset: 0:c0708cf4e46e
63 changeset: 0:c0708cf4e46e
64 tag: tip
64 tag: tip
65 user: test
65 user: test
66 date: Thu Jan 01 00:00:00 1970 +0000
66 date: Thu Jan 01 00:00:00 1970 +0000
67 summary: empty
67 summary: empty
68
68
69
69
70
70
71 Summary shows we updated to the new cset
71 Summary shows we updated to the new cset
72
72
73 $ hg summary
73 $ hg summary
74 parent: 0:c0708cf4e46e tip
74 parent: 0:c0708cf4e46e tip
75 empty
75 empty
76 branch: default
76 branch: default
77 commit: (clean)
77 commit: (clean)
78 update: (current)
78 update: (current)
79
79
80 Rename empty file
80 Rename empty file
81
81
82 $ hg mv empty-rw empty-rename
82 $ hg mv empty-rw empty-rename
83 $ hg record -d '1 0' -m rename<<EOF
83 $ hg record -d '1 0' -m rename<<EOF
84 > y
84 > y
85 > EOF
85 > EOF
86 diff --git a/empty-rw b/empty-rename
86 diff --git a/empty-rw b/empty-rename
87 rename from empty-rw
87 rename from empty-rw
88 rename to empty-rename
88 rename to empty-rename
89 examine changes to 'empty-rw' and 'empty-rename'? [Ynesfdaq?]
89 examine changes to 'empty-rw' and 'empty-rename'? [Ynesfdaq?]
90
90
91 $ hg tip -p
91 $ hg tip -p
92 changeset: 1:d695e8dcb197
92 changeset: 1:d695e8dcb197
93 tag: tip
93 tag: tip
94 user: test
94 user: test
95 date: Thu Jan 01 00:00:01 1970 +0000
95 date: Thu Jan 01 00:00:01 1970 +0000
96 summary: rename
96 summary: rename
97
97
98
98
99
99
100 Copy empty file
100 Copy empty file
101
101
102 $ hg cp empty-rename empty-copy
102 $ hg cp empty-rename empty-copy
103 $ hg record -d '2 0' -m copy<<EOF
103 $ hg record -d '2 0' -m copy<<EOF
104 > y
104 > y
105 > EOF
105 > EOF
106 diff --git a/empty-rename b/empty-copy
106 diff --git a/empty-rename b/empty-copy
107 copy from empty-rename
107 copy from empty-rename
108 copy to empty-copy
108 copy to empty-copy
109 examine changes to 'empty-rename' and 'empty-copy'? [Ynesfdaq?]
109 examine changes to 'empty-rename' and 'empty-copy'? [Ynesfdaq?]
110
110
111 $ hg tip -p
111 $ hg tip -p
112 changeset: 2:1d4b90bea524
112 changeset: 2:1d4b90bea524
113 tag: tip
113 tag: tip
114 user: test
114 user: test
115 date: Thu Jan 01 00:00:02 1970 +0000
115 date: Thu Jan 01 00:00:02 1970 +0000
116 summary: copy
116 summary: copy
117
117
118
118
119
119
120 Delete empty file
120 Delete empty file
121
121
122 $ hg rm empty-copy
122 $ hg rm empty-copy
123 $ hg record -d '3 0' -m delete<<EOF
123 $ hg record -d '3 0' -m delete<<EOF
124 > y
124 > y
125 > EOF
125 > EOF
126 diff --git a/empty-copy b/empty-copy
126 diff --git a/empty-copy b/empty-copy
127 deleted file mode 100644
127 deleted file mode 100644
128 examine changes to 'empty-copy'? [Ynesfdaq?]
128 examine changes to 'empty-copy'? [Ynesfdaq?]
129
129
130 $ hg tip -p
130 $ hg tip -p
131 changeset: 3:b39a238f01a1
131 changeset: 3:b39a238f01a1
132 tag: tip
132 tag: tip
133 user: test
133 user: test
134 date: Thu Jan 01 00:00:03 1970 +0000
134 date: Thu Jan 01 00:00:03 1970 +0000
135 summary: delete
135 summary: delete
136
136
137
137
138
138
139 Add binary file
139 Add binary file
140
140
141 $ hg bundle --base -2 tip.bundle
141 $ hg bundle --base -2 tip.bundle
142 1 changesets found
142 1 changesets found
143 $ hg add tip.bundle
143 $ hg add tip.bundle
144 $ hg record -d '4 0' -m binary<<EOF
144 $ hg record -d '4 0' -m binary<<EOF
145 > y
145 > y
146 > EOF
146 > EOF
147 diff --git a/tip.bundle b/tip.bundle
147 diff --git a/tip.bundle b/tip.bundle
148 new file mode 100644
148 new file mode 100644
149 this is a binary file
149 this is a binary file
150 examine changes to 'tip.bundle'? [Ynesfdaq?]
150 examine changes to 'tip.bundle'? [Ynesfdaq?]
151
151
152 $ hg tip -p
152 $ hg tip -p
153 changeset: 4:ad816da3711e
153 changeset: 4:ad816da3711e
154 tag: tip
154 tag: tip
155 user: test
155 user: test
156 date: Thu Jan 01 00:00:04 1970 +0000
156 date: Thu Jan 01 00:00:04 1970 +0000
157 summary: binary
157 summary: binary
158
158
159 diff -r b39a238f01a1 -r ad816da3711e tip.bundle
159 diff -r b39a238f01a1 -r ad816da3711e tip.bundle
160 Binary file tip.bundle has changed
160 Binary file tip.bundle has changed
161
161
162
162
163 Change binary file
163 Change binary file
164
164
165 $ hg bundle --base -2 tip.bundle
165 $ hg bundle --base -2 tip.bundle
166 1 changesets found
166 1 changesets found
167 $ hg record -d '5 0' -m binary-change<<EOF
167 $ hg record -d '5 0' -m binary-change<<EOF
168 > y
168 > y
169 > EOF
169 > EOF
170 diff --git a/tip.bundle b/tip.bundle
170 diff --git a/tip.bundle b/tip.bundle
171 this modifies a binary file (all or nothing)
171 this modifies a binary file (all or nothing)
172 examine changes to 'tip.bundle'? [Ynesfdaq?]
172 examine changes to 'tip.bundle'? [Ynesfdaq?]
173
173
174 $ hg tip -p
174 $ hg tip -p
175 changeset: 5:dccd6f3eb485
175 changeset: 5:dccd6f3eb485
176 tag: tip
176 tag: tip
177 user: test
177 user: test
178 date: Thu Jan 01 00:00:05 1970 +0000
178 date: Thu Jan 01 00:00:05 1970 +0000
179 summary: binary-change
179 summary: binary-change
180
180
181 diff -r ad816da3711e -r dccd6f3eb485 tip.bundle
181 diff -r ad816da3711e -r dccd6f3eb485 tip.bundle
182 Binary file tip.bundle has changed
182 Binary file tip.bundle has changed
183
183
184
184
185 Rename and change binary file
185 Rename and change binary file
186
186
187 $ hg mv tip.bundle top.bundle
187 $ hg mv tip.bundle top.bundle
188 $ hg bundle --base -2 top.bundle
188 $ hg bundle --base -2 top.bundle
189 1 changesets found
189 1 changesets found
190 $ hg record -d '6 0' -m binary-change-rename<<EOF
190 $ hg record -d '6 0' -m binary-change-rename<<EOF
191 > y
191 > y
192 > EOF
192 > EOF
193 diff --git a/tip.bundle b/top.bundle
193 diff --git a/tip.bundle b/top.bundle
194 rename from tip.bundle
194 rename from tip.bundle
195 rename to top.bundle
195 rename to top.bundle
196 this modifies a binary file (all or nothing)
196 this modifies a binary file (all or nothing)
197 examine changes to 'tip.bundle' and 'top.bundle'? [Ynesfdaq?]
197 examine changes to 'tip.bundle' and 'top.bundle'? [Ynesfdaq?]
198
198
199 $ hg tip -p
199 $ hg tip -p
200 changeset: 6:7fa44105f5b3
200 changeset: 6:7fa44105f5b3
201 tag: tip
201 tag: tip
202 user: test
202 user: test
203 date: Thu Jan 01 00:00:06 1970 +0000
203 date: Thu Jan 01 00:00:06 1970 +0000
204 summary: binary-change-rename
204 summary: binary-change-rename
205
205
206 diff -r dccd6f3eb485 -r 7fa44105f5b3 tip.bundle
206 diff -r dccd6f3eb485 -r 7fa44105f5b3 tip.bundle
207 Binary file tip.bundle has changed
207 Binary file tip.bundle has changed
208 diff -r dccd6f3eb485 -r 7fa44105f5b3 top.bundle
208 diff -r dccd6f3eb485 -r 7fa44105f5b3 top.bundle
209 Binary file top.bundle has changed
209 Binary file top.bundle has changed
210
210
211
211
212 Add plain file
212 Add plain file
213
213
214 $ for i in 1 2 3 4 5 6 7 8 9 10; do
214 $ for i in 1 2 3 4 5 6 7 8 9 10; do
215 > echo $i >> plain
215 > echo $i >> plain
216 > done
216 > done
217
217
218 $ hg add plain
218 $ hg add plain
219 $ hg record -d '7 0' -m plain plain<<EOF
219 $ hg record -d '7 0' -m plain plain<<EOF
220 > y
220 > y
221 > y
221 > y
222 > EOF
222 > EOF
223 diff --git a/plain b/plain
223 diff --git a/plain b/plain
224 new file mode 100644
224 new file mode 100644
225 examine changes to 'plain'? [Ynesfdaq?]
225 examine changes to 'plain'? [Ynesfdaq?]
226
226
227 $ hg tip -p
227 $ hg tip -p
228 changeset: 7:11fb457c1be4
228 changeset: 7:11fb457c1be4
229 tag: tip
229 tag: tip
230 user: test
230 user: test
231 date: Thu Jan 01 00:00:07 1970 +0000
231 date: Thu Jan 01 00:00:07 1970 +0000
232 summary: plain
232 summary: plain
233
233
234 diff -r 7fa44105f5b3 -r 11fb457c1be4 plain
234 diff -r 7fa44105f5b3 -r 11fb457c1be4 plain
235 --- /dev/null Thu Jan 01 00:00:00 1970 +0000
235 --- /dev/null Thu Jan 01 00:00:00 1970 +0000
236 +++ b/plain Thu Jan 01 00:00:07 1970 +0000
236 +++ b/plain Thu Jan 01 00:00:07 1970 +0000
237 @@ -0,0 +1,10 @@
237 @@ -0,0 +1,10 @@
238 +1
238 +1
239 +2
239 +2
240 +3
240 +3
241 +4
241 +4
242 +5
242 +5
243 +6
243 +6
244 +7
244 +7
245 +8
245 +8
246 +9
246 +9
247 +10
247 +10
248
248
249 Modify end of plain file with username unset
249 Modify end of plain file with username unset
250
250
251 $ echo 11 >> plain
251 $ echo 11 >> plain
252 $ unset HGUSER
252 $ unset HGUSER
253 $ hg record --config ui.username= -d '8 0' -m end plain
253 $ hg record --config ui.username= -d '8 0' -m end plain
254 abort: no username supplied (see "hg help config")
254 abort: no username supplied (see "hg help config")
255 [255]
255 [255]
256
256
257
257
258 Modify end of plain file, also test that diffopts are accounted for
258 Modify end of plain file, also test that diffopts are accounted for
259
259
260 $ HGUSER="test"
260 $ HGUSER="test"
261 $ export HGUSER
261 $ export HGUSER
262 $ hg record --config diff.showfunc=true -d '8 0' -m end plain <<EOF
262 $ hg record --config diff.showfunc=true -d '8 0' -m end plain <<EOF
263 > y
263 > y
264 > y
264 > y
265 > EOF
265 > EOF
266 diff --git a/plain b/plain
266 diff --git a/plain b/plain
267 1 hunks, 1 lines changed
267 1 hunks, 1 lines changed
268 examine changes to 'plain'? [Ynesfdaq?]
268 examine changes to 'plain'? [Ynesfdaq?]
269 @@ -8,3 +8,4 @@ 7
269 @@ -8,3 +8,4 @@ 7
270 8
270 8
271 9
271 9
272 10
272 10
273 +11
273 +11
274 record this change to 'plain'? [Ynesfdaq?]
274 record this change to 'plain'? [Ynesfdaq?]
275
275
276 Modify end of plain file, no EOL
276 Modify end of plain file, no EOL
277
277
278 $ hg tip --template '{node}' >> plain
278 $ hg tip --template '{node}' >> plain
279 $ hg record -d '9 0' -m noeol plain <<EOF
279 $ hg record -d '9 0' -m noeol plain <<EOF
280 > y
280 > y
281 > y
281 > y
282 > EOF
282 > EOF
283 diff --git a/plain b/plain
283 diff --git a/plain b/plain
284 1 hunks, 1 lines changed
284 1 hunks, 1 lines changed
285 examine changes to 'plain'? [Ynesfdaq?]
285 examine changes to 'plain'? [Ynesfdaq?]
286 @@ -9,3 +9,4 @@
286 @@ -9,3 +9,4 @@
287 9
287 9
288 10
288 10
289 11
289 11
290 +7264f99c5f5ff3261504828afa4fb4d406c3af54
290 +7264f99c5f5ff3261504828afa4fb4d406c3af54
291 \ No newline at end of file
291 \ No newline at end of file
292 record this change to 'plain'? [Ynesfdaq?]
292 record this change to 'plain'? [Ynesfdaq?]
293
293
294 Modify end of plain file, add EOL
294 Modify end of plain file, add EOL
295
295
296 $ echo >> plain
296 $ echo >> plain
297 $ echo 1 > plain2
297 $ echo 1 > plain2
298 $ hg add plain2
298 $ hg add plain2
299 $ hg record -d '10 0' -m eol plain plain2 <<EOF
299 $ hg record -d '10 0' -m eol plain plain2 <<EOF
300 > y
300 > y
301 > y
301 > y
302 > y
302 > y
303 > EOF
303 > EOF
304 diff --git a/plain b/plain
304 diff --git a/plain b/plain
305 1 hunks, 1 lines changed
305 1 hunks, 1 lines changed
306 examine changes to 'plain'? [Ynesfdaq?]
306 examine changes to 'plain'? [Ynesfdaq?]
307 @@ -9,4 +9,4 @@
307 @@ -9,4 +9,4 @@
308 9
308 9
309 10
309 10
310 11
310 11
311 -7264f99c5f5ff3261504828afa4fb4d406c3af54
311 -7264f99c5f5ff3261504828afa4fb4d406c3af54
312 \ No newline at end of file
312 \ No newline at end of file
313 +7264f99c5f5ff3261504828afa4fb4d406c3af54
313 +7264f99c5f5ff3261504828afa4fb4d406c3af54
314 record change 1/2 to 'plain'? [Ynesfdaq?]
314 record change 1/2 to 'plain'? [Ynesfdaq?]
315 diff --git a/plain2 b/plain2
315 diff --git a/plain2 b/plain2
316 new file mode 100644
316 new file mode 100644
317 examine changes to 'plain2'? [Ynesfdaq?]
317 examine changes to 'plain2'? [Ynesfdaq?]
318
318
319 Modify beginning, trim end, record both, add another file to test
319 Modify beginning, trim end, record both, add another file to test
320 changes numbering
320 changes numbering
321
321
322 $ rm plain
322 $ rm plain
323 $ for i in 2 2 3 4 5 6 7 8 9 10; do
323 $ for i in 2 2 3 4 5 6 7 8 9 10; do
324 > echo $i >> plain
324 > echo $i >> plain
325 > done
325 > done
326 $ echo 2 >> plain2
326 $ echo 2 >> plain2
327
327
328 $ hg record -d '10 0' -m begin-and-end plain plain2 <<EOF
328 $ hg record -d '10 0' -m begin-and-end plain plain2 <<EOF
329 > y
329 > y
330 > y
330 > y
331 > y
331 > y
332 > y
332 > y
333 > y
333 > y
334 > EOF
334 > EOF
335 diff --git a/plain b/plain
335 diff --git a/plain b/plain
336 2 hunks, 3 lines changed
336 2 hunks, 3 lines changed
337 examine changes to 'plain'? [Ynesfdaq?]
337 examine changes to 'plain'? [Ynesfdaq?]
338 @@ -1,4 +1,4 @@
338 @@ -1,4 +1,4 @@
339 -1
339 -1
340 +2
340 +2
341 2
341 2
342 3
342 3
343 4
343 4
344 record change 1/3 to 'plain'? [Ynesfdaq?]
344 record change 1/3 to 'plain'? [Ynesfdaq?]
345 @@ -8,5 +8,3 @@
345 @@ -8,5 +8,3 @@
346 8
346 8
347 9
347 9
348 10
348 10
349 -11
349 -11
350 -7264f99c5f5ff3261504828afa4fb4d406c3af54
350 -7264f99c5f5ff3261504828afa4fb4d406c3af54
351 record change 2/3 to 'plain'? [Ynesfdaq?]
351 record change 2/3 to 'plain'? [Ynesfdaq?]
352 diff --git a/plain2 b/plain2
352 diff --git a/plain2 b/plain2
353 1 hunks, 1 lines changed
353 1 hunks, 1 lines changed
354 examine changes to 'plain2'? [Ynesfdaq?]
354 examine changes to 'plain2'? [Ynesfdaq?]
355 @@ -1,1 +1,2 @@
355 @@ -1,1 +1,2 @@
356 1
356 1
357 +2
357 +2
358 record change 3/3 to 'plain2'? [Ynesfdaq?]
358 record change 3/3 to 'plain2'? [Ynesfdaq?]
359
359
360 $ hg tip -p
360 $ hg tip -p
361 changeset: 11:21df83db12b8
361 changeset: 11:21df83db12b8
362 tag: tip
362 tag: tip
363 user: test
363 user: test
364 date: Thu Jan 01 00:00:10 1970 +0000
364 date: Thu Jan 01 00:00:10 1970 +0000
365 summary: begin-and-end
365 summary: begin-and-end
366
366
367 diff -r ddb8b281c3ff -r 21df83db12b8 plain
367 diff -r ddb8b281c3ff -r 21df83db12b8 plain
368 --- a/plain Thu Jan 01 00:00:10 1970 +0000
368 --- a/plain Thu Jan 01 00:00:10 1970 +0000
369 +++ b/plain Thu Jan 01 00:00:10 1970 +0000
369 +++ b/plain Thu Jan 01 00:00:10 1970 +0000
370 @@ -1,4 +1,4 @@
370 @@ -1,4 +1,4 @@
371 -1
371 -1
372 +2
372 +2
373 2
373 2
374 3
374 3
375 4
375 4
376 @@ -8,5 +8,3 @@
376 @@ -8,5 +8,3 @@
377 8
377 8
378 9
378 9
379 10
379 10
380 -11
380 -11
381 -7264f99c5f5ff3261504828afa4fb4d406c3af54
381 -7264f99c5f5ff3261504828afa4fb4d406c3af54
382 diff -r ddb8b281c3ff -r 21df83db12b8 plain2
382 diff -r ddb8b281c3ff -r 21df83db12b8 plain2
383 --- a/plain2 Thu Jan 01 00:00:10 1970 +0000
383 --- a/plain2 Thu Jan 01 00:00:10 1970 +0000
384 +++ b/plain2 Thu Jan 01 00:00:10 1970 +0000
384 +++ b/plain2 Thu Jan 01 00:00:10 1970 +0000
385 @@ -1,1 +1,2 @@
385 @@ -1,1 +1,2 @@
386 1
386 1
387 +2
387 +2
388
388
389
389
390 Trim beginning, modify end
390 Trim beginning, modify end
391
391
392 $ rm plain
392 $ rm plain
393 > for i in 4 5 6 7 8 9 10.new; do
393 > for i in 4 5 6 7 8 9 10.new; do
394 > echo $i >> plain
394 > echo $i >> plain
395 > done
395 > done
396
396
397 Record end
397 Record end
398
398
399 $ hg record -d '11 0' -m end-only plain <<EOF
399 $ hg record -d '11 0' -m end-only plain <<EOF
400 > y
400 > y
401 > n
401 > n
402 > y
402 > y
403 > EOF
403 > EOF
404 diff --git a/plain b/plain
404 diff --git a/plain b/plain
405 2 hunks, 4 lines changed
405 2 hunks, 4 lines changed
406 examine changes to 'plain'? [Ynesfdaq?]
406 examine changes to 'plain'? [Ynesfdaq?]
407 @@ -1,9 +1,6 @@
407 @@ -1,9 +1,6 @@
408 -2
408 -2
409 -2
409 -2
410 -3
410 -3
411 4
411 4
412 5
412 5
413 6
413 6
414 7
414 7
415 8
415 8
416 9
416 9
417 record change 1/2 to 'plain'? [Ynesfdaq?]
417 record change 1/2 to 'plain'? [Ynesfdaq?]
418 @@ -4,7 +1,7 @@
418 @@ -4,7 +1,7 @@
419 4
419 4
420 5
420 5
421 6
421 6
422 7
422 7
423 8
423 8
424 9
424 9
425 -10
425 -10
426 +10.new
426 +10.new
427 record change 2/2 to 'plain'? [Ynesfdaq?]
427 record change 2/2 to 'plain'? [Ynesfdaq?]
428
428
429 $ hg tip -p
429 $ hg tip -p
430 changeset: 12:99337501826f
430 changeset: 12:99337501826f
431 tag: tip
431 tag: tip
432 user: test
432 user: test
433 date: Thu Jan 01 00:00:11 1970 +0000
433 date: Thu Jan 01 00:00:11 1970 +0000
434 summary: end-only
434 summary: end-only
435
435
436 diff -r 21df83db12b8 -r 99337501826f plain
436 diff -r 21df83db12b8 -r 99337501826f plain
437 --- a/plain Thu Jan 01 00:00:10 1970 +0000
437 --- a/plain Thu Jan 01 00:00:10 1970 +0000
438 +++ b/plain Thu Jan 01 00:00:11 1970 +0000
438 +++ b/plain Thu Jan 01 00:00:11 1970 +0000
439 @@ -7,4 +7,4 @@
439 @@ -7,4 +7,4 @@
440 7
440 7
441 8
441 8
442 9
442 9
443 -10
443 -10
444 +10.new
444 +10.new
445
445
446
446
447 Record beginning
447 Record beginning
448
448
449 $ hg record -d '12 0' -m begin-only plain <<EOF
449 $ hg record -d '12 0' -m begin-only plain <<EOF
450 > y
450 > y
451 > y
451 > y
452 > EOF
452 > EOF
453 diff --git a/plain b/plain
453 diff --git a/plain b/plain
454 1 hunks, 3 lines changed
454 1 hunks, 3 lines changed
455 examine changes to 'plain'? [Ynesfdaq?]
455 examine changes to 'plain'? [Ynesfdaq?]
456 @@ -1,6 +1,3 @@
456 @@ -1,6 +1,3 @@
457 -2
457 -2
458 -2
458 -2
459 -3
459 -3
460 4
460 4
461 5
461 5
462 6
462 6
463 record this change to 'plain'? [Ynesfdaq?]
463 record this change to 'plain'? [Ynesfdaq?]
464
464
465 $ hg tip -p
465 $ hg tip -p
466 changeset: 13:bbd45465d540
466 changeset: 13:bbd45465d540
467 tag: tip
467 tag: tip
468 user: test
468 user: test
469 date: Thu Jan 01 00:00:12 1970 +0000
469 date: Thu Jan 01 00:00:12 1970 +0000
470 summary: begin-only
470 summary: begin-only
471
471
472 diff -r 99337501826f -r bbd45465d540 plain
472 diff -r 99337501826f -r bbd45465d540 plain
473 --- a/plain Thu Jan 01 00:00:11 1970 +0000
473 --- a/plain Thu Jan 01 00:00:11 1970 +0000
474 +++ b/plain Thu Jan 01 00:00:12 1970 +0000
474 +++ b/plain Thu Jan 01 00:00:12 1970 +0000
475 @@ -1,6 +1,3 @@
475 @@ -1,6 +1,3 @@
476 -2
476 -2
477 -2
477 -2
478 -3
478 -3
479 4
479 4
480 5
480 5
481 6
481 6
482
482
483
483
484 Add to beginning, trim from end
484 Add to beginning, trim from end
485
485
486 $ rm plain
486 $ rm plain
487 $ for i in 1 2 3 4 5 6 7 8 9; do
487 $ for i in 1 2 3 4 5 6 7 8 9; do
488 > echo $i >> plain
488 > echo $i >> plain
489 > done
489 > done
490
490
491 Record end
491 Record end
492
492
493 $ hg record --traceback -d '13 0' -m end-again plain<<EOF
493 $ hg record --traceback -d '13 0' -m end-again plain<<EOF
494 > y
494 > y
495 > n
495 > n
496 > y
496 > y
497 > EOF
497 > EOF
498 diff --git a/plain b/plain
498 diff --git a/plain b/plain
499 2 hunks, 4 lines changed
499 2 hunks, 4 lines changed
500 examine changes to 'plain'? [Ynesfdaq?]
500 examine changes to 'plain'? [Ynesfdaq?]
501 @@ -1,6 +1,9 @@
501 @@ -1,6 +1,9 @@
502 +1
502 +1
503 +2
503 +2
504 +3
504 +3
505 4
505 4
506 5
506 5
507 6
507 6
508 7
508 7
509 8
509 8
510 9
510 9
511 record change 1/2 to 'plain'? [Ynesfdaq?]
511 record change 1/2 to 'plain'? [Ynesfdaq?]
512 @@ -1,7 +4,6 @@
512 @@ -1,7 +4,6 @@
513 4
513 4
514 5
514 5
515 6
515 6
516 7
516 7
517 8
517 8
518 9
518 9
519 -10.new
519 -10.new
520 record change 2/2 to 'plain'? [Ynesfdaq?]
520 record change 2/2 to 'plain'? [Ynesfdaq?]
521
521
522 Add to beginning, middle, end
522 Add to beginning, middle, end
523
523
524 $ rm plain
524 $ rm plain
525 $ for i in 1 2 3 4 5 5.new 5.reallynew 6 7 8 9 10 11; do
525 $ for i in 1 2 3 4 5 5.new 5.reallynew 6 7 8 9 10 11; do
526 > echo $i >> plain
526 > echo $i >> plain
527 > done
527 > done
528
528
529 Record beginning, middle
529 Record beginning, middle
530
530
531 $ hg record -d '14 0' -m middle-only plain <<EOF
531 $ hg record -d '14 0' -m middle-only plain <<EOF
532 > y
532 > y
533 > y
533 > y
534 > y
534 > y
535 > n
535 > n
536 > EOF
536 > EOF
537 diff --git a/plain b/plain
537 diff --git a/plain b/plain
538 3 hunks, 7 lines changed
538 3 hunks, 7 lines changed
539 examine changes to 'plain'? [Ynesfdaq?]
539 examine changes to 'plain'? [Ynesfdaq?]
540 @@ -1,2 +1,5 @@
540 @@ -1,2 +1,5 @@
541 +1
541 +1
542 +2
542 +2
543 +3
543 +3
544 4
544 4
545 5
545 5
546 record change 1/3 to 'plain'? [Ynesfdaq?]
546 record change 1/3 to 'plain'? [Ynesfdaq?]
547 @@ -1,6 +4,8 @@
547 @@ -1,6 +4,8 @@
548 4
548 4
549 5
549 5
550 +5.new
550 +5.new
551 +5.reallynew
551 +5.reallynew
552 6
552 6
553 7
553 7
554 8
554 8
555 9
555 9
556 record change 2/3 to 'plain'? [Ynesfdaq?]
556 record change 2/3 to 'plain'? [Ynesfdaq?]
557 @@ -3,4 +8,6 @@
557 @@ -3,4 +8,6 @@
558 6
558 6
559 7
559 7
560 8
560 8
561 9
561 9
562 +10
562 +10
563 +11
563 +11
564 record change 3/3 to 'plain'? [Ynesfdaq?]
564 record change 3/3 to 'plain'? [Ynesfdaq?]
565
565
566 $ hg tip -p
566 $ hg tip -p
567 changeset: 15:f34a7937ec33
567 changeset: 15:f34a7937ec33
568 tag: tip
568 tag: tip
569 user: test
569 user: test
570 date: Thu Jan 01 00:00:14 1970 +0000
570 date: Thu Jan 01 00:00:14 1970 +0000
571 summary: middle-only
571 summary: middle-only
572
572
573 diff -r 82c065d0b850 -r f34a7937ec33 plain
573 diff -r 82c065d0b850 -r f34a7937ec33 plain
574 --- a/plain Thu Jan 01 00:00:13 1970 +0000
574 --- a/plain Thu Jan 01 00:00:13 1970 +0000
575 +++ b/plain Thu Jan 01 00:00:14 1970 +0000
575 +++ b/plain Thu Jan 01 00:00:14 1970 +0000
576 @@ -1,5 +1,10 @@
576 @@ -1,5 +1,10 @@
577 +1
577 +1
578 +2
578 +2
579 +3
579 +3
580 4
580 4
581 5
581 5
582 +5.new
582 +5.new
583 +5.reallynew
583 +5.reallynew
584 6
584 6
585 7
585 7
586 8
586 8
587
587
588
588
589 Record end
589 Record end
590
590
591 $ hg record -d '15 0' -m end-only plain <<EOF
591 $ hg record -d '15 0' -m end-only plain <<EOF
592 > y
592 > y
593 > y
593 > y
594 > EOF
594 > EOF
595 diff --git a/plain b/plain
595 diff --git a/plain b/plain
596 1 hunks, 2 lines changed
596 1 hunks, 2 lines changed
597 examine changes to 'plain'? [Ynesfdaq?]
597 examine changes to 'plain'? [Ynesfdaq?]
598 @@ -9,3 +9,5 @@
598 @@ -9,3 +9,5 @@
599 7
599 7
600 8
600 8
601 9
601 9
602 +10
602 +10
603 +11
603 +11
604 record this change to 'plain'? [Ynesfdaq?]
604 record this change to 'plain'? [Ynesfdaq?]
605
605
606 $ hg tip -p
606 $ hg tip -p
607 changeset: 16:f9900b71a04c
607 changeset: 16:f9900b71a04c
608 tag: tip
608 tag: tip
609 user: test
609 user: test
610 date: Thu Jan 01 00:00:15 1970 +0000
610 date: Thu Jan 01 00:00:15 1970 +0000
611 summary: end-only
611 summary: end-only
612
612
613 diff -r f34a7937ec33 -r f9900b71a04c plain
613 diff -r f34a7937ec33 -r f9900b71a04c plain
614 --- a/plain Thu Jan 01 00:00:14 1970 +0000
614 --- a/plain Thu Jan 01 00:00:14 1970 +0000
615 +++ b/plain Thu Jan 01 00:00:15 1970 +0000
615 +++ b/plain Thu Jan 01 00:00:15 1970 +0000
616 @@ -9,3 +9,5 @@
616 @@ -9,3 +9,5 @@
617 7
617 7
618 8
618 8
619 9
619 9
620 +10
620 +10
621 +11
621 +11
622
622
623
623
624 $ mkdir subdir
624 $ mkdir subdir
625 $ cd subdir
625 $ cd subdir
626 $ echo a > a
626 $ echo a > a
627 $ hg ci -d '16 0' -Amsubdir
627 $ hg ci -d '16 0' -Amsubdir
628 adding subdir/a
628 adding subdir/a
629
629
630 $ echo a >> a
630 $ echo a >> a
631 $ hg record -d '16 0' -m subdir-change a <<EOF
631 $ hg record -d '16 0' -m subdir-change a <<EOF
632 > y
632 > y
633 > y
633 > y
634 > EOF
634 > EOF
635 diff --git a/subdir/a b/subdir/a
635 diff --git a/subdir/a b/subdir/a
636 1 hunks, 1 lines changed
636 1 hunks, 1 lines changed
637 examine changes to 'subdir/a'? [Ynesfdaq?]
637 examine changes to 'subdir/a'? [Ynesfdaq?]
638 @@ -1,1 +1,2 @@
638 @@ -1,1 +1,2 @@
639 a
639 a
640 +a
640 +a
641 record this change to 'subdir/a'? [Ynesfdaq?]
641 record this change to 'subdir/a'? [Ynesfdaq?]
642
642
643 $ hg tip -p
643 $ hg tip -p
644 changeset: 18:61be427a9deb
644 changeset: 18:61be427a9deb
645 tag: tip
645 tag: tip
646 user: test
646 user: test
647 date: Thu Jan 01 00:00:16 1970 +0000
647 date: Thu Jan 01 00:00:16 1970 +0000
648 summary: subdir-change
648 summary: subdir-change
649
649
650 diff -r a7ffae4d61cb -r 61be427a9deb subdir/a
650 diff -r a7ffae4d61cb -r 61be427a9deb subdir/a
651 --- a/subdir/a Thu Jan 01 00:00:16 1970 +0000
651 --- a/subdir/a Thu Jan 01 00:00:16 1970 +0000
652 +++ b/subdir/a Thu Jan 01 00:00:16 1970 +0000
652 +++ b/subdir/a Thu Jan 01 00:00:16 1970 +0000
653 @@ -1,1 +1,2 @@
653 @@ -1,1 +1,2 @@
654 a
654 a
655 +a
655 +a
656
656
657
657
658 $ echo a > f1
658 $ echo a > f1
659 $ echo b > f2
659 $ echo b > f2
660 $ hg add f1 f2
660 $ hg add f1 f2
661
661
662 $ hg ci -mz -d '17 0'
662 $ hg ci -mz -d '17 0'
663
663
664 $ echo a >> f1
664 $ echo a >> f1
665 $ echo b >> f2
665 $ echo b >> f2
666
666
667 Help, quit
667 Help, quit
668
668
669 $ hg record <<EOF
669 $ hg record <<EOF
670 > ?
670 > ?
671 > q
671 > q
672 > EOF
672 > EOF
673 diff --git a/subdir/f1 b/subdir/f1
673 diff --git a/subdir/f1 b/subdir/f1
674 1 hunks, 1 lines changed
674 1 hunks, 1 lines changed
675 examine changes to 'subdir/f1'? [Ynesfdaq?]
675 examine changes to 'subdir/f1'? [Ynesfdaq?]
676 y - record this change
676 y - record this change
677 n - skip this change
677 n - skip this change
678 e - edit this change manually
678 e - edit this change manually
679 s - skip remaining changes to this file
679 s - skip remaining changes to this file
680 f - record remaining changes to this file
680 f - record remaining changes to this file
681 d - done, skip remaining changes and files
681 d - done, skip remaining changes and files
682 a - record all changes to all remaining files
682 a - record all changes to all remaining files
683 q - quit, recording no changes
683 q - quit, recording no changes
684 ? - display help
684 ? - display help
685 examine changes to 'subdir/f1'? [Ynesfdaq?]
685 examine changes to 'subdir/f1'? [Ynesfdaq?]
686 abort: user quit
686 abort: user quit
687 [255]
687 [255]
688
688
689 Skip
689 Skip
690
690
691 $ hg record <<EOF
691 $ hg record <<EOF
692 > s
692 > s
693 > EOF
693 > EOF
694 diff --git a/subdir/f1 b/subdir/f1
694 diff --git a/subdir/f1 b/subdir/f1
695 1 hunks, 1 lines changed
695 1 hunks, 1 lines changed
696 examine changes to 'subdir/f1'? [Ynesfdaq?]
696 examine changes to 'subdir/f1'? [Ynesfdaq?]
697 diff --git a/subdir/f2 b/subdir/f2
697 diff --git a/subdir/f2 b/subdir/f2
698 1 hunks, 1 lines changed
698 1 hunks, 1 lines changed
699 examine changes to 'subdir/f2'? [Ynesfdaq?] abort: response expected
699 examine changes to 'subdir/f2'? [Ynesfdaq?] abort: response expected
700 [255]
700 [255]
701
701
702 No
702 No
703
703
704 $ hg record <<EOF
704 $ hg record <<EOF
705 > n
705 > n
706 > EOF
706 > EOF
707 diff --git a/subdir/f1 b/subdir/f1
707 diff --git a/subdir/f1 b/subdir/f1
708 1 hunks, 1 lines changed
708 1 hunks, 1 lines changed
709 examine changes to 'subdir/f1'? [Ynesfdaq?]
709 examine changes to 'subdir/f1'? [Ynesfdaq?]
710 diff --git a/subdir/f2 b/subdir/f2
710 diff --git a/subdir/f2 b/subdir/f2
711 1 hunks, 1 lines changed
711 1 hunks, 1 lines changed
712 examine changes to 'subdir/f2'? [Ynesfdaq?] abort: response expected
712 examine changes to 'subdir/f2'? [Ynesfdaq?] abort: response expected
713 [255]
713 [255]
714
714
715 f, quit
715 f, quit
716
716
717 $ hg record <<EOF
717 $ hg record <<EOF
718 > f
718 > f
719 > q
719 > q
720 > EOF
720 > EOF
721 diff --git a/subdir/f1 b/subdir/f1
721 diff --git a/subdir/f1 b/subdir/f1
722 1 hunks, 1 lines changed
722 1 hunks, 1 lines changed
723 examine changes to 'subdir/f1'? [Ynesfdaq?]
723 examine changes to 'subdir/f1'? [Ynesfdaq?]
724 diff --git a/subdir/f2 b/subdir/f2
724 diff --git a/subdir/f2 b/subdir/f2
725 1 hunks, 1 lines changed
725 1 hunks, 1 lines changed
726 examine changes to 'subdir/f2'? [Ynesfdaq?]
726 examine changes to 'subdir/f2'? [Ynesfdaq?]
727 abort: user quit
727 abort: user quit
728 [255]
728 [255]
729
729
730 s, all
730 s, all
731
731
732 $ hg record -d '18 0' -mx <<EOF
732 $ hg record -d '18 0' -mx <<EOF
733 > s
733 > s
734 > a
734 > a
735 > EOF
735 > EOF
736 diff --git a/subdir/f1 b/subdir/f1
736 diff --git a/subdir/f1 b/subdir/f1
737 1 hunks, 1 lines changed
737 1 hunks, 1 lines changed
738 examine changes to 'subdir/f1'? [Ynesfdaq?]
738 examine changes to 'subdir/f1'? [Ynesfdaq?]
739 diff --git a/subdir/f2 b/subdir/f2
739 diff --git a/subdir/f2 b/subdir/f2
740 1 hunks, 1 lines changed
740 1 hunks, 1 lines changed
741 examine changes to 'subdir/f2'? [Ynesfdaq?]
741 examine changes to 'subdir/f2'? [Ynesfdaq?]
742
742
743 $ hg tip -p
743 $ hg tip -p
744 changeset: 20:b3df3dda369a
744 changeset: 20:b3df3dda369a
745 tag: tip
745 tag: tip
746 user: test
746 user: test
747 date: Thu Jan 01 00:00:18 1970 +0000
747 date: Thu Jan 01 00:00:18 1970 +0000
748 summary: x
748 summary: x
749
749
750 diff -r 6e02d6c9906d -r b3df3dda369a subdir/f2
750 diff -r 6e02d6c9906d -r b3df3dda369a subdir/f2
751 --- a/subdir/f2 Thu Jan 01 00:00:17 1970 +0000
751 --- a/subdir/f2 Thu Jan 01 00:00:17 1970 +0000
752 +++ b/subdir/f2 Thu Jan 01 00:00:18 1970 +0000
752 +++ b/subdir/f2 Thu Jan 01 00:00:18 1970 +0000
753 @@ -1,1 +1,2 @@
753 @@ -1,1 +1,2 @@
754 b
754 b
755 +b
755 +b
756
756
757
757
758 f
758 f
759
759
760 $ hg record -d '19 0' -my <<EOF
760 $ hg record -d '19 0' -my <<EOF
761 > f
761 > f
762 > EOF
762 > EOF
763 diff --git a/subdir/f1 b/subdir/f1
763 diff --git a/subdir/f1 b/subdir/f1
764 1 hunks, 1 lines changed
764 1 hunks, 1 lines changed
765 examine changes to 'subdir/f1'? [Ynesfdaq?]
765 examine changes to 'subdir/f1'? [Ynesfdaq?]
766
766
767 $ hg tip -p
767 $ hg tip -p
768 changeset: 21:38ec577f126b
768 changeset: 21:38ec577f126b
769 tag: tip
769 tag: tip
770 user: test
770 user: test
771 date: Thu Jan 01 00:00:19 1970 +0000
771 date: Thu Jan 01 00:00:19 1970 +0000
772 summary: y
772 summary: y
773
773
774 diff -r b3df3dda369a -r 38ec577f126b subdir/f1
774 diff -r b3df3dda369a -r 38ec577f126b subdir/f1
775 --- a/subdir/f1 Thu Jan 01 00:00:18 1970 +0000
775 --- a/subdir/f1 Thu Jan 01 00:00:18 1970 +0000
776 +++ b/subdir/f1 Thu Jan 01 00:00:19 1970 +0000
776 +++ b/subdir/f1 Thu Jan 01 00:00:19 1970 +0000
777 @@ -1,1 +1,2 @@
777 @@ -1,1 +1,2 @@
778 a
778 a
779 +a
779 +a
780
780
781
781
782 #if execbit
782 #if execbit
783
783
784 Preserve chmod +x
784 Preserve chmod +x
785
785
786 $ chmod +x f1
786 $ chmod +x f1
787 $ echo a >> f1
787 $ echo a >> f1
788 $ hg record -d '20 0' -mz <<EOF
788 $ hg record -d '20 0' -mz <<EOF
789 > y
789 > y
790 > y
790 > y
791 > y
791 > y
792 > EOF
792 > EOF
793 diff --git a/subdir/f1 b/subdir/f1
793 diff --git a/subdir/f1 b/subdir/f1
794 old mode 100644
794 old mode 100644
795 new mode 100755
795 new mode 100755
796 1 hunks, 1 lines changed
796 1 hunks, 1 lines changed
797 examine changes to 'subdir/f1'? [Ynesfdaq?]
797 examine changes to 'subdir/f1'? [Ynesfdaq?]
798 @@ -1,2 +1,3 @@
798 @@ -1,2 +1,3 @@
799 a
799 a
800 a
800 a
801 +a
801 +a
802 record this change to 'subdir/f1'? [Ynesfdaq?]
802 record this change to 'subdir/f1'? [Ynesfdaq?]
803
803
804 $ hg tip --config diff.git=True -p
804 $ hg tip --config diff.git=True -p
805 changeset: 22:3261adceb075
805 changeset: 22:3261adceb075
806 tag: tip
806 tag: tip
807 user: test
807 user: test
808 date: Thu Jan 01 00:00:20 1970 +0000
808 date: Thu Jan 01 00:00:20 1970 +0000
809 summary: z
809 summary: z
810
810
811 diff --git a/subdir/f1 b/subdir/f1
811 diff --git a/subdir/f1 b/subdir/f1
812 old mode 100644
812 old mode 100644
813 new mode 100755
813 new mode 100755
814 --- a/subdir/f1
814 --- a/subdir/f1
815 +++ b/subdir/f1
815 +++ b/subdir/f1
816 @@ -1,2 +1,3 @@
816 @@ -1,2 +1,3 @@
817 a
817 a
818 a
818 a
819 +a
819 +a
820
820
821
821
822 Preserve execute permission on original
822 Preserve execute permission on original
823
823
824 $ echo b >> f1
824 $ echo b >> f1
825 $ hg record -d '21 0' -maa <<EOF
825 $ hg record -d '21 0' -maa <<EOF
826 > y
826 > y
827 > y
827 > y
828 > y
828 > y
829 > EOF
829 > EOF
830 diff --git a/subdir/f1 b/subdir/f1
830 diff --git a/subdir/f1 b/subdir/f1
831 1 hunks, 1 lines changed
831 1 hunks, 1 lines changed
832 examine changes to 'subdir/f1'? [Ynesfdaq?]
832 examine changes to 'subdir/f1'? [Ynesfdaq?]
833 @@ -1,3 +1,4 @@
833 @@ -1,3 +1,4 @@
834 a
834 a
835 a
835 a
836 a
836 a
837 +b
837 +b
838 record this change to 'subdir/f1'? [Ynesfdaq?]
838 record this change to 'subdir/f1'? [Ynesfdaq?]
839
839
840 $ hg tip --config diff.git=True -p
840 $ hg tip --config diff.git=True -p
841 changeset: 23:b429867550db
841 changeset: 23:b429867550db
842 tag: tip
842 tag: tip
843 user: test
843 user: test
844 date: Thu Jan 01 00:00:21 1970 +0000
844 date: Thu Jan 01 00:00:21 1970 +0000
845 summary: aa
845 summary: aa
846
846
847 diff --git a/subdir/f1 b/subdir/f1
847 diff --git a/subdir/f1 b/subdir/f1
848 --- a/subdir/f1
848 --- a/subdir/f1
849 +++ b/subdir/f1
849 +++ b/subdir/f1
850 @@ -1,3 +1,4 @@
850 @@ -1,3 +1,4 @@
851 a
851 a
852 a
852 a
853 a
853 a
854 +b
854 +b
855
855
856
856
857 Preserve chmod -x
857 Preserve chmod -x
858
858
859 $ chmod -x f1
859 $ chmod -x f1
860 $ echo c >> f1
860 $ echo c >> f1
861 $ hg record -d '22 0' -mab <<EOF
861 $ hg record -d '22 0' -mab <<EOF
862 > y
862 > y
863 > y
863 > y
864 > y
864 > y
865 > EOF
865 > EOF
866 diff --git a/subdir/f1 b/subdir/f1
866 diff --git a/subdir/f1 b/subdir/f1
867 old mode 100755
867 old mode 100755
868 new mode 100644
868 new mode 100644
869 1 hunks, 1 lines changed
869 1 hunks, 1 lines changed
870 examine changes to 'subdir/f1'? [Ynesfdaq?]
870 examine changes to 'subdir/f1'? [Ynesfdaq?]
871 @@ -2,3 +2,4 @@
871 @@ -2,3 +2,4 @@
872 a
872 a
873 a
873 a
874 b
874 b
875 +c
875 +c
876 record this change to 'subdir/f1'? [Ynesfdaq?]
876 record this change to 'subdir/f1'? [Ynesfdaq?]
877
877
878 $ hg tip --config diff.git=True -p
878 $ hg tip --config diff.git=True -p
879 changeset: 24:0b082130c20a
879 changeset: 24:0b082130c20a
880 tag: tip
880 tag: tip
881 user: test
881 user: test
882 date: Thu Jan 01 00:00:22 1970 +0000
882 date: Thu Jan 01 00:00:22 1970 +0000
883 summary: ab
883 summary: ab
884
884
885 diff --git a/subdir/f1 b/subdir/f1
885 diff --git a/subdir/f1 b/subdir/f1
886 old mode 100755
886 old mode 100755
887 new mode 100644
887 new mode 100644
888 --- a/subdir/f1
888 --- a/subdir/f1
889 +++ b/subdir/f1
889 +++ b/subdir/f1
890 @@ -2,3 +2,4 @@
890 @@ -2,3 +2,4 @@
891 a
891 a
892 a
892 a
893 b
893 b
894 +c
894 +c
895
895
896
896
897 #else
897 #else
898
898
899 Slightly bogus tests to get almost same repo structure as when x bit is used
899 Slightly bogus tests to get almost same repo structure as when x bit is used
900 - but with different hashes.
900 - but with different hashes.
901
901
902 Mock "Preserve chmod +x"
902 Mock "Preserve chmod +x"
903
903
904 $ echo a >> f1
904 $ echo a >> f1
905 $ hg record -d '20 0' -mz <<EOF
905 $ hg record -d '20 0' -mz <<EOF
906 > y
906 > y
907 > y
907 > y
908 > y
908 > y
909 > EOF
909 > EOF
910 diff --git a/subdir/f1 b/subdir/f1
910 diff --git a/subdir/f1 b/subdir/f1
911 1 hunks, 1 lines changed
911 1 hunks, 1 lines changed
912 examine changes to 'subdir/f1'? [Ynesfdaq?]
912 examine changes to 'subdir/f1'? [Ynesfdaq?]
913 @@ -1,2 +1,3 @@
913 @@ -1,2 +1,3 @@
914 a
914 a
915 a
915 a
916 +a
916 +a
917 record this change to 'subdir/f1'? [Ynesfdaq?]
917 record this change to 'subdir/f1'? [Ynesfdaq?]
918
918
919 $ hg tip --config diff.git=True -p
919 $ hg tip --config diff.git=True -p
920 changeset: 22:0d463bd428f5
920 changeset: 22:0d463bd428f5
921 tag: tip
921 tag: tip
922 user: test
922 user: test
923 date: Thu Jan 01 00:00:20 1970 +0000
923 date: Thu Jan 01 00:00:20 1970 +0000
924 summary: z
924 summary: z
925
925
926 diff --git a/subdir/f1 b/subdir/f1
926 diff --git a/subdir/f1 b/subdir/f1
927 --- a/subdir/f1
927 --- a/subdir/f1
928 +++ b/subdir/f1
928 +++ b/subdir/f1
929 @@ -1,2 +1,3 @@
929 @@ -1,2 +1,3 @@
930 a
930 a
931 a
931 a
932 +a
932 +a
933
933
934
934
935 Mock "Preserve execute permission on original"
935 Mock "Preserve execute permission on original"
936
936
937 $ echo b >> f1
937 $ echo b >> f1
938 $ hg record -d '21 0' -maa <<EOF
938 $ hg record -d '21 0' -maa <<EOF
939 > y
939 > y
940 > y
940 > y
941 > y
941 > y
942 > EOF
942 > EOF
943 diff --git a/subdir/f1 b/subdir/f1
943 diff --git a/subdir/f1 b/subdir/f1
944 1 hunks, 1 lines changed
944 1 hunks, 1 lines changed
945 examine changes to 'subdir/f1'? [Ynesfdaq?]
945 examine changes to 'subdir/f1'? [Ynesfdaq?]
946 @@ -1,3 +1,4 @@
946 @@ -1,3 +1,4 @@
947 a
947 a
948 a
948 a
949 a
949 a
950 +b
950 +b
951 record this change to 'subdir/f1'? [Ynesfdaq?]
951 record this change to 'subdir/f1'? [Ynesfdaq?]
952
952
953 $ hg tip --config diff.git=True -p
953 $ hg tip --config diff.git=True -p
954 changeset: 23:0eab41a3e524
954 changeset: 23:0eab41a3e524
955 tag: tip
955 tag: tip
956 user: test
956 user: test
957 date: Thu Jan 01 00:00:21 1970 +0000
957 date: Thu Jan 01 00:00:21 1970 +0000
958 summary: aa
958 summary: aa
959
959
960 diff --git a/subdir/f1 b/subdir/f1
960 diff --git a/subdir/f1 b/subdir/f1
961 --- a/subdir/f1
961 --- a/subdir/f1
962 +++ b/subdir/f1
962 +++ b/subdir/f1
963 @@ -1,3 +1,4 @@
963 @@ -1,3 +1,4 @@
964 a
964 a
965 a
965 a
966 a
966 a
967 +b
967 +b
968
968
969
969
970 Mock "Preserve chmod -x"
970 Mock "Preserve chmod -x"
971
971
972 $ chmod -x f1
972 $ chmod -x f1
973 $ echo c >> f1
973 $ echo c >> f1
974 $ hg record -d '22 0' -mab <<EOF
974 $ hg record -d '22 0' -mab <<EOF
975 > y
975 > y
976 > y
976 > y
977 > y
977 > y
978 > EOF
978 > EOF
979 diff --git a/subdir/f1 b/subdir/f1
979 diff --git a/subdir/f1 b/subdir/f1
980 1 hunks, 1 lines changed
980 1 hunks, 1 lines changed
981 examine changes to 'subdir/f1'? [Ynesfdaq?]
981 examine changes to 'subdir/f1'? [Ynesfdaq?]
982 @@ -2,3 +2,4 @@
982 @@ -2,3 +2,4 @@
983 a
983 a
984 a
984 a
985 b
985 b
986 +c
986 +c
987 record this change to 'subdir/f1'? [Ynesfdaq?]
987 record this change to 'subdir/f1'? [Ynesfdaq?]
988
988
989 $ hg tip --config diff.git=True -p
989 $ hg tip --config diff.git=True -p
990 changeset: 24:f4f718f27b7c
990 changeset: 24:f4f718f27b7c
991 tag: tip
991 tag: tip
992 user: test
992 user: test
993 date: Thu Jan 01 00:00:22 1970 +0000
993 date: Thu Jan 01 00:00:22 1970 +0000
994 summary: ab
994 summary: ab
995
995
996 diff --git a/subdir/f1 b/subdir/f1
996 diff --git a/subdir/f1 b/subdir/f1
997 --- a/subdir/f1
997 --- a/subdir/f1
998 +++ b/subdir/f1
998 +++ b/subdir/f1
999 @@ -2,3 +2,4 @@
999 @@ -2,3 +2,4 @@
1000 a
1000 a
1001 a
1001 a
1002 b
1002 b
1003 +c
1003 +c
1004
1004
1005
1005
1006 #endif
1006 #endif
1007
1007
1008 $ cd ..
1008 $ cd ..
1009
1009
1010
1010
1011 Abort early when a merge is in progress
1011 Abort early when a merge is in progress
1012
1012
1013 $ hg up 4
1013 $ hg up 4
1014 1 files updated, 0 files merged, 6 files removed, 0 files unresolved
1014 1 files updated, 0 files merged, 6 files removed, 0 files unresolved
1015
1015
1016 $ touch iwillmergethat
1016 $ touch iwillmergethat
1017 $ hg add iwillmergethat
1017 $ hg add iwillmergethat
1018
1018
1019 $ hg branch thatbranch
1019 $ hg branch thatbranch
1020 marked working directory as branch thatbranch
1020 marked working directory as branch thatbranch
1021 (branches are permanent and global, did you want a bookmark?)
1021 (branches are permanent and global, did you want a bookmark?)
1022
1022
1023 $ hg ci -m'new head'
1023 $ hg ci -m'new head'
1024
1024
1025 $ hg up default
1025 $ hg up default
1026 6 files updated, 0 files merged, 2 files removed, 0 files unresolved
1026 6 files updated, 0 files merged, 2 files removed, 0 files unresolved
1027
1027
1028 $ hg merge thatbranch
1028 $ hg merge thatbranch
1029 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
1029 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
1030 (branch merge, don't forget to commit)
1030 (branch merge, don't forget to commit)
1031
1031
1032 $ hg record -m'will abort'
1032 $ hg record -m'will abort'
1033 abort: cannot partially commit a merge (use "hg commit" instead)
1033 abort: cannot partially commit a merge (use "hg commit" instead)
1034 [255]
1034 [255]
1035
1035
1036 $ hg up -C
1036 $ hg up -C
1037 0 files updated, 0 files merged, 1 files removed, 0 files unresolved
1037 0 files updated, 0 files merged, 1 files removed, 0 files unresolved
1038
1038
1039 Editing patch (and ignoring trailing text)
1039 Editing patch (and ignoring trailing text)
1040
1040
1041 $ cat > editor.sh << '__EOF__'
1041 $ cat > editor.sh << '__EOF__'
1042 > sed -e 7d -e '5s/^-/ /' -e '/^# ---/i\
1042 > sed -e 7d -e '5s/^-/ /' -e '/^# ---/i\
1043 > trailing\nditto' "$1" > tmp
1043 > trailing\nditto' "$1" > tmp
1044 > mv tmp "$1"
1044 > mv tmp "$1"
1045 > __EOF__
1045 > __EOF__
1046 $ cat > editedfile << '__EOF__'
1046 $ cat > editedfile << '__EOF__'
1047 > This is the first line
1047 > This is the first line
1048 > This is the second line
1048 > This is the second line
1049 > This is the third line
1049 > This is the third line
1050 > __EOF__
1050 > __EOF__
1051 $ hg add editedfile
1051 $ hg add editedfile
1052 $ hg commit -medit-patch-1
1052 $ hg commit -medit-patch-1
1053 $ cat > editedfile << '__EOF__'
1053 $ cat > editedfile << '__EOF__'
1054 > This line has changed
1054 > This line has changed
1055 > This change will be committed
1055 > This change will be committed
1056 > This is the third line
1056 > This is the third line
1057 > __EOF__
1057 > __EOF__
1058 $ HGEDITOR="\"sh\" \"`pwd`/editor.sh\"" hg record -d '23 0' -medit-patch-2 <<EOF
1058 $ HGEDITOR="\"sh\" \"`pwd`/editor.sh\"" hg record -d '23 0' -medit-patch-2 <<EOF
1059 > y
1059 > y
1060 > e
1060 > e
1061 > EOF
1061 > EOF
1062 diff --git a/editedfile b/editedfile
1062 diff --git a/editedfile b/editedfile
1063 1 hunks, 2 lines changed
1063 1 hunks, 2 lines changed
1064 examine changes to 'editedfile'? [Ynesfdaq?]
1064 examine changes to 'editedfile'? [Ynesfdaq?]
1065 @@ -1,3 +1,3 @@
1065 @@ -1,3 +1,3 @@
1066 -This is the first line
1066 -This is the first line
1067 -This is the second line
1067 -This is the second line
1068 +This line has changed
1068 +This line has changed
1069 +This change will be committed
1069 +This change will be committed
1070 This is the third line
1070 This is the third line
1071 record this change to 'editedfile'? [Ynesfdaq?]
1071 record this change to 'editedfile'? [Ynesfdaq?]
1072 $ cat editedfile
1072 $ cat editedfile
1073 This line has changed
1073 This line has changed
1074 This change will be committed
1074 This change will be committed
1075 This is the third line
1075 This is the third line
1076 $ hg cat -r tip editedfile
1076 $ hg cat -r tip editedfile
1077 This is the first line
1077 This is the first line
1078 This change will be committed
1078 This change will be committed
1079 This is the third line
1079 This is the third line
1080 $ hg revert editedfile
1080 $ hg revert editedfile
1081
1081
1082 Trying to edit patch for whole file
1082 Trying to edit patch for whole file
1083
1083
1084 $ echo "This is the fourth line" >> editedfile
1084 $ echo "This is the fourth line" >> editedfile
1085 $ hg record <<EOF
1085 $ hg record <<EOF
1086 > e
1086 > e
1087 > q
1087 > q
1088 > EOF
1088 > EOF
1089 diff --git a/editedfile b/editedfile
1089 diff --git a/editedfile b/editedfile
1090 1 hunks, 1 lines changed
1090 1 hunks, 1 lines changed
1091 examine changes to 'editedfile'? [Ynesfdaq?]
1091 examine changes to 'editedfile'? [Ynesfdaq?]
1092 cannot edit patch for whole file
1092 cannot edit patch for whole file
1093 examine changes to 'editedfile'? [Ynesfdaq?]
1093 examine changes to 'editedfile'? [Ynesfdaq?]
1094 abort: user quit
1094 abort: user quit
1095 [255]
1095 [255]
1096 $ hg revert editedfile
1096 $ hg revert editedfile
1097
1097
1098 Removing changes from patch
1098 Removing changes from patch
1099
1099
1100 $ sed -e '3s/third/second/' -e '2s/will/will not/' -e 1d editedfile > tmp
1100 $ sed -e '3s/third/second/' -e '2s/will/will not/' -e 1d editedfile > tmp
1101 $ mv tmp editedfile
1101 $ mv tmp editedfile
1102 $ echo "This line has been added" >> editedfile
1102 $ echo "This line has been added" >> editedfile
1103 $ cat > editor.sh << '__EOF__'
1103 $ cat > editor.sh << '__EOF__'
1104 > sed -e 's/^[-+]/ /' "$1" > tmp
1104 > sed -e 's/^[-+]/ /' "$1" > tmp
1105 > mv tmp "$1"
1105 > mv tmp "$1"
1106 > __EOF__
1106 > __EOF__
1107 $ HGEDITOR="\"sh\" \"`pwd`/editor.sh\"" hg record <<EOF
1107 $ HGEDITOR="\"sh\" \"`pwd`/editor.sh\"" hg record <<EOF
1108 > y
1108 > y
1109 > e
1109 > e
1110 > EOF
1110 > EOF
1111 diff --git a/editedfile b/editedfile
1111 diff --git a/editedfile b/editedfile
1112 1 hunks, 3 lines changed
1112 1 hunks, 3 lines changed
1113 examine changes to 'editedfile'? [Ynesfdaq?]
1113 examine changes to 'editedfile'? [Ynesfdaq?]
1114 @@ -1,3 +1,3 @@
1114 @@ -1,3 +1,3 @@
1115 -This is the first line
1115 -This is the first line
1116 -This change will be committed
1116 -This change will be committed
1117 -This is the third line
1117 -This is the third line
1118 +This change will not be committed
1118 +This change will not be committed
1119 +This is the second line
1119 +This is the second line
1120 +This line has been added
1120 +This line has been added
1121 record this change to 'editedfile'? [Ynesfdaq?]
1121 record this change to 'editedfile'? [Ynesfdaq?]
1122 no changes to record
1122 no changes to record
1123 $ cat editedfile
1123 $ cat editedfile
1124 This change will not be committed
1124 This change will not be committed
1125 This is the second line
1125 This is the second line
1126 This line has been added
1126 This line has been added
1127 $ hg cat -r tip editedfile
1127 $ hg cat -r tip editedfile
1128 This is the first line
1128 This is the first line
1129 This change will be committed
1129 This change will be committed
1130 This is the third line
1130 This is the third line
1131 $ hg revert editedfile
1131 $ hg revert editedfile
1132
1132
1133 Invalid patch
1133 Invalid patch
1134
1134
1135 $ sed -e '3s/third/second/' -e '2s/will/will not/' -e 1d editedfile > tmp
1135 $ sed -e '3s/third/second/' -e '2s/will/will not/' -e 1d editedfile > tmp
1136 $ mv tmp editedfile
1136 $ mv tmp editedfile
1137 $ echo "This line has been added" >> editedfile
1137 $ echo "This line has been added" >> editedfile
1138 $ cat > editor.sh << '__EOF__'
1138 $ cat > editor.sh << '__EOF__'
1139 > sed s/This/That/ "$1" > tmp
1139 > sed s/This/That/ "$1" > tmp
1140 > mv tmp "$1"
1140 > mv tmp "$1"
1141 > __EOF__
1141 > __EOF__
1142 $ HGEDITOR="\"sh\" \"`pwd`/editor.sh\"" hg record <<EOF
1142 $ HGEDITOR="\"sh\" \"`pwd`/editor.sh\"" hg record <<EOF
1143 > y
1143 > y
1144 > e
1144 > e
1145 > EOF
1145 > EOF
1146 diff --git a/editedfile b/editedfile
1146 diff --git a/editedfile b/editedfile
1147 1 hunks, 3 lines changed
1147 1 hunks, 3 lines changed
1148 examine changes to 'editedfile'? [Ynesfdaq?]
1148 examine changes to 'editedfile'? [Ynesfdaq?]
1149 @@ -1,3 +1,3 @@
1149 @@ -1,3 +1,3 @@
1150 -This is the first line
1150 -This is the first line
1151 -This change will be committed
1151 -This change will be committed
1152 -This is the third line
1152 -This is the third line
1153 +This change will not be committed
1153 +This change will not be committed
1154 +This is the second line
1154 +This is the second line
1155 +This line has been added
1155 +This line has been added
1156 record this change to 'editedfile'? [Ynesfdaq?]
1156 record this change to 'editedfile'? [Ynesfdaq?]
1157 patching file editedfile
1157 patching file editedfile
1158 Hunk #1 FAILED at 0
1158 Hunk #1 FAILED at 0
1159 1 out of 1 hunks FAILED -- saving rejects to file editedfile.rej
1159 1 out of 1 hunks FAILED -- saving rejects to file editedfile.rej
1160 abort: patch failed to apply
1160 abort: patch failed to apply
1161 [255]
1161 [255]
1162 $ cat editedfile
1162 $ cat editedfile
1163 This change will not be committed
1163 This change will not be committed
1164 This is the second line
1164 This is the second line
1165 This line has been added
1165 This line has been added
1166 $ hg cat -r tip editedfile
1166 $ hg cat -r tip editedfile
1167 This is the first line
1167 This is the first line
1168 This change will be committed
1168 This change will be committed
1169 This is the third line
1169 This is the third line
1170 $ cat editedfile.rej
1170 $ cat editedfile.rej
1171 --- editedfile
1171 --- editedfile
1172 +++ editedfile
1172 +++ editedfile
1173 @@ -1,3 +1,3 @@
1173 @@ -1,3 +1,3 @@
1174 -That is the first line
1174 -That is the first line
1175 -That change will be committed
1175 -That change will be committed
1176 -That is the third line
1176 -That is the third line
1177 +That change will not be committed
1177 +That change will not be committed
1178 +That is the second line
1178 +That is the second line
1179 +That line has been added
1179 +That line has been added
1180
1180
1181 Malformed patch - error handling
1181 Malformed patch - error handling
1182
1182
1183 $ cat > editor.sh << '__EOF__'
1183 $ cat > editor.sh << '__EOF__'
1184 > sed -e '/^@/p' "$1" > tmp
1184 > sed -e '/^@/p' "$1" > tmp
1185 > mv tmp "$1"
1185 > mv tmp "$1"
1186 > __EOF__
1186 > __EOF__
1187 $ HGEDITOR="\"sh\" \"`pwd`/editor.sh\"" hg record <<EOF
1187 $ HGEDITOR="\"sh\" \"`pwd`/editor.sh\"" hg record <<EOF
1188 > y
1188 > y
1189 > e
1189 > e
1190 > EOF
1190 > EOF
1191 diff --git a/editedfile b/editedfile
1191 diff --git a/editedfile b/editedfile
1192 1 hunks, 3 lines changed
1192 1 hunks, 3 lines changed
1193 examine changes to 'editedfile'? [Ynesfdaq?]
1193 examine changes to 'editedfile'? [Ynesfdaq?]
1194 @@ -1,3 +1,3 @@
1194 @@ -1,3 +1,3 @@
1195 -This is the first line
1195 -This is the first line
1196 -This change will be committed
1196 -This change will be committed
1197 -This is the third line
1197 -This is the third line
1198 +This change will not be committed
1198 +This change will not be committed
1199 +This is the second line
1199 +This is the second line
1200 +This line has been added
1200 +This line has been added
1201 record this change to 'editedfile'? [Ynesfdaq?]
1201 record this change to 'editedfile'? [Ynesfdaq?]
1202 abort: error parsing patch: unhandled transition: range -> range
1202 abort: error parsing patch: unhandled transition: range -> range
1203 [255]
1203 [255]
1204
1204
1205 random text in random positions is still an error
1205 random text in random positions is still an error
1206
1206
1207 $ cat > editor.sh << '__EOF__'
1207 $ cat > editor.sh << '__EOF__'
1208 > sed -e '/^@/i\
1208 > sed -e '/^@/i\
1209 > other' "$1" > tmp
1209 > other' "$1" > tmp
1210 > mv tmp "$1"
1210 > mv tmp "$1"
1211 > __EOF__
1211 > __EOF__
1212 $ HGEDITOR="\"sh\" \"`pwd`/editor.sh\"" hg record <<EOF
1212 $ HGEDITOR="\"sh\" \"`pwd`/editor.sh\"" hg record <<EOF
1213 > y
1213 > y
1214 > e
1214 > e
1215 > EOF
1215 > EOF
1216 diff --git a/editedfile b/editedfile
1216 diff --git a/editedfile b/editedfile
1217 1 hunks, 3 lines changed
1217 1 hunks, 3 lines changed
1218 examine changes to 'editedfile'? [Ynesfdaq?]
1218 examine changes to 'editedfile'? [Ynesfdaq?]
1219 @@ -1,3 +1,3 @@
1219 @@ -1,3 +1,3 @@
1220 -This is the first line
1220 -This is the first line
1221 -This change will be committed
1221 -This change will be committed
1222 -This is the third line
1222 -This is the third line
1223 +This change will not be committed
1223 +This change will not be committed
1224 +This is the second line
1224 +This is the second line
1225 +This line has been added
1225 +This line has been added
1226 record this change to 'editedfile'? [Ynesfdaq?]
1226 record this change to 'editedfile'? [Ynesfdaq?]
1227 abort: error parsing patch: unhandled transition: file -> other
1227 abort: error parsing patch: unhandled transition: file -> other
1228 [255]
1228 [255]
1229
1229
1230 $ hg up -C
1230 $ hg up -C
1231 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
1231 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
1232
1232
1233 With win32text
1233 With win32text
1234
1234
1235 $ echo '[extensions]' >> .hg/hgrc
1235 $ echo '[extensions]' >> .hg/hgrc
1236 $ echo 'win32text = ' >> .hg/hgrc
1236 $ echo 'win32text = ' >> .hg/hgrc
1237 $ echo '[decode]' >> .hg/hgrc
1237 $ echo '[decode]' >> .hg/hgrc
1238 $ echo '** = cleverdecode:' >> .hg/hgrc
1238 $ echo '** = cleverdecode:' >> .hg/hgrc
1239 $ echo '[encode]' >> .hg/hgrc
1239 $ echo '[encode]' >> .hg/hgrc
1240 $ echo '** = cleverencode:' >> .hg/hgrc
1240 $ echo '** = cleverencode:' >> .hg/hgrc
1241 $ echo '[patch]' >> .hg/hgrc
1241 $ echo '[patch]' >> .hg/hgrc
1242 $ echo 'eol = crlf' >> .hg/hgrc
1242 $ echo 'eol = crlf' >> .hg/hgrc
1243
1243
1244 Ignore win32text deprecation warning for now:
1244 Ignore win32text deprecation warning for now:
1245
1245
1246 $ echo '[win32text]' >> .hg/hgrc
1246 $ echo '[win32text]' >> .hg/hgrc
1247 $ echo 'warn = no' >> .hg/hgrc
1247 $ echo 'warn = no' >> .hg/hgrc
1248
1248
1249 $ echo d >> subdir/f1
1249 $ echo d >> subdir/f1
1250 $ hg record -d '24 0' -mw1 <<EOF
1250 $ hg record -d '24 0' -mw1 <<EOF
1251 > y
1251 > y
1252 > y
1252 > y
1253 > EOF
1253 > EOF
1254 diff --git a/subdir/f1 b/subdir/f1
1254 diff --git a/subdir/f1 b/subdir/f1
1255 1 hunks, 1 lines changed
1255 1 hunks, 1 lines changed
1256 examine changes to 'subdir/f1'? [Ynesfdaq?]
1256 examine changes to 'subdir/f1'? [Ynesfdaq?]
1257 @@ -3,3 +3,4 @@
1257 @@ -3,3 +3,4 @@
1258 a
1258 a
1259 b
1259 b
1260 c
1260 c
1261 +d
1261 +d
1262 record this change to 'subdir/f1'? [Ynesfdaq?]
1262 record this change to 'subdir/f1'? [Ynesfdaq?]
1263
1263
1264 $ hg tip -p
1264 $ hg tip -p
1265 changeset: 28:* (glob)
1265 changeset: 28:* (glob)
1266 tag: tip
1266 tag: tip
1267 user: test
1267 user: test
1268 date: Thu Jan 01 00:00:24 1970 +0000
1268 date: Thu Jan 01 00:00:24 1970 +0000
1269 summary: w1
1269 summary: w1
1270
1270
1271 diff -r ???????????? -r ???????????? subdir/f1 (glob)
1271 diff -r ???????????? -r ???????????? subdir/f1 (glob)
1272 --- a/subdir/f1 Thu Jan 01 00:00:23 1970 +0000
1272 --- a/subdir/f1 Thu Jan 01 00:00:23 1970 +0000
1273 +++ b/subdir/f1 Thu Jan 01 00:00:24 1970 +0000
1273 +++ b/subdir/f1 Thu Jan 01 00:00:24 1970 +0000
1274 @@ -3,3 +3,4 @@
1274 @@ -3,3 +3,4 @@
1275 a
1275 a
1276 b
1276 b
1277 c
1277 c
1278 +d
1278 +d
1279
1279
1280 Test --user when ui.username not set
1281 $ unset HGUSER
1282 $ echo e >> subdir/f1
1283 $ hg record --config ui.username= -d '8 0' --user xyz -m "user flag" <<EOF
1284 > y
1285 > y
1286 > EOF
1287 diff --git a/subdir/f1 b/subdir/f1
1288 1 hunks, 1 lines changed
1289 examine changes to 'subdir/f1'? [Ynesfdaq?]
1290 @@ -4,3 +4,4 @@
1291 b
1292 c
1293 d
1294 +e
1295 record this change to 'subdir/f1'? [Ynesfdaq?]
1296 $ hg log --template '{author}\n' -l 1
1297 xyz
1298 $ HGUSER="test"
1299 $ export HGUSER
1280
1300
1281 $ cd ..
1301 $ cd ..
General Comments 0
You need to be logged in to leave comments. Login now