##// END OF EJS Templates
dispatch: protect against malicious 'hg serve --stdio' invocations (sec)...
dispatch: protect against malicious 'hg serve --stdio' invocations (sec) Some shared-ssh installations assume that 'hg serve --stdio' is a safe command to run for minimally trusted users. Unfortunately, the messy implementation of argument parsing here meant that trying to access a repo named '--debugger' would give the user a pdb prompt, thereby sidestepping any hoped-for sandboxing. Serving repositories over HTTP(S) is unaffected. We're not currently hardening any subcommands other than 'serve'. If your service exposes other commands to users with arbitrary repository names, it is imperative that you defend against repository names of '--debugger' and anything starting with '--config'. The read-only mode of hg-ssh stopped working because it provided its hook configuration to "hg serve --stdio" via --config parameter. This is banned for security reasons now. This patch switches it to directly call ui.setconfig(). If your custom hosting infrastructure relies on passing --config to "hg serve --stdio", you'll need to find a different way to get that configuration into Mercurial, either by using ui.setconfig() as hg-ssh does in this patch, or by placing an hgrc file someplace where Mercurial will read it. mitrandir@fb.com provided some extra fixes for the dispatch code and for hg-ssh in places that I overlooked.

File last commit:

r31998:83527d9f default
r32050:77eaf953 4.1.3 stable
Show More
test-annotate.t
776 lines | 14.1 KiB | text/troff | Tads3Lexer
Martin Geisler
tests: unify test-annotate
r11852 $ HGMERGE=true; export HGMERGE
init
Patrick Mezard
annotate: support diff whitespace filtering flags (issue3030)...
r15528 $ hg init repo
$ cd repo
Martin Geisler
tests: unify test-annotate
r11852
commit
$ echo 'a' > a
$ hg ci -A -m test -u nobody -d '1 0'
adding a
annotate -c
$ hg annotate -c a
8435f90966e4: a
annotate -cl
$ hg annotate -cl a
8435f90966e4:1: a
annotate -d
$ hg annotate -d a
Thu Jan 01 00:00:01 1970 +0000: a
annotate -n
$ hg annotate -n a
0: a
annotate -nl
$ hg annotate -nl a
0:1: a
annotate -u
$ hg annotate -u a
nobody: a
annotate -cdnu
$ hg annotate -cdnu a
nobody 0 8435f90966e4 Thu Jan 01 00:00:01 1970 +0000: a
annotate -cdnul
$ hg annotate -cdnul a
nobody 0 8435f90966e4 Thu Jan 01 00:00:01 1970 +0000:1: a
Yuya Nishihara
annotate: port to generic templater enabled by hidden -T option...
r22480 annotate (JSON)
$ hg annotate -Tjson a
[
{
"line": "a\n",
"rev": 0
}
]
$ hg annotate -Tjson -cdfnul a
[
{
"date": [1.0, 0],
"file": "a",
"line": "a\n",
"line_number": 1,
"node": "8435f90966e442695d2ded29fdade2bac5ad8065",
"rev": 0,
"user": "nobody"
}
]
Martin Geisler
tests: unify test-annotate
r11852 $ cat <<EOF >>a
> a
> a
> EOF
$ hg ci -ma1 -d '1 0'
$ hg cp a b
$ hg ci -mb -d '1 0'
$ cat <<EOF >> b
> b4
> b5
> b6
> EOF
$ hg ci -mb2 -d '2 0'
annotate -n b
$ hg annotate -n b
Mads Kiilerich
bdiff: give slight preference to appending lines...
r30432 0: a
Mads Kiilerich
bdiff: give slight preference to longest matches in the middle of the B side...
r30431 1: a
Martin Geisler
tests: unify test-annotate
r11852 1: a
3: b4
3: b5
3: b6
annotate --no-follow b
$ hg annotate --no-follow b
2: a
2: a
2: a
3: b4
3: b5
3: b6
annotate -nl b
$ hg annotate -nl b
0:1: a
Mads Kiilerich
bdiff: give slight preference to appending lines...
r30432 1:2: a
Martin Geisler
tests: unify test-annotate
r11852 1:3: a
3:4: b4
3:5: b5
3:6: b6
annotate -nf b
$ hg annotate -nf b
Mads Kiilerich
bdiff: give slight preference to appending lines...
r30432 0 a: a
Mads Kiilerich
bdiff: give slight preference to longest matches in the middle of the B side...
r30431 1 a: a
Martin Geisler
tests: unify test-annotate
r11852 1 a: a
3 b: b4
3 b: b5
3 b: b6
annotate -nlf b
$ hg annotate -nlf b
0 a:1: a
Mads Kiilerich
bdiff: give slight preference to appending lines...
r30432 1 a:2: a
Martin Geisler
tests: unify test-annotate
r11852 1 a:3: a
3 b:4: b4
3 b:5: b5
3 b:6: b6
$ hg up -C 2
1 files updated, 0 files merged, 0 files removed, 0 files unresolved
$ cat <<EOF >> b
> b4
> c
> b5
> EOF
$ hg ci -mb2.1 -d '2 0'
created new head
$ hg merge
merging b
0 files updated, 1 files merged, 0 files removed, 0 files unresolved
(branch merge, don't forget to commit)
$ hg ci -mmergeb -d '3 0'
annotate after merge
$ hg annotate -nf b
Mads Kiilerich
bdiff: give slight preference to appending lines...
r30432 0 a: a
Mads Kiilerich
bdiff: give slight preference to longest matches in the middle of the B side...
r30431 1 a: a
Martin Geisler
tests: unify test-annotate
r11852 1 a: a
3 b: b4
4 b: c
3 b: b5
annotate after merge with -l
$ hg annotate -nlf b
0 a:1: a
Mads Kiilerich
bdiff: give slight preference to appending lines...
r30432 1 a:2: a
Martin Geisler
tests: unify test-annotate
r11852 1 a:3: a
3 b:4: b4
4 b:5: c
3 b:5: b5
$ hg up -C 1
0 files updated, 0 files merged, 1 files removed, 0 files unresolved
$ hg cp a b
$ cat <<EOF > b
> a
> z
> a
> EOF
$ hg ci -mc -d '3 0'
created new head
$ hg merge
merging b
0 files updated, 1 files merged, 0 files removed, 0 files unresolved
(branch merge, don't forget to commit)
$ cat <<EOF >> b
> b4
> c
> b5
> EOF
$ echo d >> b
$ hg ci -mmerge2 -d '4 0'
annotate after rename merge
$ hg annotate -nf b
Mads Kiilerich
bdiff: give slight preference to appending lines...
r30432 0 a: a
Martin Geisler
tests: unify test-annotate
r11852 6 b: z
1 a: a
3 b: b4
4 b: c
3 b: b5
7 b: d
annotate after rename merge with -l
$ hg annotate -nlf b
Mads Kiilerich
bdiff: give slight preference to appending lines...
r30432 0 a:1: a
Martin Geisler
tests: unify test-annotate
r11852 6 b:2: z
1 a:3: a
3 b:4: b4
4 b:5: c
3 b:5: b5
7 b:7: d
Thomas Arendsen Hein
annotate: fix alignment of columns in front of line numbers (issue2807)
r14358 Issue2807: alignment of line numbers with -l
$ echo more >> b
$ hg ci -mmore -d '5 0'
$ echo more >> b
$ hg ci -mmore -d '6 0'
$ echo more >> b
$ hg ci -mmore -d '7 0'
$ hg annotate -nlf b
Mads Kiilerich
bdiff: give slight preference to appending lines...
r30432 0 a: 1: a
Thomas Arendsen Hein
annotate: fix alignment of columns in front of line numbers (issue2807)
r14358 6 b: 2: z
1 a: 3: a
3 b: 4: b4
4 b: 5: c
3 b: 5: b5
7 b: 7: d
8 b: 8: more
9 b: 9: more
10 b:10: more
Martin Geisler
tests: unify test-annotate
r11852 linkrev vs rev
$ hg annotate -r tip -n a
Mads Kiilerich
bdiff: give slight preference to appending lines...
r30432 0: a
Mads Kiilerich
bdiff: give slight preference to longest matches in the middle of the B side...
r30431 1: a
Martin Geisler
tests: unify test-annotate
r11852 1: a
linkrev vs rev with -l
$ hg annotate -r tip -nl a
0:1: a
Mads Kiilerich
bdiff: give slight preference to appending lines...
r30432 1:2: a
Martin Geisler
tests: unify test-annotate
r11852 1:3: a
Martin Geisler
tests: added a short description to issue numbers...
r12399 Issue589: "undelete" sequence leads to crash
Martin Geisler
tests: unify test-annotate
r11852
annotate was crashing when trying to --follow something
like A -> B -> A
generate ABA rename configuration
$ echo foo > foo
$ hg add foo
$ hg ci -m addfoo
$ hg rename foo bar
$ hg ci -m renamefoo
$ hg rename bar foo
$ hg ci -m renamebar
annotate after ABA with follow
$ hg annotate --follow foo
foo: foo
Matt Mackall
annotate: catch nonexistent files using match.bad callback (issue1590)
r13697 missing file
$ hg ann nosuchfile
Thomas Arendsen Hein
annotate: fix alignment of columns in front of line numbers (issue2807)
r14358 abort: nosuchfile: no such file in rev e9e6b4fa872f
Matt Mackall
annotate: catch nonexistent files using match.bad callback (issue1590)
r13697 [255]
Patrick Mezard
annotate: support diff whitespace filtering flags (issue3030)...
r15528
Ion Savin
annotate: append newline after non newline-terminated file listings...
r15829 annotate file without '\n' on last line
$ printf "" > c
$ hg ci -A -m test -u nobody -d '1 0'
adding c
$ hg annotate c
$ printf "a\nb" > c
$ hg ci -m test
$ hg annotate c
[0-9]+: a (re)
[0-9]+: b (re)
FUJIWARA Katsunori
annotate: increase refcount of each revisions correctly (issue3841)...
r18993 Issue3841: check annotation of the file of which filelog includes
merging between the revision and its ancestor
to reproduce the situation with recent Mercurial, this script uses (1)
"hg debugsetparents" to merge without ancestor check by "hg merge",
and (2) the extension to allow filelog merging between the revision
and its ancestor by overriding "repo._filecommit".
$ cat > ../legacyrepo.py <<EOF
Pierre-Yves David
error: get Abort from 'error' instead of 'util'...
r26587 > from mercurial import node, error
FUJIWARA Katsunori
annotate: increase refcount of each revisions correctly (issue3841)...
r18993 > def reposetup(ui, repo):
> class legacyrepo(repo.__class__):
> def _filecommit(self, fctx, manifest1, manifest2,
> linkrev, tr, changelist):
> fname = fctx.path()
> text = fctx.data()
> flog = self.file(fname)
> fparent1 = manifest1.get(fname, node.nullid)
> fparent2 = manifest2.get(fname, node.nullid)
> meta = {}
> copy = fctx.renamed()
> if copy and copy[0] != fname:
Pierre-Yves David
error: get Abort from 'error' instead of 'util'...
r26587 > raise error.Abort('copying is not supported')
FUJIWARA Katsunori
annotate: increase refcount of each revisions correctly (issue3841)...
r18993 > if fparent2 != node.nullid:
> changelist.append(fname)
> return flog.add(text, meta, tr, linkrev,
> fparent1, fparent2)
Pierre-Yves David
error: get Abort from 'error' instead of 'util'...
r26587 > raise error.Abort('only merging is supported')
FUJIWARA Katsunori
annotate: increase refcount of each revisions correctly (issue3841)...
r18993 > repo.__class__ = legacyrepo
> EOF
$ cat > baz <<EOF
> 1
> 2
> 3
> 4
> 5
> EOF
$ hg add baz
$ hg commit -m "baz:0"
$ cat > baz <<EOF
> 1 baz:1
> 2
> 3
> 4
> 5
> EOF
$ hg commit -m "baz:1"
$ cat > baz <<EOF
> 1 baz:1
> 2 baz:2
> 3
> 4
> 5
> EOF
$ hg debugsetparents 17 17
$ hg --config extensions.legacyrepo=../legacyrepo.py commit -m "baz:2"
$ hg debugindexdot .hg/store/data/baz.i
digraph G {
-1 -> 0
0 -> 1
1 -> 2
1 -> 2
}
$ hg annotate baz
17: 1 baz:1
18: 2 baz:2
16: 3
16: 4
16: 5
$ cat > baz <<EOF
> 1 baz:1
> 2 baz:2
> 3 baz:3
> 4
> 5
> EOF
$ hg commit -m "baz:3"
$ cat > baz <<EOF
> 1 baz:1
> 2 baz:2
> 3 baz:3
> 4 baz:4
> 5
> EOF
$ hg debugsetparents 19 18
$ hg --config extensions.legacyrepo=../legacyrepo.py commit -m "baz:4"
$ hg debugindexdot .hg/store/data/baz.i
digraph G {
-1 -> 0
0 -> 1
1 -> 2
1 -> 2
2 -> 3
3 -> 4
2 -> 4
}
$ hg annotate baz
17: 1 baz:1
18: 2 baz:2
19: 3 baz:3
20: 4 baz:4
16: 5
Yuya Nishihara
annotate: add option to annotate working-directory files...
r24421 annotate clean file
$ hg annotate -ncr "wdir()" foo
11 472b18db256d : foo
annotate modified file
$ echo foofoo >> foo
$ hg annotate -r "wdir()" foo
11 : foo
20+: foofoo
$ hg annotate -cr "wdir()" foo
472b18db256d : foo
b6bedd5477e7+: foofoo
$ hg annotate -ncr "wdir()" foo
11 472b18db256d : foo
20 b6bedd5477e7+: foofoo
$ hg annotate --debug -ncr "wdir()" foo
11 472b18db256d1e8282064eab4bfdaf48cbfe83cd : foo
20 b6bedd5477e797f25e568a6402d4697f3f895a72+: foofoo
$ hg annotate -udr "wdir()" foo
test Thu Jan 01 00:00:00 1970 +0000: foo
test [A-Za-z0-9:+ ]+: foofoo (re)
$ hg annotate -ncr "wdir()" -Tjson foo
[
{
"line": "foo\n",
"node": "472b18db256d1e8282064eab4bfdaf48cbfe83cd",
"rev": 11
},
{
"line": "foofoo\n",
"node": null,
"rev": null
}
]
annotate added file
$ echo bar > bar
$ hg add bar
$ hg annotate -ncr "wdir()" bar
20 b6bedd5477e7+: bar
annotate renamed file
$ hg rename foo renamefoo2
$ hg annotate -ncr "wdir()" renamefoo2
11 472b18db256d : foo
20 b6bedd5477e7+: foofoo
annotate missing file
$ rm baz
Matt Harbison
test-annotate: conditionalize error output for Windows...
r24498 #if windows
$ hg annotate -ncr "wdir()" baz
abort: $TESTTMP\repo\baz: The system cannot find the file specified
[255]
#else
Yuya Nishihara
annotate: add option to annotate working-directory files...
r24421 $ hg annotate -ncr "wdir()" baz
abort: No such file or directory: $TESTTMP/repo/baz
[255]
Matt Harbison
test-annotate: conditionalize error output for Windows...
r24498 #endif
Yuya Nishihara
annotate: add option to annotate working-directory files...
r24421
annotate removed file
$ hg rm baz
Matt Harbison
test-annotate: conditionalize error output for Windows...
r24498 #if windows
$ hg annotate -ncr "wdir()" baz
abort: $TESTTMP\repo\baz: The system cannot find the file specified
[255]
#else
Yuya Nishihara
annotate: add option to annotate working-directory files...
r24421 $ hg annotate -ncr "wdir()" baz
abort: No such file or directory: $TESTTMP/repo/baz
[255]
Matt Harbison
test-annotate: conditionalize error output for Windows...
r24498 #endif
Yuya Nishihara
annotate: add option to annotate working-directory files...
r24421
Denis Laxalde
revset: add a followlines(file, fromline, toline[, rev]) revset...
r30719 $ hg revert --all --no-backup --quiet
$ hg id -n
20
Test followlines() revset
Yuya Nishihara
revset: abuse x:y syntax to specify line range of followlines()...
r30804 $ hg log -T '{rev}: {desc}\n' -r 'followlines(baz, 3:5)'
Denis Laxalde
revset: add a followlines(file, fromline, toline[, rev]) revset...
r30719 16: baz:0
19: baz:3
20: baz:4
Yuya Nishihara
revset: abuse x:y syntax to specify line range of followlines()...
r30804 $ hg log -T '{rev}: {desc}\n' -r 'followlines(baz, 3:5, startrev=20)'
Denis Laxalde
revset: add a followlines(file, fromline, toline[, rev]) revset...
r30719 16: baz:0
19: baz:3
20: baz:4
Yuya Nishihara
revset: abuse x:y syntax to specify line range of followlines()...
r30804 $ hg log -T '{rev}: {desc}\n' -r 'followlines(baz, 3:5, startrev=.^)'
Denis Laxalde
revset: add a followlines(file, fromline, toline[, rev]) revset...
r30719 16: baz:0
19: baz:3
$ printf "0\n0\n" | cat - baz > baz1
$ mv baz1 baz
$ hg ci -m 'added two lines with 0'
Yuya Nishihara
revset: abuse x:y syntax to specify line range of followlines()...
r30804 $ hg log -T '{rev}: {desc}\n' -r 'followlines(baz, 5:7)'
Denis Laxalde
revset: add a followlines(file, fromline, toline[, rev]) revset...
r30719 16: baz:0
19: baz:3
20: baz:4
$ echo 6 >> baz
$ hg ci -m 'added line 8'
Yuya Nishihara
revset: abuse x:y syntax to specify line range of followlines()...
r30804 $ hg log -T '{rev}: {desc}\n' -r 'followlines(baz, 5:7)'
Denis Laxalde
revset: add a followlines(file, fromline, toline[, rev]) revset...
r30719 16: baz:0
19: baz:3
20: baz:4
$ sed 's/3/3+/' baz > baz.new
$ mv baz.new baz
$ hg ci -m 'baz:3->3+'
Yuya Nishihara
revset: abuse x:y syntax to specify line range of followlines()...
r30804 $ hg log -T '{rev}: {desc}\n' -r 'followlines(baz, 5:7)'
Denis Laxalde
revset: add a followlines(file, fromline, toline[, rev]) revset...
r30719 16: baz:0
19: baz:3
20: baz:4
23: baz:3->3+
Yuya Nishihara
revset: abuse x:y syntax to specify line range of followlines()...
r30804 $ hg log -T '{rev}: {desc}\n' -r 'followlines(baz, 1:2)'
Denis Laxalde
revset: add a followlines(file, fromline, toline[, rev]) revset...
r30719 21: added two lines with 0
file patterns are okay
Yuya Nishihara
revset: abuse x:y syntax to specify line range of followlines()...
r30804 $ hg log -T '{rev}: {desc}\n' -r 'followlines("path:baz", 1:2)'
Denis Laxalde
revset: add a followlines(file, fromline, toline[, rev]) revset...
r30719 21: added two lines with 0
renames are followed
$ hg mv baz qux
$ sed 's/4/4+/' qux > qux.new
$ mv qux.new qux
$ hg ci -m 'qux:4->4+'
Yuya Nishihara
revset: abuse x:y syntax to specify line range of followlines()...
r30804 $ hg log -T '{rev}: {desc}\n' -r 'followlines(qux, 5:7)'
Denis Laxalde
revset: add a followlines(file, fromline, toline[, rev]) revset...
r30719 16: baz:0
19: baz:3
20: baz:4
23: baz:3->3+
24: qux:4->4+
$ hg up 23 --quiet
merge
$ echo 7 >> baz
$ hg ci -m 'one more line, out of line range'
created new head
$ sed 's/3+/3-/' baz > baz.new
$ mv baz.new baz
$ hg ci -m 'baz:3+->3-'
Yuya Nishihara
revset: abuse x:y syntax to specify line range of followlines()...
r30804 $ hg log -T '{rev}: {desc}\n' -r 'followlines(baz, 5:7)'
Denis Laxalde
revset: add a followlines(file, fromline, toline[, rev]) revset...
r30719 16: baz:0
19: baz:3
20: baz:4
23: baz:3->3+
26: baz:3+->3-
$ hg merge 24
merging baz and qux to qux
0 files updated, 1 files merged, 0 files removed, 0 files unresolved
(branch merge, don't forget to commit)
$ hg ci -m merge
Yuya Nishihara
revset: abuse x:y syntax to specify line range of followlines()...
r30804 $ hg log -T '{rev}: {desc}\n' -r 'followlines(qux, 5:7)'
Denis Laxalde
revset: add a followlines(file, fromline, toline[, rev]) revset...
r30719 16: baz:0
19: baz:3
20: baz:4
23: baz:3->3+
24: qux:4->4+
26: baz:3+->3-
27: merge
$ hg up 24 --quiet
$ hg merge 26
merging qux and baz to qux
0 files updated, 1 files merged, 0 files removed, 0 files unresolved
(branch merge, don't forget to commit)
$ hg ci -m 'merge from other side'
created new head
Yuya Nishihara
revset: abuse x:y syntax to specify line range of followlines()...
r30804 $ hg log -T '{rev}: {desc}\n' -r 'followlines(qux, 5:7)'
Denis Laxalde
revset: add a followlines(file, fromline, toline[, rev]) revset...
r30719 16: baz:0
19: baz:3
20: baz:4
23: baz:3->3+
24: qux:4->4+
26: baz:3+->3-
28: merge from other side
$ hg up 23 --quiet
check error cases
Yuya Nishihara
revset: parse variable-length arguments of followlines() by getargsdict()
r30754 $ hg log -r 'followlines()'
hg: parse error: followlines takes at least 1 positional arguments
[255]
$ hg log -r 'followlines(baz)'
Yuya Nishihara
revset: abuse x:y syntax to specify line range of followlines()...
r30804 hg: parse error: followlines requires a line range
Yuya Nishihara
revset: parse variable-length arguments of followlines() by getargsdict()
r30754 [255]
$ hg log -r 'followlines(baz, 1)'
Yuya Nishihara
revset: abuse x:y syntax to specify line range of followlines()...
r30804 hg: parse error: followlines expects a line range
Yuya Nishihara
revset: parse variable-length arguments of followlines() by getargsdict()
r30754 [255]
Yuya Nishihara
revset: abuse x:y syntax to specify line range of followlines()...
r30804 $ hg log -r 'followlines(baz, 1:2, startrev=desc("b"))'
Denis Laxalde
revset: add a followlines(file, fromline, toline[, rev]) revset...
r30719 hg: parse error: followlines expects exactly one revision
[255]
Yuya Nishihara
revset: abuse x:y syntax to specify line range of followlines()...
r30804 $ hg log -r 'followlines("glob:*", 1:2)'
Denis Laxalde
revset: add a followlines(file, fromline, toline[, rev]) revset...
r30719 hg: parse error: followlines expects exactly one file
[255]
Yuya Nishihara
revset: abuse x:y syntax to specify line range of followlines()...
r30804 $ hg log -r 'followlines(baz, 1:)'
hg: parse error: line range bounds must be integers
[255]
$ hg log -r 'followlines(baz, :1)'
Denis Laxalde
revset: add a followlines(file, fromline, toline[, rev]) revset...
r30719 hg: parse error: line range bounds must be integers
[255]
Yuya Nishihara
revset: abuse x:y syntax to specify line range of followlines()...
r30804 $ hg log -r 'followlines(baz, x:4)'
hg: parse error: line range bounds must be integers
[255]
$ hg log -r 'followlines(baz, 5:4)'
Denis Laxalde
revset: add a followlines(file, fromline, toline[, rev]) revset...
r30719 hg: parse error: line range must be positive
[255]
Yuya Nishihara
revset: abuse x:y syntax to specify line range of followlines()...
r30804 $ hg log -r 'followlines(baz, 0:4)'
Denis Laxalde
revset: add a followlines(file, fromline, toline[, rev]) revset...
r30719 hg: parse error: fromline must be strictly positive
[255]
Yuya Nishihara
revset: abuse x:y syntax to specify line range of followlines()...
r30804 $ hg log -r 'followlines(baz, 2:40)'
Denis Laxalde
revset: add a followlines(file, fromline, toline[, rev]) revset...
r30719 abort: line range exceeds file size
[255]
Patrick Mezard
annotate: support diff whitespace filtering flags (issue3030)...
r15528 Test annotate with whitespace options
$ cd ..
$ hg init repo-ws
$ cd repo-ws
$ cat > a <<EOF
> aa
>
> b b
> EOF
$ hg ci -Am "adda"
adding a
Mads Kiilerich
check-code: fix check for trailing whitespace on continued lines too...
r17347 $ sed 's/EOL$//g' > a <<EOF
Patrick Mezard
annotate: support diff whitespace filtering flags (issue3030)...
r15528 > a a
>
Mads Kiilerich
check-code: fix check for trailing whitespace on continued lines too...
r17347 > EOL
Patrick Mezard
annotate: support diff whitespace filtering flags (issue3030)...
r15528 > b b
> EOF
$ hg ci -m "changea"
Annotate with no option
$ hg annotate a
1: a a
0:
1:
1: b b
Annotate with --ignore-space-change
$ hg annotate --ignore-space-change a
1: a a
1:
0:
0: b b
Annotate with --ignore-all-space
$ hg annotate --ignore-all-space a
0: a a
0:
1:
0: b b
Annotate with --ignore-blank-lines (similar to no options case)
$ hg annotate --ignore-blank-lines a
1: a a
0:
1:
1: b b
Mads Kiilerich
tests: add missing trailing 'cd ..'...
r16913 $ cd ..
Pierre-Yves David
filectx.parents: enforce changeid of parent to be in own changectx ancestors...
r23702
Annotate with linkrev pointing to another branch
------------------------------------------------
create history with a filerev whose linkrev points to another branch
$ hg init branchedlinkrev
$ cd branchedlinkrev
$ echo A > a
$ hg commit -Am 'contentA'
adding a
$ echo B >> a
$ hg commit -m 'contentB'
$ hg up --rev 'desc(contentA)'
1 files updated, 0 files merged, 0 files removed, 0 files unresolved
$ echo unrelated > unrelated
$ hg commit -Am 'unrelated'
adding unrelated
created new head
$ hg graft -r 'desc(contentB)'
grafting 1:fd27c222e3e6 "contentB"
$ echo C >> a
$ hg commit -m 'contentC'
Yuya Nishihara
committablefilectx: propagate ancestry info to parent to fix annotation...
r24817 $ echo W >> a
Pierre-Yves David
filectx.parents: enforce changeid of parent to be in own changectx ancestors...
r23702 $ hg log -G
@ changeset: 4:072f1e8df249
| tag: tip
| user: test
| date: Thu Jan 01 00:00:00 1970 +0000
| summary: contentC
|
o changeset: 3:ff38df03cc4b
| user: test
| date: Thu Jan 01 00:00:00 1970 +0000
| summary: contentB
|
o changeset: 2:62aaf3f6fc06
| parent: 0:f0932f74827e
| user: test
| date: Thu Jan 01 00:00:00 1970 +0000
| summary: unrelated
|
| o changeset: 1:fd27c222e3e6
|/ user: test
| date: Thu Jan 01 00:00:00 1970 +0000
| summary: contentB
|
o changeset: 0:f0932f74827e
user: test
date: Thu Jan 01 00:00:00 1970 +0000
summary: contentA
Annotate should list ancestor of starting revision only
$ hg annotate a
0: A
3: B
4: C
Yuya Nishihara
committablefilectx: propagate ancestry info to parent to fix annotation...
r24817 $ hg annotate a -r 'wdir()'
0 : A
3 : B
4 : C
4+: W
Pierre-Yves David
linkrev: also adjust linkrev when bootstrapping annotate (issue4305)...
r23705 Even when the starting revision is the linkrev-shadowed one:
$ hg annotate a -r 3
0: A
3: B
Pierre-Yves David
filectx.parents: enforce changeid of parent to be in own changectx ancestors...
r23702 $ cd ..
Jun Wu
annotate: pre-calculate the "needed" dictionary (issue5360)...
r29861
Issue5360: Deleted chunk in p1 of a merge changeset
$ hg init repo-5360
$ cd repo-5360
$ echo 1 > a
$ hg commit -A a -m 1
$ echo 2 >> a
$ hg commit -m 2
$ echo a > a
$ hg commit -m a
$ hg update '.^' -q
$ echo 3 >> a
$ hg commit -m 3 -q
$ hg merge 2 -q
$ cat > a << EOF
> b
> 1
> 2
> 3
> a
> EOF
$ hg resolve --mark -q
$ hg commit -m m
$ hg annotate a
4: b
0: 1
1: 2
3: 3
2: a
$ cd ..