2010-08-30 08:23:32 +04:00
|
|
|
$ HGENCODING=utf-8
|
|
|
|
$ export HGENCODING
|
2014-03-27 02:55:50 +04:00
|
|
|
$ cat > testrevset.py << EOF
|
|
|
|
> import mercurial.revset
|
|
|
|
>
|
|
|
|
> baseset = mercurial.revset.baseset
|
|
|
|
>
|
|
|
|
> def r3232(repo, subset, x):
|
|
|
|
> """"simple revset that return [3,2,3,2]
|
|
|
|
>
|
|
|
|
> revisions duplicated on purpose.
|
|
|
|
> """
|
|
|
|
> if 3 not in subset:
|
|
|
|
> if 2 in subset:
|
|
|
|
> return baseset([2,2])
|
|
|
|
> return baseset()
|
|
|
|
> return baseset([3,3,2,2])
|
|
|
|
>
|
|
|
|
> mercurial.revset.symbols['r3232'] = r3232
|
|
|
|
> EOF
|
|
|
|
$ cat >> $HGRCPATH << EOF
|
|
|
|
> [extensions]
|
2017-07-10 20:56:40 +03:00
|
|
|
> drawdag=$TESTDIR/drawdag.py
|
2014-03-27 02:55:50 +04:00
|
|
|
> testrevset=$TESTTMP/testrevset.py
|
|
|
|
> EOF
|
2010-08-30 08:23:32 +04:00
|
|
|
|
|
|
|
$ try() {
|
2011-04-30 20:30:14 +04:00
|
|
|
> hg debugrevspec --debug "$@"
|
2010-08-30 08:23:32 +04:00
|
|
|
> }
|
|
|
|
|
|
|
|
$ log() {
|
|
|
|
> hg log --template '{rev}\n' -r "$1"
|
|
|
|
> }
|
|
|
|
|
2016-06-22 16:02:25 +03:00
|
|
|
extension to build '_intlist()' and '_hexlist()', which is necessary because
|
|
|
|
these predicates use '\0' as a separator:
|
|
|
|
|
|
|
|
$ cat <<EOF > debugrevlistspec.py
|
|
|
|
> from __future__ import absolute_import
|
|
|
|
> from mercurial import (
|
|
|
|
> node as nodemod,
|
2016-01-09 17:07:20 +03:00
|
|
|
> registrar,
|
2016-06-22 16:02:25 +03:00
|
|
|
> revset,
|
2017-02-19 12:19:33 +03:00
|
|
|
> revsetlang,
|
2016-10-16 11:28:51 +03:00
|
|
|
> smartset,
|
2016-06-22 16:02:25 +03:00
|
|
|
> )
|
|
|
|
> cmdtable = {}
|
2016-01-09 17:07:20 +03:00
|
|
|
> command = registrar.command(cmdtable)
|
2017-06-25 05:50:05 +03:00
|
|
|
> @command(b'debugrevlistspec',
|
2016-06-22 16:02:25 +03:00
|
|
|
> [('', 'optimize', None, 'print parsed tree after optimizing'),
|
|
|
|
> ('', 'bin', None, 'unhexlify arguments')])
|
|
|
|
> def debugrevlistspec(ui, repo, fmt, *args, **opts):
|
|
|
|
> if opts['bin']:
|
|
|
|
> args = map(nodemod.bin, args)
|
2017-02-19 12:19:33 +03:00
|
|
|
> expr = revsetlang.formatspec(fmt, list(args))
|
2016-06-22 16:02:25 +03:00
|
|
|
> if ui.verbose:
|
2017-02-19 12:19:33 +03:00
|
|
|
> tree = revsetlang.parse(expr, lookup=repo.__contains__)
|
|
|
|
> ui.note(revsetlang.prettyformat(tree), "\n")
|
2016-06-22 16:02:25 +03:00
|
|
|
> if opts["optimize"]:
|
2017-02-19 12:19:33 +03:00
|
|
|
> opttree = revsetlang.optimize(revsetlang.analyze(tree))
|
|
|
|
> ui.note("* optimized:\n", revsetlang.prettyformat(opttree),
|
|
|
|
> "\n")
|
2016-06-22 16:02:25 +03:00
|
|
|
> func = revset.match(ui, expr, repo)
|
|
|
|
> revs = func(repo)
|
|
|
|
> if ui.verbose:
|
2016-10-16 11:28:51 +03:00
|
|
|
> ui.note("* set:\n", smartset.prettyformat(revs), "\n")
|
2016-06-22 16:02:25 +03:00
|
|
|
> for c in revs:
|
|
|
|
> ui.write("%s\n" % c)
|
|
|
|
> EOF
|
|
|
|
$ cat <<EOF >> $HGRCPATH
|
|
|
|
> [extensions]
|
|
|
|
> debugrevlistspec = $TESTTMP/debugrevlistspec.py
|
|
|
|
> EOF
|
|
|
|
$ trylist() {
|
|
|
|
> hg debugrevlistspec --debug "$@"
|
|
|
|
> }
|
|
|
|
|
2010-08-30 08:23:32 +04:00
|
|
|
$ hg init repo
|
|
|
|
$ cd repo
|
|
|
|
|
|
|
|
$ echo a > a
|
|
|
|
$ hg branch a
|
|
|
|
marked working directory as branch a
|
2011-12-09 00:32:44 +04:00
|
|
|
(branches are permanent and global, did you want a bookmark?)
|
2010-08-30 08:23:32 +04:00
|
|
|
$ hg ci -Aqm0
|
|
|
|
|
|
|
|
$ echo b > b
|
|
|
|
$ hg branch b
|
|
|
|
marked working directory as branch b
|
|
|
|
$ hg ci -Aqm1
|
|
|
|
|
|
|
|
$ rm a
|
|
|
|
$ hg branch a-b-c-
|
|
|
|
marked working directory as branch a-b-c-
|
|
|
|
$ hg ci -Aqm2 -u Bob
|
|
|
|
|
2012-05-12 12:20:57 +04:00
|
|
|
$ hg log -r "extra('branch', 'a-b-c-')" --template '{rev}\n'
|
|
|
|
2
|
|
|
|
$ hg log -r "extra('branch')" --template '{rev}\n'
|
|
|
|
0
|
|
|
|
1
|
|
|
|
2
|
2012-05-31 02:14:04 +04:00
|
|
|
$ hg log -r "extra('branch', 're:a')" --template '{rev} {branch}\n'
|
|
|
|
0 a
|
|
|
|
2 a-b-c-
|
2012-05-12 12:20:57 +04:00
|
|
|
|
2010-08-30 08:23:32 +04:00
|
|
|
$ hg co 1
|
|
|
|
1 files updated, 0 files merged, 0 files removed, 0 files unresolved
|
|
|
|
$ hg branch +a+b+c+
|
|
|
|
marked working directory as branch +a+b+c+
|
|
|
|
$ hg ci -Aqm3
|
|
|
|
|
|
|
|
$ hg co 2 # interleave
|
|
|
|
0 files updated, 0 files merged, 1 files removed, 0 files unresolved
|
|
|
|
$ echo bb > b
|
|
|
|
$ hg branch -- -a-b-c-
|
|
|
|
marked working directory as branch -a-b-c-
|
|
|
|
$ hg ci -Aqm4 -d "May 12 2005"
|
|
|
|
|
|
|
|
$ hg co 3
|
|
|
|
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
|
test-revset: enable for Windows
In MSYS, the test fails like this if the hghave exit at the beginning is
removed:
--- C:\Users\adi\hgrepos\hg-main\tests\test-revset.t
+++ C:\Users\adi\hgrepos\hg-main\tests\test-revset.t.err
@@ -58,7 +58,7 @@
$ hg co 3
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
$ hg branch /a/b/c/
- marked working directory as branch /a/b/c/
+ marked working directory as branch a:/b/c/
(branches are permanent and global, did you want a bookmark?)
$ hg ci -Aqm"5 bug"
@@ -252,7 +252,7 @@
2 a-b-c-
3 +a+b+c+
4 -a-b-c-
- 5 /a/b/c/
+ 5 a:/b/c/
6 _a_b_c_
7 .a.b.c.
$ log 'children(ancestor(4,5))'
due to the posix path conversion done by MSYS globally, as explained here
http://www.mingw.org/wiki/Posix_path_conversion
The solution is a bit lame, but it is simple and works: don't use strings that
look like '/a/b', in order not to trigger the path magic done by MSYS.
So, if we can agree not to insist on testing branch names starting with '/',
then this relatively simple patch makes the test pass both on Windows with MSYS
and Linux.
2012-06-03 11:06:15 +04:00
|
|
|
$ hg branch !a/b/c/
|
|
|
|
marked working directory as branch !a/b/c/
|
2010-08-30 08:23:32 +04:00
|
|
|
$ hg ci -Aqm"5 bug"
|
|
|
|
|
|
|
|
$ hg merge 4
|
|
|
|
1 files updated, 0 files merged, 1 files removed, 0 files unresolved
|
|
|
|
(branch merge, don't forget to commit)
|
|
|
|
$ hg branch _a_b_c_
|
|
|
|
marked working directory as branch _a_b_c_
|
|
|
|
$ hg ci -Aqm"6 issue619"
|
|
|
|
|
|
|
|
$ hg branch .a.b.c.
|
|
|
|
marked working directory as branch .a.b.c.
|
|
|
|
$ hg ci -Aqm7
|
|
|
|
|
|
|
|
$ hg branch all
|
|
|
|
marked working directory as branch all
|
|
|
|
|
|
|
|
$ hg co 4
|
|
|
|
0 files updated, 0 files merged, 0 files removed, 0 files unresolved
|
|
|
|
$ hg branch é
|
2010-11-08 03:41:41 +03:00
|
|
|
marked working directory as branch \xc3\xa9 (esc)
|
2010-08-30 08:23:32 +04:00
|
|
|
$ hg ci -Aqm9
|
|
|
|
|
|
|
|
$ hg tag -r6 1.0
|
2015-04-20 10:52:20 +03:00
|
|
|
$ hg bookmark -r6 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
|
2010-08-30 08:23:32 +04:00
|
|
|
|
|
|
|
$ hg clone --quiet -U -r 7 . ../remote1
|
|
|
|
$ hg clone --quiet -U -r 8 . ../remote2
|
|
|
|
$ echo "[paths]" >> .hg/hgrc
|
|
|
|
$ echo "default = ../remote1" >> .hg/hgrc
|
|
|
|
|
2015-03-16 12:36:53 +03:00
|
|
|
trivial
|
|
|
|
|
|
|
|
$ try 0:1
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '0')
|
|
|
|
(symbol '1'))
|
2015-03-16 12:36:53 +03:00
|
|
|
* set:
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset+ 0:2>
|
2015-03-16 12:36:53 +03:00
|
|
|
0
|
|
|
|
1
|
2015-07-05 06:15:54 +03:00
|
|
|
$ try --optimize :
|
|
|
|
(rangeall
|
|
|
|
None)
|
|
|
|
* optimized:
|
2017-01-09 10:55:56 +03:00
|
|
|
(rangeall
|
2017-08-20 20:55:11 +03:00
|
|
|
None)
|
2015-07-05 06:15:54 +03:00
|
|
|
* set:
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset+ 0:10>
|
2015-07-05 06:15:54 +03:00
|
|
|
0
|
|
|
|
1
|
|
|
|
2
|
|
|
|
3
|
|
|
|
4
|
|
|
|
5
|
|
|
|
6
|
|
|
|
7
|
|
|
|
8
|
|
|
|
9
|
2015-03-16 12:36:53 +03:00
|
|
|
$ try 3::6
|
|
|
|
(dagrange
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '3')
|
|
|
|
(symbol '6'))
|
2015-03-16 12:36:53 +03:00
|
|
|
* set:
|
2015-08-21 03:23:21 +03:00
|
|
|
<baseset+ [3, 5, 6]>
|
2015-03-16 12:36:53 +03:00
|
|
|
3
|
|
|
|
5
|
|
|
|
6
|
|
|
|
$ try '0|1|2'
|
|
|
|
(or
|
2016-08-07 11:04:05 +03:00
|
|
|
(list
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '0')
|
|
|
|
(symbol '1')
|
|
|
|
(symbol '2')))
|
2015-03-16 12:36:53 +03:00
|
|
|
* set:
|
2015-05-17 09:11:38 +03:00
|
|
|
<baseset [0, 1, 2]>
|
2015-03-16 12:36:53 +03:00
|
|
|
0
|
|
|
|
1
|
|
|
|
2
|
|
|
|
|
2010-08-30 08:23:32 +04:00
|
|
|
names that should work without quoting
|
|
|
|
|
|
|
|
$ try a
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'a')
|
2015-03-16 12:36:53 +03:00
|
|
|
* set:
|
|
|
|
<baseset [0]>
|
2010-08-30 08:23:32 +04:00
|
|
|
0
|
|
|
|
$ try b-a
|
debugrevspec: pretty print output
Before:
('func', ('symbol', 'reverse'), ('func', ('symbol', 'sort'), ('list', ('or',
('symbol', '2'), ('symbol', '3')), ('symbol', 'date'))))
After:
(func
('symbol', 'reverse')
(func
('symbol', 'sort')
(list
(or
('symbol', '2')
('symbol', '3'))
('symbol', 'date'))))
v2:
- Rebased on stable to avoid having to merge tests output
2012-02-24 14:02:21 +04:00
|
|
|
(minus
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'b')
|
|
|
|
(symbol 'a'))
|
2015-03-16 12:36:53 +03:00
|
|
|
* set:
|
|
|
|
<filteredset
|
2016-02-13 13:25:11 +03:00
|
|
|
<baseset [1]>,
|
|
|
|
<not
|
|
|
|
<baseset [0]>>>
|
2010-08-30 08:23:32 +04:00
|
|
|
1
|
|
|
|
$ try _a_b_c_
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '_a_b_c_')
|
2015-03-16 12:36:53 +03:00
|
|
|
* set:
|
|
|
|
<baseset [6]>
|
2010-08-30 08:23:32 +04:00
|
|
|
6
|
|
|
|
$ try _a_b_c_-a
|
debugrevspec: pretty print output
Before:
('func', ('symbol', 'reverse'), ('func', ('symbol', 'sort'), ('list', ('or',
('symbol', '2'), ('symbol', '3')), ('symbol', 'date'))))
After:
(func
('symbol', 'reverse')
(func
('symbol', 'sort')
(list
(or
('symbol', '2')
('symbol', '3'))
('symbol', 'date'))))
v2:
- Rebased on stable to avoid having to merge tests output
2012-02-24 14:02:21 +04:00
|
|
|
(minus
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '_a_b_c_')
|
|
|
|
(symbol 'a'))
|
2015-03-16 12:36:53 +03:00
|
|
|
* set:
|
|
|
|
<filteredset
|
2016-02-13 13:25:11 +03:00
|
|
|
<baseset [6]>,
|
|
|
|
<not
|
|
|
|
<baseset [0]>>>
|
2010-08-30 08:23:32 +04:00
|
|
|
6
|
|
|
|
$ try .a.b.c.
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '.a.b.c.')
|
2015-03-16 12:36:53 +03:00
|
|
|
* set:
|
|
|
|
<baseset [7]>
|
2010-08-30 08:23:32 +04:00
|
|
|
7
|
|
|
|
$ try .a.b.c.-a
|
debugrevspec: pretty print output
Before:
('func', ('symbol', 'reverse'), ('func', ('symbol', 'sort'), ('list', ('or',
('symbol', '2'), ('symbol', '3')), ('symbol', 'date'))))
After:
(func
('symbol', 'reverse')
(func
('symbol', 'sort')
(list
(or
('symbol', '2')
('symbol', '3'))
('symbol', 'date'))))
v2:
- Rebased on stable to avoid having to merge tests output
2012-02-24 14:02:21 +04:00
|
|
|
(minus
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '.a.b.c.')
|
|
|
|
(symbol 'a'))
|
2015-03-16 12:36:53 +03:00
|
|
|
* set:
|
|
|
|
<filteredset
|
2016-02-13 13:25:11 +03:00
|
|
|
<baseset [7]>,
|
|
|
|
<not
|
|
|
|
<baseset [0]>>>
|
2010-08-30 08:23:32 +04:00
|
|
|
7
|
2015-07-18 17:02:18 +03:00
|
|
|
|
|
|
|
names that should be caught by fallback mechanism
|
|
|
|
|
|
|
|
$ try -- '-a-b-c-'
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '-a-b-c-')
|
2015-07-18 17:02:18 +03:00
|
|
|
* set:
|
|
|
|
<baseset [4]>
|
|
|
|
4
|
|
|
|
$ log -a-b-c-
|
2010-08-30 08:23:32 +04:00
|
|
|
4
|
2015-07-18 17:30:17 +03:00
|
|
|
$ try '+a+b+c+'
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '+a+b+c+')
|
2015-07-18 17:30:17 +03:00
|
|
|
* set:
|
|
|
|
<baseset [3]>
|
|
|
|
3
|
|
|
|
$ try '+a+b+c+:'
|
|
|
|
(rangepost
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '+a+b+c+'))
|
2015-07-18 17:30:17 +03:00
|
|
|
* set:
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset+ 3:10>
|
2015-07-18 17:30:17 +03:00
|
|
|
3
|
|
|
|
4
|
|
|
|
5
|
|
|
|
6
|
|
|
|
7
|
|
|
|
8
|
|
|
|
9
|
|
|
|
$ try ':+a+b+c+'
|
|
|
|
(rangepre
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '+a+b+c+'))
|
2015-07-18 17:30:17 +03:00
|
|
|
* set:
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset+ 0:4>
|
2015-07-18 17:30:17 +03:00
|
|
|
0
|
|
|
|
1
|
|
|
|
2
|
|
|
|
3
|
|
|
|
$ try -- '-a-b-c-:+a+b+c+'
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '-a-b-c-')
|
|
|
|
(symbol '+a+b+c+'))
|
2015-07-18 17:30:17 +03:00
|
|
|
* set:
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset- 3:5>
|
2015-07-18 17:30:17 +03:00
|
|
|
4
|
|
|
|
3
|
|
|
|
$ log '-a-b-c-:+a+b+c+'
|
|
|
|
4
|
|
|
|
3
|
2014-03-19 02:56:27 +04:00
|
|
|
|
2010-08-30 08:23:32 +04:00
|
|
|
$ try -- -a-b-c--a # complains
|
debugrevspec: pretty print output
Before:
('func', ('symbol', 'reverse'), ('func', ('symbol', 'sort'), ('list', ('or',
('symbol', '2'), ('symbol', '3')), ('symbol', 'date'))))
After:
(func
('symbol', 'reverse')
(func
('symbol', 'sort')
(list
(or
('symbol', '2')
('symbol', '3'))
('symbol', 'date'))))
v2:
- Rebased on stable to avoid having to merge tests output
2012-02-24 14:02:21 +04:00
|
|
|
(minus
|
|
|
|
(minus
|
|
|
|
(minus
|
|
|
|
(negate
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'a'))
|
|
|
|
(symbol 'b'))
|
|
|
|
(symbol 'c'))
|
debugrevspec: pretty print output
Before:
('func', ('symbol', 'reverse'), ('func', ('symbol', 'sort'), ('list', ('or',
('symbol', '2'), ('symbol', '3')), ('symbol', 'date'))))
After:
(func
('symbol', 'reverse')
(func
('symbol', 'sort')
(list
(or
('symbol', '2')
('symbol', '3'))
('symbol', 'date'))))
v2:
- Rebased on stable to avoid having to merge tests output
2012-02-24 14:02:21 +04:00
|
|
|
(negate
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'a')))
|
2010-08-30 08:23:32 +04:00
|
|
|
abort: unknown revision '-a'!
|
2010-09-17 02:51:32 +04:00
|
|
|
[255]
|
2010-08-30 08:23:32 +04:00
|
|
|
$ try é
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '\xc3\xa9')
|
2015-03-16 12:36:53 +03:00
|
|
|
* set:
|
|
|
|
<baseset [9]>
|
2010-08-30 08:23:32 +04:00
|
|
|
9
|
|
|
|
|
2014-03-19 02:56:27 +04:00
|
|
|
no quoting needed
|
|
|
|
|
|
|
|
$ log ::a-b-c-
|
|
|
|
0
|
|
|
|
1
|
|
|
|
2
|
|
|
|
|
2010-08-30 08:23:32 +04:00
|
|
|
quoting needed
|
|
|
|
|
|
|
|
$ try '"-a-b-c-"-a'
|
debugrevspec: pretty print output
Before:
('func', ('symbol', 'reverse'), ('func', ('symbol', 'sort'), ('list', ('or',
('symbol', '2'), ('symbol', '3')), ('symbol', 'date'))))
After:
(func
('symbol', 'reverse')
(func
('symbol', 'sort')
(list
(or
('symbol', '2')
('symbol', '3'))
('symbol', 'date'))))
v2:
- Rebased on stable to avoid having to merge tests output
2012-02-24 14:02:21 +04:00
|
|
|
(minus
|
2017-09-03 15:17:25 +03:00
|
|
|
(string '-a-b-c-')
|
|
|
|
(symbol 'a'))
|
2015-03-16 12:36:53 +03:00
|
|
|
* set:
|
|
|
|
<filteredset
|
2016-02-13 13:25:11 +03:00
|
|
|
<baseset [4]>,
|
|
|
|
<not
|
|
|
|
<baseset [0]>>>
|
2010-08-30 08:23:32 +04:00
|
|
|
4
|
|
|
|
|
|
|
|
$ log '1 or 2'
|
|
|
|
1
|
|
|
|
2
|
|
|
|
$ log '1|2'
|
|
|
|
1
|
|
|
|
2
|
|
|
|
$ log '1 and 2'
|
|
|
|
$ log '1&2'
|
|
|
|
$ try '1&2|3' # precedence - and is higher
|
debugrevspec: pretty print output
Before:
('func', ('symbol', 'reverse'), ('func', ('symbol', 'sort'), ('list', ('or',
('symbol', '2'), ('symbol', '3')), ('symbol', 'date'))))
After:
(func
('symbol', 'reverse')
(func
('symbol', 'sort')
(list
(or
('symbol', '2')
('symbol', '3'))
('symbol', 'date'))))
v2:
- Rebased on stable to avoid having to merge tests output
2012-02-24 14:02:21 +04:00
|
|
|
(or
|
2016-08-07 11:04:05 +03:00
|
|
|
(list
|
|
|
|
(and
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '1')
|
|
|
|
(symbol '2'))
|
|
|
|
(symbol '3')))
|
2015-03-16 12:36:53 +03:00
|
|
|
* set:
|
|
|
|
<addset
|
|
|
|
<baseset []>,
|
|
|
|
<baseset [3]>>
|
2010-08-30 08:23:32 +04:00
|
|
|
3
|
|
|
|
$ try '1|2&3'
|
debugrevspec: pretty print output
Before:
('func', ('symbol', 'reverse'), ('func', ('symbol', 'sort'), ('list', ('or',
('symbol', '2'), ('symbol', '3')), ('symbol', 'date'))))
After:
(func
('symbol', 'reverse')
(func
('symbol', 'sort')
(list
(or
('symbol', '2')
('symbol', '3'))
('symbol', 'date'))))
v2:
- Rebased on stable to avoid having to merge tests output
2012-02-24 14:02:21 +04:00
|
|
|
(or
|
2016-08-07 11:04:05 +03:00
|
|
|
(list
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '1')
|
2016-08-07 11:04:05 +03:00
|
|
|
(and
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2')
|
|
|
|
(symbol '3'))))
|
2015-03-16 12:36:53 +03:00
|
|
|
* set:
|
|
|
|
<addset
|
|
|
|
<baseset [1]>,
|
|
|
|
<baseset []>>
|
2010-08-30 08:23:32 +04:00
|
|
|
1
|
|
|
|
$ try '1&2&3' # associativity
|
debugrevspec: pretty print output
Before:
('func', ('symbol', 'reverse'), ('func', ('symbol', 'sort'), ('list', ('or',
('symbol', '2'), ('symbol', '3')), ('symbol', 'date'))))
After:
(func
('symbol', 'reverse')
(func
('symbol', 'sort')
(list
(or
('symbol', '2')
('symbol', '3'))
('symbol', 'date'))))
v2:
- Rebased on stable to avoid having to merge tests output
2012-02-24 14:02:21 +04:00
|
|
|
(and
|
|
|
|
(and
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '1')
|
|
|
|
(symbol '2'))
|
|
|
|
(symbol '3'))
|
2015-03-16 12:36:53 +03:00
|
|
|
* set:
|
|
|
|
<baseset []>
|
2010-08-30 08:23:32 +04:00
|
|
|
$ try '1|(2|3)'
|
debugrevspec: pretty print output
Before:
('func', ('symbol', 'reverse'), ('func', ('symbol', 'sort'), ('list', ('or',
('symbol', '2'), ('symbol', '3')), ('symbol', 'date'))))
After:
(func
('symbol', 'reverse')
(func
('symbol', 'sort')
(list
(or
('symbol', '2')
('symbol', '3'))
('symbol', 'date'))))
v2:
- Rebased on stable to avoid having to merge tests output
2012-02-24 14:02:21 +04:00
|
|
|
(or
|
2016-08-07 11:04:05 +03:00
|
|
|
(list
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '1')
|
2016-08-07 11:04:05 +03:00
|
|
|
(group
|
|
|
|
(or
|
|
|
|
(list
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2')
|
|
|
|
(symbol '3'))))))
|
2015-03-16 12:36:53 +03:00
|
|
|
* set:
|
|
|
|
<addset
|
|
|
|
<baseset [1]>,
|
2015-05-17 09:11:38 +03:00
|
|
|
<baseset [2, 3]>>
|
2010-08-30 08:23:32 +04:00
|
|
|
1
|
|
|
|
2
|
|
|
|
3
|
|
|
|
$ log '1.0' # tag
|
|
|
|
6
|
|
|
|
$ log 'a' # branch
|
|
|
|
0
|
|
|
|
$ log '2785f51ee'
|
|
|
|
0
|
|
|
|
$ log 'date(2005)'
|
|
|
|
4
|
|
|
|
$ log 'date(this is a test)'
|
|
|
|
hg: parse error at 10: unexpected token: symbol
|
2010-09-17 02:51:32 +04:00
|
|
|
[255]
|
2010-08-30 08:23:32 +04:00
|
|
|
$ log 'date()'
|
2010-10-16 20:50:53 +04:00
|
|
|
hg: parse error: date requires a string
|
2010-09-17 02:51:32 +04:00
|
|
|
[255]
|
2010-08-30 08:23:32 +04:00
|
|
|
$ log 'date'
|
2015-05-03 19:28:15 +03:00
|
|
|
abort: unknown revision 'date'!
|
2010-09-17 02:51:32 +04:00
|
|
|
[255]
|
2010-08-30 08:23:32 +04:00
|
|
|
$ log 'date('
|
|
|
|
hg: parse error at 5: not a prefix: end
|
2010-09-17 02:51:32 +04:00
|
|
|
[255]
|
2015-09-10 17:29:55 +03:00
|
|
|
$ log 'date("\xy")'
|
|
|
|
hg: parse error: invalid \x escape
|
|
|
|
[255]
|
2010-08-30 08:23:32 +04:00
|
|
|
$ log 'date(tip)'
|
2017-05-24 18:50:17 +03:00
|
|
|
hg: parse error: invalid date: 'tip'
|
2010-09-17 02:51:32 +04:00
|
|
|
[255]
|
2015-05-03 19:28:15 +03:00
|
|
|
$ log '0:date'
|
|
|
|
abort: unknown revision 'date'!
|
|
|
|
[255]
|
|
|
|
$ log '::"date"'
|
2010-08-30 08:23:32 +04:00
|
|
|
abort: unknown revision 'date'!
|
2010-09-17 02:51:32 +04:00
|
|
|
[255]
|
2015-05-03 19:28:15 +03:00
|
|
|
$ hg book date -r 4
|
|
|
|
$ log '0:date'
|
|
|
|
0
|
|
|
|
1
|
|
|
|
2
|
|
|
|
3
|
|
|
|
4
|
|
|
|
$ log '::date'
|
|
|
|
0
|
|
|
|
1
|
|
|
|
2
|
|
|
|
4
|
|
|
|
$ log '::"date"'
|
|
|
|
0
|
|
|
|
1
|
|
|
|
2
|
|
|
|
4
|
2010-08-30 08:23:32 +04:00
|
|
|
$ log 'date(2005) and 1::'
|
|
|
|
4
|
2015-05-03 19:28:15 +03:00
|
|
|
$ hg book -d date
|
|
|
|
|
2016-06-27 14:44:14 +03:00
|
|
|
function name should be a symbol
|
|
|
|
|
|
|
|
$ log '"date"(2005)'
|
|
|
|
hg: parse error: not a symbol
|
|
|
|
[255]
|
|
|
|
|
2015-06-27 11:05:28 +03:00
|
|
|
keyword arguments
|
|
|
|
|
2015-06-28 16:57:33 +03:00
|
|
|
$ log 'extra(branch, value=a)'
|
|
|
|
0
|
|
|
|
|
|
|
|
$ log 'extra(branch, a, b)'
|
2017-04-08 14:07:37 +03:00
|
|
|
hg: parse error: extra takes at most 2 positional arguments
|
2015-06-28 16:57:33 +03:00
|
|
|
[255]
|
|
|
|
$ log 'extra(a, label=b)'
|
|
|
|
hg: parse error: extra got multiple values for keyword argument 'label'
|
|
|
|
[255]
|
|
|
|
$ log 'extra(label=branch, default)'
|
|
|
|
hg: parse error: extra got an invalid argument
|
|
|
|
[255]
|
|
|
|
$ log 'extra(branch, foo+bar=baz)'
|
|
|
|
hg: parse error: extra got an invalid argument
|
|
|
|
[255]
|
|
|
|
$ log 'extra(unknown=branch)'
|
|
|
|
hg: parse error: extra got an unexpected keyword argument 'unknown'
|
|
|
|
[255]
|
|
|
|
|
2015-06-27 11:05:28 +03:00
|
|
|
$ try 'foo=bar|baz'
|
|
|
|
(keyvalue
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'foo')
|
2015-06-27 11:05:28 +03:00
|
|
|
(or
|
2016-08-07 11:04:05 +03:00
|
|
|
(list
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'bar')
|
|
|
|
(symbol 'baz'))))
|
2015-06-27 11:05:28 +03:00
|
|
|
hg: parse error: can't use a key-value pair in this context
|
|
|
|
[255]
|
|
|
|
|
2016-08-07 08:58:49 +03:00
|
|
|
right-hand side should be optimized recursively
|
|
|
|
|
|
|
|
$ try --optimize 'foo=(not public())'
|
|
|
|
(keyvalue
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'foo')
|
2016-08-07 08:58:49 +03:00
|
|
|
(group
|
|
|
|
(not
|
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'public')
|
2016-08-07 08:58:49 +03:00
|
|
|
None))))
|
|
|
|
* optimized:
|
|
|
|
(keyvalue
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'foo')
|
2016-08-07 08:58:49 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '_notpublic')
|
2017-08-20 20:55:11 +03:00
|
|
|
None))
|
2016-08-07 08:58:49 +03:00
|
|
|
hg: parse error: can't use a key-value pair in this context
|
|
|
|
[255]
|
|
|
|
|
2017-07-08 07:07:59 +03:00
|
|
|
relation-subscript operator has the highest binding strength (as function call):
|
|
|
|
|
|
|
|
$ hg debugrevspec -p parsed 'tip:tip^#generations[-1]'
|
|
|
|
* parsed:
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'tip')
|
2017-07-08 07:07:59 +03:00
|
|
|
(relsubscript
|
|
|
|
(parentpost
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'tip'))
|
|
|
|
(symbol 'generations')
|
2017-07-08 07:07:59 +03:00
|
|
|
(negate
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '1'))))
|
2017-07-08 07:15:17 +03:00
|
|
|
9
|
|
|
|
8
|
|
|
|
7
|
|
|
|
6
|
|
|
|
5
|
|
|
|
4
|
2017-07-08 07:07:59 +03:00
|
|
|
|
|
|
|
$ hg debugrevspec -p parsed --no-show-revs 'not public()#generations[0]'
|
|
|
|
* parsed:
|
|
|
|
(not
|
|
|
|
(relsubscript
|
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'public')
|
2017-07-08 07:07:59 +03:00
|
|
|
None)
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'generations')
|
|
|
|
(symbol '0')))
|
2017-07-08 07:07:59 +03:00
|
|
|
|
|
|
|
left-hand side of relation-subscript operator should be optimized recursively:
|
|
|
|
|
|
|
|
$ hg debugrevspec -p analyzed -p optimized --no-show-revs \
|
|
|
|
> '(not public())#generations[0]'
|
|
|
|
* analyzed:
|
|
|
|
(relsubscript
|
|
|
|
(not
|
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'public')
|
2017-08-20 20:55:11 +03:00
|
|
|
None))
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'generations')
|
|
|
|
(symbol '0'))
|
2017-07-08 07:07:59 +03:00
|
|
|
* optimized:
|
|
|
|
(relsubscript
|
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '_notpublic')
|
2017-08-20 20:55:11 +03:00
|
|
|
None)
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'generations')
|
|
|
|
(symbol '0'))
|
2017-07-08 07:07:59 +03:00
|
|
|
|
|
|
|
resolution of subscript and relation-subscript ternary operators:
|
|
|
|
|
|
|
|
$ hg debugrevspec -p analyzed 'tip[0]'
|
|
|
|
* analyzed:
|
|
|
|
(subscript
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'tip')
|
|
|
|
(symbol '0'))
|
2017-07-08 07:07:59 +03:00
|
|
|
hg: parse error: can't use a subscript in this context
|
|
|
|
[255]
|
|
|
|
|
|
|
|
$ hg debugrevspec -p analyzed 'tip#rel[0]'
|
|
|
|
* analyzed:
|
|
|
|
(relsubscript
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'tip')
|
|
|
|
(symbol 'rel')
|
|
|
|
(symbol '0'))
|
2017-07-08 07:15:17 +03:00
|
|
|
hg: parse error: unknown identifier: rel
|
2017-07-08 07:07:59 +03:00
|
|
|
[255]
|
|
|
|
|
|
|
|
$ hg debugrevspec -p analyzed '(tip#rel)[0]'
|
|
|
|
* analyzed:
|
|
|
|
(subscript
|
|
|
|
(relation
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'tip')
|
|
|
|
(symbol 'rel'))
|
|
|
|
(symbol '0'))
|
2017-07-08 07:07:59 +03:00
|
|
|
hg: parse error: can't use a subscript in this context
|
|
|
|
[255]
|
|
|
|
|
|
|
|
$ hg debugrevspec -p analyzed 'tip#rel[0][1]'
|
|
|
|
* analyzed:
|
|
|
|
(subscript
|
|
|
|
(relsubscript
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'tip')
|
|
|
|
(symbol 'rel')
|
|
|
|
(symbol '0'))
|
|
|
|
(symbol '1'))
|
2017-07-08 07:07:59 +03:00
|
|
|
hg: parse error: can't use a subscript in this context
|
|
|
|
[255]
|
|
|
|
|
|
|
|
$ hg debugrevspec -p analyzed 'tip#rel0#rel1[1]'
|
|
|
|
* analyzed:
|
|
|
|
(relsubscript
|
|
|
|
(relation
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'tip')
|
|
|
|
(symbol 'rel0'))
|
|
|
|
(symbol 'rel1')
|
|
|
|
(symbol '1'))
|
2017-07-08 07:15:17 +03:00
|
|
|
hg: parse error: unknown identifier: rel1
|
2017-07-08 07:07:59 +03:00
|
|
|
[255]
|
|
|
|
|
|
|
|
$ hg debugrevspec -p analyzed 'tip#rel0[0]#rel1[1]'
|
|
|
|
* analyzed:
|
|
|
|
(relsubscript
|
|
|
|
(relsubscript
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'tip')
|
|
|
|
(symbol 'rel0')
|
|
|
|
(symbol '0'))
|
|
|
|
(symbol 'rel1')
|
|
|
|
(symbol '1'))
|
2017-07-08 07:15:17 +03:00
|
|
|
hg: parse error: unknown identifier: rel1
|
2017-07-08 07:07:59 +03:00
|
|
|
[255]
|
|
|
|
|
|
|
|
parse errors of relation, subscript and relation-subscript operators:
|
|
|
|
|
|
|
|
$ hg debugrevspec '[0]'
|
|
|
|
hg: parse error at 0: not a prefix: [
|
|
|
|
[255]
|
|
|
|
$ hg debugrevspec '.#'
|
|
|
|
hg: parse error at 2: not a prefix: end
|
|
|
|
[255]
|
|
|
|
$ hg debugrevspec '#rel'
|
|
|
|
hg: parse error at 0: not a prefix: #
|
|
|
|
[255]
|
|
|
|
$ hg debugrevspec '.#rel[0'
|
|
|
|
hg: parse error at 7: unexpected token: end
|
|
|
|
[255]
|
|
|
|
$ hg debugrevspec '.]'
|
|
|
|
hg: parse error at 1: invalid token
|
|
|
|
[255]
|
|
|
|
|
2017-07-08 07:15:17 +03:00
|
|
|
$ hg debugrevspec '.#generations[a]'
|
|
|
|
hg: parse error: relation subscript must be an integer
|
|
|
|
[255]
|
|
|
|
$ hg debugrevspec '.#generations[1-2]'
|
|
|
|
hg: parse error: relation subscript must be an integer
|
|
|
|
[255]
|
|
|
|
|
2016-08-21 06:33:57 +03:00
|
|
|
parsed tree at stages:
|
|
|
|
|
|
|
|
$ hg debugrevspec -p all '()'
|
|
|
|
* parsed:
|
|
|
|
(group
|
|
|
|
None)
|
|
|
|
* expanded:
|
|
|
|
(group
|
|
|
|
None)
|
|
|
|
* concatenated:
|
|
|
|
(group
|
|
|
|
None)
|
|
|
|
* analyzed:
|
|
|
|
None
|
|
|
|
* optimized:
|
|
|
|
None
|
|
|
|
hg: parse error: missing argument
|
|
|
|
[255]
|
|
|
|
|
2016-08-21 06:40:02 +03:00
|
|
|
$ hg debugrevspec --no-optimized -p all '()'
|
|
|
|
* parsed:
|
|
|
|
(group
|
|
|
|
None)
|
|
|
|
* expanded:
|
|
|
|
(group
|
|
|
|
None)
|
|
|
|
* concatenated:
|
|
|
|
(group
|
|
|
|
None)
|
|
|
|
* analyzed:
|
|
|
|
None
|
|
|
|
hg: parse error: missing argument
|
|
|
|
[255]
|
|
|
|
|
2016-08-21 06:33:57 +03:00
|
|
|
$ hg debugrevspec -p parsed -p analyzed -p optimized '(0|1)-1'
|
|
|
|
* parsed:
|
|
|
|
(minus
|
|
|
|
(group
|
|
|
|
(or
|
2016-08-07 11:04:05 +03:00
|
|
|
(list
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '0')
|
|
|
|
(symbol '1'))))
|
|
|
|
(symbol '1'))
|
2016-08-21 06:33:57 +03:00
|
|
|
* analyzed:
|
|
|
|
(and
|
|
|
|
(or
|
2016-08-07 11:04:05 +03:00
|
|
|
(list
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '0')
|
|
|
|
(symbol '1')))
|
2016-08-21 06:33:57 +03:00
|
|
|
(not
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '1')))
|
2016-08-21 06:33:57 +03:00
|
|
|
* optimized:
|
|
|
|
(difference
|
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '_list')
|
|
|
|
(string '0\x001'))
|
|
|
|
(symbol '1'))
|
2016-08-21 06:33:57 +03:00
|
|
|
0
|
|
|
|
|
|
|
|
$ hg debugrevspec -p unknown '0'
|
|
|
|
abort: invalid stage name: unknown
|
|
|
|
[255]
|
|
|
|
|
|
|
|
$ hg debugrevspec -p all --optimize '0'
|
|
|
|
abort: cannot use --optimize with --show-stage
|
|
|
|
[255]
|
|
|
|
|
2016-08-21 07:16:21 +03:00
|
|
|
verify optimized tree:
|
|
|
|
|
|
|
|
$ hg debugrevspec --verify '0|1'
|
|
|
|
|
|
|
|
$ hg debugrevspec --verify -v -p analyzed -p optimized 'r3232() & 2'
|
|
|
|
* analyzed:
|
|
|
|
(and
|
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'r3232')
|
2017-08-20 20:55:11 +03:00
|
|
|
None)
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2'))
|
2016-08-21 07:16:21 +03:00
|
|
|
* optimized:
|
2017-08-31 02:05:12 +03:00
|
|
|
(andsmally
|
2016-08-21 07:16:21 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'r3232')
|
2017-08-31 02:05:12 +03:00
|
|
|
None)
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2'))
|
2016-08-21 07:16:21 +03:00
|
|
|
* analyzed set:
|
|
|
|
<baseset [2]>
|
|
|
|
* optimized set:
|
|
|
|
<baseset [2, 2]>
|
|
|
|
--- analyzed
|
|
|
|
+++ optimized
|
|
|
|
2
|
|
|
|
+2
|
|
|
|
[1]
|
|
|
|
|
|
|
|
$ hg debugrevspec --no-optimized --verify-optimized '0'
|
|
|
|
abort: cannot use --verify-optimized with --no-optimized
|
|
|
|
[255]
|
|
|
|
|
2015-05-03 19:28:15 +03:00
|
|
|
Test that symbols only get parsed as functions if there's an opening
|
|
|
|
parenthesis.
|
|
|
|
|
|
|
|
$ hg book only -r 9
|
|
|
|
$ log 'only(only)' # Outer "only" is a function, inner "only" is the bookmark
|
|
|
|
8
|
|
|
|
9
|
2010-08-30 08:23:32 +04:00
|
|
|
|
2016-10-01 14:20:11 +03:00
|
|
|
':y' behaves like '0:y', but can't be rewritten as such since the revision '0'
|
|
|
|
may be hidden (issue5385)
|
|
|
|
|
|
|
|
$ try -p parsed -p analyzed ':'
|
|
|
|
* parsed:
|
|
|
|
(rangeall
|
|
|
|
None)
|
|
|
|
* analyzed:
|
2017-01-09 10:55:56 +03:00
|
|
|
(rangeall
|
2017-08-20 20:55:11 +03:00
|
|
|
None)
|
2016-10-01 14:20:11 +03:00
|
|
|
* set:
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset+ 0:10>
|
2016-10-01 14:20:11 +03:00
|
|
|
0
|
|
|
|
1
|
|
|
|
2
|
|
|
|
3
|
|
|
|
4
|
|
|
|
5
|
|
|
|
6
|
|
|
|
7
|
|
|
|
8
|
|
|
|
9
|
|
|
|
$ try -p analyzed ':1'
|
|
|
|
* analyzed:
|
|
|
|
(rangepre
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '1'))
|
2016-10-01 14:20:11 +03:00
|
|
|
* set:
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset+ 0:2>
|
2016-10-01 14:20:11 +03:00
|
|
|
0
|
|
|
|
1
|
|
|
|
$ try -p analyzed ':(1|2)'
|
|
|
|
* analyzed:
|
|
|
|
(rangepre
|
|
|
|
(or
|
|
|
|
(list
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '1')
|
|
|
|
(symbol '2'))))
|
2016-10-01 14:20:11 +03:00
|
|
|
* set:
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset+ 0:3>
|
2016-10-01 14:20:11 +03:00
|
|
|
0
|
|
|
|
1
|
|
|
|
2
|
|
|
|
$ try -p analyzed ':(1&2)'
|
|
|
|
* analyzed:
|
|
|
|
(rangepre
|
|
|
|
(and
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '1')
|
|
|
|
(symbol '2')))
|
2016-10-01 14:20:11 +03:00
|
|
|
* set:
|
|
|
|
<baseset []>
|
|
|
|
|
2016-08-06 13:59:28 +03:00
|
|
|
infix/suffix resolution of ^ operator (issue2884):
|
|
|
|
|
|
|
|
x^:y means (x^):y
|
|
|
|
|
2016-08-06 14:21:00 +03:00
|
|
|
$ try '1^:2'
|
2016-08-06 13:59:28 +03:00
|
|
|
(range
|
|
|
|
(parentpost
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '1'))
|
|
|
|
(symbol '2'))
|
2016-08-06 13:59:28 +03:00
|
|
|
* set:
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset+ 0:3>
|
2016-08-06 13:59:28 +03:00
|
|
|
0
|
|
|
|
1
|
|
|
|
2
|
|
|
|
|
2016-08-06 14:21:00 +03:00
|
|
|
$ try '1^::2'
|
2016-08-06 13:59:28 +03:00
|
|
|
(dagrange
|
|
|
|
(parentpost
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '1'))
|
|
|
|
(symbol '2'))
|
2016-08-06 13:59:28 +03:00
|
|
|
* set:
|
|
|
|
<baseset+ [0, 1, 2]>
|
|
|
|
0
|
|
|
|
1
|
|
|
|
2
|
|
|
|
|
2016-08-06 14:37:48 +03:00
|
|
|
$ try '9^:'
|
|
|
|
(rangepost
|
|
|
|
(parentpost
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '9')))
|
2016-08-06 14:37:48 +03:00
|
|
|
* set:
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset+ 8:10>
|
2016-08-06 14:37:48 +03:00
|
|
|
8
|
|
|
|
9
|
|
|
|
|
2016-08-06 13:59:28 +03:00
|
|
|
x^:y should be resolved before omitting group operators
|
|
|
|
|
2016-08-06 14:21:00 +03:00
|
|
|
$ try '1^(:2)'
|
2016-08-06 13:59:28 +03:00
|
|
|
(parent
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '1')
|
2016-08-06 13:59:28 +03:00
|
|
|
(group
|
|
|
|
(rangepre
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2'))))
|
2016-08-06 13:59:28 +03:00
|
|
|
hg: parse error: ^ expects a number 0, 1, or 2
|
|
|
|
[255]
|
|
|
|
|
|
|
|
x^:y should be resolved recursively
|
|
|
|
|
2016-08-06 14:21:00 +03:00
|
|
|
$ try 'sort(1^:2)'
|
2016-08-06 13:59:28 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'sort')
|
2016-08-06 13:59:28 +03:00
|
|
|
(range
|
|
|
|
(parentpost
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '1'))
|
|
|
|
(symbol '2')))
|
2016-08-06 13:59:28 +03:00
|
|
|
* set:
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset+ 0:3>
|
2016-08-06 13:59:28 +03:00
|
|
|
0
|
|
|
|
1
|
|
|
|
2
|
|
|
|
|
2016-08-06 14:21:00 +03:00
|
|
|
$ try '(3^:4)^:2'
|
2016-08-06 13:59:28 +03:00
|
|
|
(range
|
|
|
|
(parentpost
|
2016-08-06 14:21:00 +03:00
|
|
|
(group
|
|
|
|
(range
|
|
|
|
(parentpost
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '3'))
|
|
|
|
(symbol '4'))))
|
|
|
|
(symbol '2'))
|
2016-08-06 13:59:28 +03:00
|
|
|
* set:
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset+ 0:3>
|
2016-08-06 13:59:28 +03:00
|
|
|
0
|
|
|
|
1
|
|
|
|
2
|
|
|
|
|
2016-08-06 14:21:00 +03:00
|
|
|
$ try '(3^::4)^::2'
|
2016-08-06 13:59:28 +03:00
|
|
|
(dagrange
|
|
|
|
(parentpost
|
2016-08-06 14:21:00 +03:00
|
|
|
(group
|
|
|
|
(dagrange
|
|
|
|
(parentpost
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '3'))
|
|
|
|
(symbol '4'))))
|
|
|
|
(symbol '2'))
|
2016-08-06 13:59:28 +03:00
|
|
|
* set:
|
|
|
|
<baseset+ [0, 1, 2]>
|
|
|
|
0
|
|
|
|
1
|
|
|
|
2
|
|
|
|
|
2016-08-06 14:37:48 +03:00
|
|
|
$ try '(9^:)^:'
|
|
|
|
(rangepost
|
|
|
|
(parentpost
|
|
|
|
(group
|
|
|
|
(rangepost
|
|
|
|
(parentpost
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '9'))))))
|
2016-08-06 14:37:48 +03:00
|
|
|
* set:
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset+ 4:10>
|
2016-08-06 14:37:48 +03:00
|
|
|
4
|
|
|
|
5
|
|
|
|
6
|
|
|
|
7
|
|
|
|
8
|
|
|
|
9
|
|
|
|
|
2016-08-06 13:59:28 +03:00
|
|
|
x^ in alias should also be resolved
|
|
|
|
|
2016-08-06 14:21:00 +03:00
|
|
|
$ try 'A' --config 'revsetalias.A=1^:2'
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'A')
|
2016-08-06 13:59:28 +03:00
|
|
|
* expanded:
|
|
|
|
(range
|
|
|
|
(parentpost
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '1'))
|
|
|
|
(symbol '2'))
|
2016-08-06 13:59:28 +03:00
|
|
|
* set:
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset+ 0:3>
|
2016-08-06 13:59:28 +03:00
|
|
|
0
|
|
|
|
1
|
|
|
|
2
|
|
|
|
|
2016-08-06 14:21:00 +03:00
|
|
|
$ try 'A:2' --config 'revsetalias.A=1^'
|
2016-08-06 13:59:28 +03:00
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'A')
|
|
|
|
(symbol '2'))
|
2016-08-06 13:59:28 +03:00
|
|
|
* expanded:
|
|
|
|
(range
|
|
|
|
(parentpost
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '1'))
|
|
|
|
(symbol '2'))
|
2016-08-06 13:59:28 +03:00
|
|
|
* set:
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset+ 0:3>
|
2016-08-06 13:59:28 +03:00
|
|
|
0
|
|
|
|
1
|
|
|
|
2
|
|
|
|
|
|
|
|
but not beyond the boundary of alias expansion, because the resolution should
|
|
|
|
be made at the parsing stage
|
|
|
|
|
2016-08-06 14:21:00 +03:00
|
|
|
$ try '1^A' --config 'revsetalias.A=:2'
|
2016-08-06 13:59:28 +03:00
|
|
|
(parent
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '1')
|
|
|
|
(symbol 'A'))
|
2016-08-06 13:59:28 +03:00
|
|
|
* expanded:
|
|
|
|
(parent
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '1')
|
2016-08-06 13:59:28 +03:00
|
|
|
(rangepre
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2')))
|
2016-08-06 14:21:00 +03:00
|
|
|
hg: parse error: ^ expects a number 0, 1, or 2
|
|
|
|
[255]
|
2016-08-06 13:59:28 +03:00
|
|
|
|
2013-01-29 00:19:21 +04:00
|
|
|
ancestor can accept 0 or more arguments
|
|
|
|
|
|
|
|
$ log 'ancestor()'
|
2010-08-30 08:23:32 +04:00
|
|
|
$ log 'ancestor(1)'
|
2013-01-29 00:19:21 +04:00
|
|
|
1
|
2010-08-30 08:23:32 +04:00
|
|
|
$ log 'ancestor(4,5)'
|
|
|
|
1
|
|
|
|
$ log 'ancestor(4,5) and 4'
|
2013-01-29 00:19:21 +04:00
|
|
|
$ log 'ancestor(0,0,1,3)'
|
|
|
|
0
|
|
|
|
$ log 'ancestor(3,1,5,3,5,1)'
|
|
|
|
1
|
|
|
|
$ log 'ancestor(0,1,3,5)'
|
|
|
|
0
|
|
|
|
$ log 'ancestor(1,2,3,4,5)'
|
|
|
|
1
|
2014-03-27 02:55:50 +04:00
|
|
|
|
|
|
|
test ancestors
|
|
|
|
|
2017-06-17 18:22:41 +03:00
|
|
|
$ hg log -G -T '{rev}\n' --config experimental.graphshorten=True
|
|
|
|
@ 9
|
|
|
|
o 8
|
|
|
|
| o 7
|
|
|
|
| o 6
|
|
|
|
|/|
|
|
|
|
| o 5
|
|
|
|
o | 4
|
|
|
|
| o 3
|
|
|
|
o | 2
|
|
|
|
|/
|
|
|
|
o 1
|
|
|
|
o 0
|
|
|
|
|
2010-08-30 08:23:32 +04:00
|
|
|
$ log 'ancestors(5)'
|
|
|
|
0
|
|
|
|
1
|
|
|
|
3
|
|
|
|
5
|
2013-01-29 00:19:21 +04:00
|
|
|
$ log 'ancestor(ancestors(5))'
|
|
|
|
0
|
2014-03-27 02:55:50 +04:00
|
|
|
$ log '::r3232()'
|
|
|
|
0
|
|
|
|
1
|
|
|
|
2
|
|
|
|
3
|
|
|
|
|
2017-06-17 18:22:41 +03:00
|
|
|
test ancestors with depth limit
|
|
|
|
|
|
|
|
(depth=0 selects the node itself)
|
|
|
|
|
|
|
|
$ log 'reverse(ancestors(9, depth=0))'
|
|
|
|
9
|
|
|
|
|
|
|
|
(interleaved: '4' would be missing if heap queue were higher depth first)
|
|
|
|
|
|
|
|
$ log 'reverse(ancestors(8:9, depth=1))'
|
|
|
|
9
|
|
|
|
8
|
|
|
|
4
|
|
|
|
|
|
|
|
(interleaved: '2' would be missing if heap queue were higher depth first)
|
|
|
|
|
|
|
|
$ log 'reverse(ancestors(7+8, depth=2))'
|
|
|
|
8
|
|
|
|
7
|
|
|
|
6
|
|
|
|
5
|
|
|
|
4
|
|
|
|
2
|
|
|
|
|
|
|
|
(walk example above by separate queries)
|
|
|
|
|
|
|
|
$ log 'reverse(ancestors(8, depth=2)) + reverse(ancestors(7, depth=2))'
|
|
|
|
8
|
|
|
|
4
|
|
|
|
2
|
|
|
|
7
|
|
|
|
6
|
|
|
|
5
|
|
|
|
|
2017-06-17 18:40:58 +03:00
|
|
|
(walk 2nd and 3rd ancestors)
|
|
|
|
|
|
|
|
$ log 'reverse(ancestors(7, depth=3, startdepth=2))'
|
|
|
|
5
|
|
|
|
4
|
|
|
|
3
|
|
|
|
2
|
|
|
|
|
|
|
|
(interleaved: '4' would be missing if higher-depth ancestors weren't scanned)
|
|
|
|
|
|
|
|
$ log 'reverse(ancestors(7+8, depth=2, startdepth=2))'
|
|
|
|
5
|
|
|
|
4
|
|
|
|
2
|
|
|
|
|
|
|
|
(note that 'ancestors(x, depth=y, startdepth=z)' does not identical to
|
|
|
|
'ancestors(x, depth=y) - ancestors(x, depth=z-1)' because a node may have
|
|
|
|
multiple depths)
|
|
|
|
|
|
|
|
$ log 'reverse(ancestors(7+8, depth=2) - ancestors(7+8, depth=1))'
|
|
|
|
5
|
|
|
|
2
|
|
|
|
|
2017-06-17 18:22:41 +03:00
|
|
|
test bad arguments passed to ancestors()
|
|
|
|
|
|
|
|
$ log 'ancestors(., depth=-1)'
|
|
|
|
hg: parse error: negative depth
|
|
|
|
[255]
|
|
|
|
$ log 'ancestors(., depth=foo)'
|
|
|
|
hg: parse error: ancestors expects an integer depth
|
|
|
|
[255]
|
|
|
|
|
2017-06-20 16:11:23 +03:00
|
|
|
test descendants
|
|
|
|
|
|
|
|
$ hg log -G -T '{rev}\n' --config experimental.graphshorten=True
|
|
|
|
@ 9
|
|
|
|
o 8
|
|
|
|
| o 7
|
|
|
|
| o 6
|
|
|
|
|/|
|
|
|
|
| o 5
|
|
|
|
o | 4
|
|
|
|
| o 3
|
|
|
|
o | 2
|
|
|
|
|/
|
|
|
|
o 1
|
|
|
|
o 0
|
|
|
|
|
|
|
|
(null is ultimate root and has optimized path)
|
|
|
|
|
|
|
|
$ log 'null:4 & descendants(null)'
|
|
|
|
-1
|
|
|
|
0
|
|
|
|
1
|
|
|
|
2
|
|
|
|
3
|
|
|
|
4
|
|
|
|
|
|
|
|
(including merge)
|
|
|
|
|
|
|
|
$ log ':8 & descendants(2)'
|
|
|
|
2
|
|
|
|
4
|
|
|
|
6
|
|
|
|
7
|
|
|
|
8
|
|
|
|
|
|
|
|
(multiple roots)
|
|
|
|
|
|
|
|
$ log ':8 & descendants(2+5)'
|
|
|
|
2
|
|
|
|
4
|
|
|
|
5
|
|
|
|
6
|
|
|
|
7
|
|
|
|
8
|
|
|
|
|
revset: add depth limit to descendants() (issue5374)
This is naive implementation using two-pass scanning. Tracking descendants
isn't an easy problem if both start and stop depths are specified. It's
impractical to remember all possible depths of each node while scanning from
roots to descendants because the number of depths explodes. Instead, we could
cache (min, max) depths as a good approximation and track ancestors back when
needed, but that's likely to have off-by-one bug.
Since this implementation appears not significantly slower, and is quite
straightforward, I think it's good enough for practical use cases. The time
and space complexity is O(n) ish.
revisions:
0) 1-pass scanning with (min, max)-depth cache (worst-case quadratic)
1) 2-pass scanning (this version)
repository:
mozilla-central
# descendants(0) (for reference)
*) 0.430353
# descendants(0, depth=1000)
0) 0.264889
1) 0.398289
# descendants(limit(tip:0, 1, offset=10000), depth=1000)
0) 0.025478
1) 0.029099
# descendants(0, depth=2000, startdepth=1000)
0) painfully slow (due to quadratic backtracking of ancestors)
1) 1.531138
2017-06-24 17:05:57 +03:00
|
|
|
test descendants with depth limit
|
|
|
|
|
|
|
|
(depth=0 selects the node itself)
|
|
|
|
|
|
|
|
$ log 'descendants(0, depth=0)'
|
|
|
|
0
|
|
|
|
$ log 'null: & descendants(null, depth=0)'
|
|
|
|
-1
|
|
|
|
|
|
|
|
(p2 = null should be ignored)
|
|
|
|
|
|
|
|
$ log 'null: & descendants(null, depth=2)'
|
|
|
|
-1
|
|
|
|
0
|
|
|
|
1
|
|
|
|
|
|
|
|
(multiple paths: depth(6) = (2, 3))
|
|
|
|
|
|
|
|
$ log 'descendants(1+3, depth=2)'
|
|
|
|
1
|
|
|
|
2
|
|
|
|
3
|
|
|
|
4
|
|
|
|
5
|
|
|
|
6
|
|
|
|
|
|
|
|
(multiple paths: depth(5) = (1, 2), depth(6) = (2, 3))
|
|
|
|
|
|
|
|
$ log 'descendants(3+1, depth=2, startdepth=2)'
|
|
|
|
4
|
|
|
|
5
|
|
|
|
6
|
|
|
|
|
|
|
|
(multiple depths: depth(6) = (0, 2, 4), search for depth=2)
|
|
|
|
|
|
|
|
$ log 'descendants(0+3+6, depth=3, startdepth=1)'
|
|
|
|
1
|
|
|
|
2
|
|
|
|
3
|
|
|
|
4
|
|
|
|
5
|
|
|
|
6
|
|
|
|
7
|
|
|
|
|
|
|
|
(multiple depths: depth(6) = (0, 4), no match)
|
|
|
|
|
|
|
|
$ log 'descendants(0+6, depth=3, startdepth=1)'
|
|
|
|
1
|
|
|
|
2
|
|
|
|
3
|
|
|
|
4
|
|
|
|
5
|
|
|
|
7
|
|
|
|
|
2017-07-08 07:15:17 +03:00
|
|
|
test ancestors/descendants relation subscript:
|
|
|
|
|
|
|
|
$ log 'tip#generations[0]'
|
|
|
|
9
|
|
|
|
$ log '.#generations[-1]'
|
|
|
|
8
|
|
|
|
$ log '.#g[(-1)]'
|
|
|
|
8
|
|
|
|
|
|
|
|
$ hg debugrevspec -p parsed 'roots(:)#g[2]'
|
|
|
|
* parsed:
|
|
|
|
(relsubscript
|
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'roots')
|
2017-07-08 07:15:17 +03:00
|
|
|
(rangeall
|
|
|
|
None))
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'g')
|
|
|
|
(symbol '2'))
|
2017-07-08 07:15:17 +03:00
|
|
|
2
|
|
|
|
3
|
|
|
|
|
2017-06-17 18:22:41 +03:00
|
|
|
test author
|
|
|
|
|
2010-08-30 08:23:32 +04:00
|
|
|
$ log 'author(bob)'
|
|
|
|
2
|
2012-05-31 02:13:58 +04:00
|
|
|
$ log 'author("re:bob|test")'
|
|
|
|
0
|
|
|
|
1
|
|
|
|
2
|
|
|
|
3
|
|
|
|
4
|
|
|
|
5
|
|
|
|
6
|
|
|
|
7
|
|
|
|
8
|
|
|
|
9
|
2017-01-12 06:42:10 +03:00
|
|
|
$ log 'author(r"re:\S")'
|
|
|
|
0
|
|
|
|
1
|
|
|
|
2
|
|
|
|
3
|
|
|
|
4
|
|
|
|
5
|
|
|
|
6
|
|
|
|
7
|
|
|
|
8
|
|
|
|
9
|
2010-08-30 08:23:32 +04:00
|
|
|
$ log 'branch(é)'
|
|
|
|
8
|
|
|
|
9
|
2012-05-31 02:13:33 +04:00
|
|
|
$ log 'branch(a)'
|
|
|
|
0
|
|
|
|
$ hg log -r 'branch("re:a")' --template '{rev} {branch}\n'
|
|
|
|
0 a
|
|
|
|
2 a-b-c-
|
|
|
|
3 +a+b+c+
|
|
|
|
4 -a-b-c-
|
test-revset: enable for Windows
In MSYS, the test fails like this if the hghave exit at the beginning is
removed:
--- C:\Users\adi\hgrepos\hg-main\tests\test-revset.t
+++ C:\Users\adi\hgrepos\hg-main\tests\test-revset.t.err
@@ -58,7 +58,7 @@
$ hg co 3
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
$ hg branch /a/b/c/
- marked working directory as branch /a/b/c/
+ marked working directory as branch a:/b/c/
(branches are permanent and global, did you want a bookmark?)
$ hg ci -Aqm"5 bug"
@@ -252,7 +252,7 @@
2 a-b-c-
3 +a+b+c+
4 -a-b-c-
- 5 /a/b/c/
+ 5 a:/b/c/
6 _a_b_c_
7 .a.b.c.
$ log 'children(ancestor(4,5))'
due to the posix path conversion done by MSYS globally, as explained here
http://www.mingw.org/wiki/Posix_path_conversion
The solution is a bit lame, but it is simple and works: don't use strings that
look like '/a/b', in order not to trigger the path magic done by MSYS.
So, if we can agree not to insist on testing branch names starting with '/',
then this relatively simple patch makes the test pass both on Windows with MSYS
and Linux.
2012-06-03 11:06:15 +04:00
|
|
|
5 !a/b/c/
|
2012-05-31 02:13:33 +04:00
|
|
|
6 _a_b_c_
|
|
|
|
7 .a.b.c.
|
2010-08-30 08:23:32 +04:00
|
|
|
$ log 'children(ancestor(4,5))'
|
|
|
|
2
|
|
|
|
3
|
2015-05-23 05:04:11 +03:00
|
|
|
|
|
|
|
$ log 'children(4)'
|
|
|
|
6
|
|
|
|
8
|
|
|
|
$ log 'children(null)'
|
|
|
|
0
|
|
|
|
|
2010-08-30 08:23:32 +04:00
|
|
|
$ log 'closed()'
|
|
|
|
$ log 'contains(a)'
|
|
|
|
0
|
|
|
|
1
|
|
|
|
3
|
|
|
|
5
|
2014-01-17 18:42:12 +04:00
|
|
|
$ log 'contains("../repo/a")'
|
|
|
|
0
|
|
|
|
1
|
|
|
|
3
|
|
|
|
5
|
2011-06-17 00:47:34 +04:00
|
|
|
$ log 'desc(B)'
|
|
|
|
5
|
2017-01-08 05:26:32 +03:00
|
|
|
$ hg log -r 'desc(r"re:S?u")' --template "{rev} {desc|firstline}\n"
|
|
|
|
5 5 bug
|
|
|
|
6 6 issue619
|
2010-08-30 08:23:32 +04:00
|
|
|
$ log 'descendants(2 or 3)'
|
|
|
|
2
|
|
|
|
3
|
|
|
|
4
|
|
|
|
5
|
|
|
|
6
|
|
|
|
7
|
|
|
|
8
|
|
|
|
9
|
2012-04-11 13:32:00 +04:00
|
|
|
$ log 'file("b*")'
|
2010-08-30 08:23:32 +04:00
|
|
|
1
|
|
|
|
4
|
2014-01-17 18:55:03 +04:00
|
|
|
$ log 'filelog("b")'
|
|
|
|
1
|
|
|
|
4
|
|
|
|
$ log 'filelog("../repo/b")'
|
|
|
|
1
|
|
|
|
4
|
2010-08-30 08:23:32 +04:00
|
|
|
$ log 'follow()'
|
|
|
|
0
|
|
|
|
1
|
|
|
|
2
|
|
|
|
4
|
|
|
|
8
|
|
|
|
9
|
|
|
|
$ log 'grep("issue\d+")'
|
|
|
|
6
|
2010-09-20 17:42:58 +04:00
|
|
|
$ try 'grep("(")' # invalid regular expression
|
debugrevspec: pretty print output
Before:
('func', ('symbol', 'reverse'), ('func', ('symbol', 'sort'), ('list', ('or',
('symbol', '2'), ('symbol', '3')), ('symbol', 'date'))))
After:
(func
('symbol', 'reverse')
(func
('symbol', 'sort')
(list
(or
('symbol', '2')
('symbol', '3'))
('symbol', 'date'))))
v2:
- Rebased on stable to avoid having to merge tests output
2012-02-24 14:02:21 +04:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'grep')
|
|
|
|
(string '('))
|
2010-09-20 17:42:58 +04:00
|
|
|
hg: parse error: invalid match pattern: unbalanced parenthesis
|
|
|
|
[255]
|
2010-09-25 00:36:53 +04:00
|
|
|
$ try 'grep("\bissue\d+")'
|
debugrevspec: pretty print output
Before:
('func', ('symbol', 'reverse'), ('func', ('symbol', 'sort'), ('list', ('or',
('symbol', '2'), ('symbol', '3')), ('symbol', 'date'))))
After:
(func
('symbol', 'reverse')
(func
('symbol', 'sort')
(list
(or
('symbol', '2')
('symbol', '3'))
('symbol', 'date'))))
v2:
- Rebased on stable to avoid having to merge tests output
2012-02-24 14:02:21 +04:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'grep')
|
|
|
|
(string '\x08issue\\d+'))
|
2015-03-16 12:36:53 +03:00
|
|
|
* set:
|
|
|
|
<filteredset
|
2017-06-10 18:21:38 +03:00
|
|
|
<fullreposet+ 0:10>,
|
2016-02-13 14:05:57 +03:00
|
|
|
<grep '\x08issue\\d+'>>
|
2010-09-25 00:36:53 +04:00
|
|
|
$ try 'grep(r"\bissue\d+")'
|
debugrevspec: pretty print output
Before:
('func', ('symbol', 'reverse'), ('func', ('symbol', 'sort'), ('list', ('or',
('symbol', '2'), ('symbol', '3')), ('symbol', 'date'))))
After:
(func
('symbol', 'reverse')
(func
('symbol', 'sort')
(list
(or
('symbol', '2')
('symbol', '3'))
('symbol', 'date'))))
v2:
- Rebased on stable to avoid having to merge tests output
2012-02-24 14:02:21 +04:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'grep')
|
|
|
|
(string '\\bissue\\d+'))
|
2015-03-16 12:36:53 +03:00
|
|
|
* set:
|
|
|
|
<filteredset
|
2017-06-10 18:21:38 +03:00
|
|
|
<fullreposet+ 0:10>,
|
2016-02-13 14:05:57 +03:00
|
|
|
<grep '\\bissue\\d+'>>
|
2010-09-25 00:36:53 +04:00
|
|
|
6
|
|
|
|
$ try 'grep(r"\")'
|
|
|
|
hg: parse error at 7: unterminated string
|
|
|
|
[255]
|
2010-08-30 08:23:32 +04:00
|
|
|
$ log 'head()'
|
|
|
|
0
|
|
|
|
1
|
|
|
|
2
|
|
|
|
3
|
|
|
|
4
|
|
|
|
5
|
|
|
|
6
|
|
|
|
7
|
|
|
|
9
|
|
|
|
$ log 'heads(6::)'
|
|
|
|
7
|
|
|
|
$ log 'keyword(issue)'
|
|
|
|
6
|
2013-08-06 00:52:06 +04:00
|
|
|
$ log 'keyword("test a")'
|
2017-06-10 12:04:56 +03:00
|
|
|
|
|
|
|
Test first (=limit) and last
|
|
|
|
|
2010-08-30 08:23:32 +04:00
|
|
|
$ log 'limit(head(), 1)'
|
|
|
|
0
|
2015-03-23 18:28:28 +03:00
|
|
|
$ log 'limit(author("re:bob|test"), 3, 5)'
|
|
|
|
5
|
|
|
|
6
|
|
|
|
7
|
|
|
|
$ log 'limit(author("re:bob|test"), offset=6)'
|
|
|
|
6
|
|
|
|
$ log 'limit(author("re:bob|test"), offset=10)'
|
|
|
|
$ log 'limit(all(), 1, -1)'
|
|
|
|
hg: parse error: negative offset
|
|
|
|
[255]
|
2017-06-10 12:35:11 +03:00
|
|
|
$ log 'limit(all(), -1)'
|
|
|
|
hg: parse error: negative number to select
|
|
|
|
[255]
|
|
|
|
$ log 'limit(all(), 0)'
|
2017-06-10 12:04:56 +03:00
|
|
|
|
2017-06-10 12:35:11 +03:00
|
|
|
$ log 'last(all(), -1)'
|
|
|
|
hg: parse error: negative number to select
|
|
|
|
[255]
|
2017-06-10 12:04:56 +03:00
|
|
|
$ log 'last(all(), 0)'
|
|
|
|
$ log 'last(all(), 1)'
|
|
|
|
9
|
|
|
|
$ log 'last(all(), 2)'
|
|
|
|
8
|
|
|
|
9
|
|
|
|
|
2015-03-23 18:14:53 +03:00
|
|
|
Test smartset.slice() by first/last()
|
|
|
|
|
|
|
|
(using unoptimized set, filteredset as example)
|
|
|
|
|
|
|
|
$ hg debugrevspec --no-show-revs -s '0:7 & branch("re:")'
|
|
|
|
* set:
|
|
|
|
<filteredset
|
|
|
|
<spanset+ 0:8>,
|
|
|
|
<branch 're:'>>
|
|
|
|
$ log 'limit(0:7 & branch("re:"), 3, 4)'
|
|
|
|
4
|
|
|
|
5
|
|
|
|
6
|
|
|
|
$ log 'limit(7:0 & branch("re:"), 3, 4)'
|
|
|
|
3
|
|
|
|
2
|
|
|
|
1
|
|
|
|
$ log 'last(0:7 & branch("re:"), 2)'
|
|
|
|
6
|
|
|
|
7
|
|
|
|
|
2015-04-09 17:56:06 +03:00
|
|
|
(using baseset)
|
|
|
|
|
|
|
|
$ hg debugrevspec --no-show-revs -s 0+1+2+3+4+5+6+7
|
|
|
|
* set:
|
|
|
|
<baseset [0, 1, 2, 3, 4, 5, 6, 7]>
|
|
|
|
$ hg debugrevspec --no-show-revs -s 0::7
|
|
|
|
* set:
|
|
|
|
<baseset+ [0, 1, 2, 3, 4, 5, 6, 7]>
|
|
|
|
$ log 'limit(0+1+2+3+4+5+6+7, 3, 4)'
|
|
|
|
4
|
|
|
|
5
|
|
|
|
6
|
|
|
|
$ log 'limit(sort(0::7, rev), 3, 4)'
|
|
|
|
4
|
|
|
|
5
|
|
|
|
6
|
|
|
|
$ log 'limit(sort(0::7, -rev), 3, 4)'
|
|
|
|
3
|
|
|
|
2
|
|
|
|
1
|
|
|
|
$ log 'last(sort(0::7, rev), 2)'
|
|
|
|
6
|
|
|
|
7
|
|
|
|
$ hg debugrevspec -s 'limit(sort(0::7, rev), 3, 6)'
|
|
|
|
* set:
|
|
|
|
<baseset+ [6, 7]>
|
|
|
|
6
|
|
|
|
7
|
|
|
|
$ hg debugrevspec -s 'limit(sort(0::7, rev), 3, 9)'
|
|
|
|
* set:
|
|
|
|
<baseset+ []>
|
|
|
|
$ hg debugrevspec -s 'limit(sort(0::7, -rev), 3, 6)'
|
|
|
|
* set:
|
|
|
|
<baseset- [0, 1]>
|
|
|
|
1
|
|
|
|
0
|
|
|
|
$ hg debugrevspec -s 'limit(sort(0::7, -rev), 3, 9)'
|
|
|
|
* set:
|
|
|
|
<baseset- []>
|
|
|
|
$ hg debugrevspec -s 'limit(0::7, 0)'
|
|
|
|
* set:
|
|
|
|
<baseset+ []>
|
|
|
|
|
2015-04-09 18:14:16 +03:00
|
|
|
(using spanset)
|
|
|
|
|
|
|
|
$ hg debugrevspec --no-show-revs -s 0:7
|
|
|
|
* set:
|
|
|
|
<spanset+ 0:8>
|
|
|
|
$ log 'limit(0:7, 3, 4)'
|
|
|
|
4
|
|
|
|
5
|
|
|
|
6
|
|
|
|
$ log 'limit(7:0, 3, 4)'
|
|
|
|
3
|
|
|
|
2
|
|
|
|
1
|
|
|
|
$ log 'limit(0:7, 3, 6)'
|
|
|
|
6
|
|
|
|
7
|
|
|
|
$ log 'limit(7:0, 3, 6)'
|
|
|
|
1
|
|
|
|
0
|
|
|
|
$ log 'last(0:7, 2)'
|
|
|
|
6
|
|
|
|
7
|
|
|
|
$ hg debugrevspec -s 'limit(0:7, 3, 6)'
|
|
|
|
* set:
|
|
|
|
<spanset+ 6:8>
|
|
|
|
6
|
|
|
|
7
|
|
|
|
$ hg debugrevspec -s 'limit(0:7, 3, 9)'
|
|
|
|
* set:
|
|
|
|
<spanset+ 8:8>
|
|
|
|
$ hg debugrevspec -s 'limit(7:0, 3, 6)'
|
|
|
|
* set:
|
|
|
|
<spanset- 0:2>
|
|
|
|
1
|
|
|
|
0
|
|
|
|
$ hg debugrevspec -s 'limit(7:0, 3, 9)'
|
|
|
|
* set:
|
|
|
|
<spanset- 0:0>
|
|
|
|
$ hg debugrevspec -s 'limit(0:7, 0)'
|
|
|
|
* set:
|
|
|
|
<spanset+ 0:0>
|
|
|
|
|
2017-06-10 13:41:42 +03:00
|
|
|
Test order of first/last revisions
|
|
|
|
|
|
|
|
$ hg debugrevspec -s 'first(4:0, 3) & 3:'
|
|
|
|
* set:
|
|
|
|
<filteredset
|
2015-04-09 18:14:16 +03:00
|
|
|
<spanset- 2:5>,
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset+ 3:10>>
|
2017-06-10 13:41:42 +03:00
|
|
|
4
|
|
|
|
3
|
|
|
|
|
|
|
|
$ hg debugrevspec -s '3: & first(4:0, 3)'
|
|
|
|
* set:
|
|
|
|
<filteredset
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset+ 3:10>,
|
2015-04-09 18:14:16 +03:00
|
|
|
<spanset- 2:5>>
|
2017-06-10 13:41:42 +03:00
|
|
|
3
|
2017-06-10 13:48:48 +03:00
|
|
|
4
|
2017-06-10 13:41:42 +03:00
|
|
|
|
|
|
|
$ hg debugrevspec -s 'last(4:0, 3) & :1'
|
|
|
|
* set:
|
|
|
|
<filteredset
|
2015-04-09 18:14:16 +03:00
|
|
|
<spanset- 0:3>,
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset+ 0:2>>
|
2017-06-10 13:41:42 +03:00
|
|
|
1
|
|
|
|
0
|
|
|
|
|
|
|
|
$ hg debugrevspec -s ':1 & last(4:0, 3)'
|
|
|
|
* set:
|
|
|
|
<filteredset
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset+ 0:2>,
|
2015-04-09 18:14:16 +03:00
|
|
|
<spanset+ 0:3>>
|
2017-06-10 13:41:42 +03:00
|
|
|
0
|
2017-06-10 13:48:48 +03:00
|
|
|
1
|
2017-06-10 13:41:42 +03:00
|
|
|
|
2017-06-27 17:50:22 +03:00
|
|
|
Test scmutil.revsingle() should return the last revision
|
|
|
|
|
|
|
|
$ hg debugrevspec -s 'last(0::)'
|
|
|
|
* set:
|
|
|
|
<baseset slice=0:1
|
|
|
|
<generatorset->>
|
|
|
|
9
|
|
|
|
$ hg identify -r '0::' --num
|
|
|
|
9
|
|
|
|
|
2017-06-10 12:04:56 +03:00
|
|
|
Test matching
|
|
|
|
|
2012-04-15 02:27:31 +04:00
|
|
|
$ log 'matching(6)'
|
|
|
|
6
|
|
|
|
$ log 'matching(6:7, "phase parents user date branch summary files description substate")'
|
|
|
|
6
|
|
|
|
7
|
2014-03-29 04:00:13 +04:00
|
|
|
|
|
|
|
Testing min and max
|
|
|
|
|
|
|
|
max: simple
|
|
|
|
|
2010-08-30 08:23:32 +04:00
|
|
|
$ log 'max(contains(a))'
|
|
|
|
5
|
2014-03-29 04:00:13 +04:00
|
|
|
|
|
|
|
max: simple on unordered set)
|
|
|
|
|
|
|
|
$ log 'max((4+0+2+5+7) and contains(a))'
|
|
|
|
5
|
|
|
|
|
|
|
|
max: no result
|
|
|
|
|
|
|
|
$ log 'max(contains(stringthatdoesnotappearanywhere))'
|
|
|
|
|
|
|
|
max: no result on unordered set
|
|
|
|
|
|
|
|
$ log 'max((4+0+2+5+7) and contains(stringthatdoesnotappearanywhere))'
|
|
|
|
|
|
|
|
min: simple
|
|
|
|
|
2010-08-30 08:23:32 +04:00
|
|
|
$ log 'min(contains(a))'
|
|
|
|
0
|
2014-03-29 04:00:13 +04:00
|
|
|
|
|
|
|
min: simple on unordered set
|
|
|
|
|
|
|
|
$ log 'min((4+0+2+5+7) and contains(a))'
|
|
|
|
0
|
|
|
|
|
|
|
|
min: empty
|
|
|
|
|
|
|
|
$ log 'min(contains(stringthatdoesnotappearanywhere))'
|
|
|
|
|
|
|
|
min: empty on unordered set
|
|
|
|
|
|
|
|
$ log 'min((4+0+2+5+7) and contains(stringthatdoesnotappearanywhere))'
|
|
|
|
|
|
|
|
|
2010-08-30 08:23:32 +04:00
|
|
|
$ log 'merge()'
|
|
|
|
6
|
2012-08-13 23:50:45 +04:00
|
|
|
$ log 'branchpoint()'
|
|
|
|
1
|
|
|
|
4
|
2010-08-30 08:23:32 +04:00
|
|
|
$ log 'modifies(b)'
|
|
|
|
4
|
2012-04-26 16:24:46 +04:00
|
|
|
$ log 'modifies("path:b")'
|
|
|
|
4
|
|
|
|
$ log 'modifies("*")'
|
|
|
|
4
|
|
|
|
6
|
|
|
|
$ log 'modifies("set:modified()")'
|
|
|
|
4
|
2010-10-11 18:44:19 +04:00
|
|
|
$ log 'id(5)'
|
|
|
|
2
|
2013-11-16 20:57:08 +04:00
|
|
|
$ log 'only(9)'
|
|
|
|
8
|
|
|
|
9
|
|
|
|
$ log 'only(8)'
|
|
|
|
8
|
|
|
|
$ log 'only(9, 5)'
|
|
|
|
2
|
|
|
|
4
|
|
|
|
8
|
|
|
|
9
|
|
|
|
$ log 'only(7 + 9, 5 + 2)'
|
|
|
|
4
|
|
|
|
6
|
|
|
|
7
|
2014-07-19 03:46:56 +04:00
|
|
|
8
|
|
|
|
9
|
|
|
|
|
|
|
|
Test empty set input
|
|
|
|
$ log 'only(p2())'
|
|
|
|
$ log 'only(p1(), p2())'
|
|
|
|
0
|
|
|
|
1
|
|
|
|
2
|
|
|
|
4
|
2013-11-16 20:57:08 +04:00
|
|
|
8
|
|
|
|
9
|
2014-10-19 11:48:33 +04:00
|
|
|
|
2014-11-07 01:55:18 +03:00
|
|
|
Test '%' operator
|
|
|
|
|
|
|
|
$ log '9%'
|
|
|
|
8
|
|
|
|
9
|
|
|
|
$ log '9%5'
|
|
|
|
2
|
|
|
|
4
|
|
|
|
8
|
|
|
|
9
|
|
|
|
$ log '(7 + 9)%(5 + 2)'
|
|
|
|
4
|
|
|
|
6
|
|
|
|
7
|
|
|
|
8
|
|
|
|
9
|
|
|
|
|
2016-10-18 00:16:55 +03:00
|
|
|
Test operand of '%' is optimized recursively (issue4670)
|
2015-05-15 16:32:31 +03:00
|
|
|
|
|
|
|
$ try --optimize '8:9-8%'
|
|
|
|
(onlypost
|
|
|
|
(minus
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '8')
|
|
|
|
(symbol '9'))
|
|
|
|
(symbol '8')))
|
2015-05-15 16:32:31 +03:00
|
|
|
* optimized:
|
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'only')
|
2016-02-24 21:41:15 +03:00
|
|
|
(difference
|
2015-05-15 16:32:31 +03:00
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '8')
|
|
|
|
(symbol '9'))
|
|
|
|
(symbol '8')))
|
2015-05-15 16:32:31 +03:00
|
|
|
* set:
|
|
|
|
<baseset+ [8, 9]>
|
|
|
|
8
|
|
|
|
9
|
2015-05-15 16:38:24 +03:00
|
|
|
$ try --optimize '(9)%(5)'
|
|
|
|
(only
|
|
|
|
(group
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '9'))
|
2015-05-15 16:38:24 +03:00
|
|
|
(group
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '5')))
|
2015-05-15 16:38:24 +03:00
|
|
|
* optimized:
|
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'only')
|
2015-05-15 16:38:24 +03:00
|
|
|
(list
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '9')
|
|
|
|
(symbol '5')))
|
2015-05-15 16:38:24 +03:00
|
|
|
* set:
|
2016-04-05 03:45:15 +03:00
|
|
|
<baseset+ [2, 4, 8, 9]>
|
2015-05-15 16:38:24 +03:00
|
|
|
2
|
|
|
|
4
|
|
|
|
8
|
|
|
|
9
|
2015-05-15 16:32:31 +03:00
|
|
|
|
2014-11-07 01:55:18 +03:00
|
|
|
Test the order of operations
|
|
|
|
|
|
|
|
$ log '7 + 9%5 + 2'
|
|
|
|
7
|
|
|
|
2
|
|
|
|
4
|
|
|
|
8
|
|
|
|
9
|
|
|
|
|
2014-10-19 11:48:33 +04:00
|
|
|
Test explicit numeric revision
|
2015-01-10 06:56:38 +03:00
|
|
|
$ log 'rev(-2)'
|
2014-10-19 11:48:33 +04:00
|
|
|
$ log 'rev(-1)'
|
2015-01-10 06:56:38 +03:00
|
|
|
-1
|
2014-10-19 11:48:33 +04:00
|
|
|
$ log 'rev(0)'
|
|
|
|
0
|
|
|
|
$ log 'rev(9)'
|
|
|
|
9
|
|
|
|
$ log 'rev(10)'
|
|
|
|
$ log 'rev(tip)'
|
|
|
|
hg: parse error: rev expects a number
|
|
|
|
[255]
|
|
|
|
|
2015-04-20 10:52:20 +03:00
|
|
|
Test hexadecimal revision
|
|
|
|
$ log 'id(2)'
|
|
|
|
abort: 00changelog.i@2: ambiguous identifier!
|
|
|
|
[255]
|
|
|
|
$ log 'id(23268)'
|
|
|
|
4
|
|
|
|
$ log 'id(2785f51eece)'
|
|
|
|
0
|
|
|
|
$ log 'id(d5d0dcbdc4d9ff5dbb2d336f32f0bb561c1a532c)'
|
|
|
|
8
|
|
|
|
$ log 'id(d5d0dcbdc4a)'
|
|
|
|
$ log 'id(d5d0dcbdc4w)'
|
|
|
|
$ log 'id(d5d0dcbdc4d9ff5dbb2d336f32f0bb561c1a532d)'
|
|
|
|
$ log 'id(d5d0dcbdc4d9ff5dbb2d336f32f0bb561c1a532q)'
|
|
|
|
$ log 'id(1.0)'
|
|
|
|
$ log 'id(xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx)'
|
|
|
|
|
2015-01-25 14:20:27 +03:00
|
|
|
Test null revision
|
2015-01-08 17:05:45 +03:00
|
|
|
$ log '(null)'
|
|
|
|
-1
|
|
|
|
$ log '(null:0)'
|
|
|
|
-1
|
|
|
|
0
|
|
|
|
$ log '(0:null)'
|
|
|
|
0
|
|
|
|
-1
|
|
|
|
$ log 'null::0'
|
|
|
|
-1
|
|
|
|
0
|
|
|
|
$ log 'null:tip - 0:'
|
|
|
|
-1
|
|
|
|
$ log 'null: and null::' | head -1
|
|
|
|
-1
|
|
|
|
$ log 'null: or 0:' | head -2
|
|
|
|
-1
|
|
|
|
0
|
2015-01-25 14:20:27 +03:00
|
|
|
$ log 'ancestors(null)'
|
|
|
|
-1
|
2015-01-08 17:05:45 +03:00
|
|
|
$ log 'reverse(null:)' | tail -2
|
|
|
|
0
|
|
|
|
-1
|
|
|
|
$ log 'first(null:)'
|
2017-06-10 13:41:42 +03:00
|
|
|
-1
|
2015-01-08 17:05:45 +03:00
|
|
|
$ log 'min(null:)'
|
2017-06-10 13:41:42 +03:00
|
|
|
BROKEN: should be '-1'
|
2015-01-10 08:49:50 +03:00
|
|
|
$ log 'tip:null and all()' | tail -2
|
|
|
|
1
|
|
|
|
0
|
2015-01-25 14:20:27 +03:00
|
|
|
|
2014-08-16 08:44:16 +04:00
|
|
|
Test working-directory revision
|
|
|
|
$ hg debugrevspec 'wdir()'
|
2015-03-16 10:17:06 +03:00
|
|
|
2147483647
|
2017-05-19 17:36:45 +03:00
|
|
|
$ hg debugrevspec 'wdir()^'
|
|
|
|
9
|
|
|
|
$ hg up 7
|
|
|
|
0 files updated, 0 files merged, 1 files removed, 0 files unresolved
|
|
|
|
$ hg debugrevspec 'wdir()^'
|
|
|
|
7
|
2017-05-21 23:05:53 +03:00
|
|
|
$ hg debugrevspec 'wdir()^0'
|
|
|
|
2147483647
|
2017-05-22 22:38:19 +03:00
|
|
|
$ hg debugrevspec 'wdir()~3'
|
|
|
|
5
|
2017-05-22 22:52:33 +03:00
|
|
|
$ hg debugrevspec 'ancestors(wdir())'
|
|
|
|
0
|
|
|
|
1
|
|
|
|
2
|
|
|
|
3
|
|
|
|
4
|
|
|
|
5
|
|
|
|
6
|
|
|
|
7
|
|
|
|
2147483647
|
2017-05-21 23:05:53 +03:00
|
|
|
$ hg debugrevspec 'wdir()~0'
|
|
|
|
2147483647
|
|
|
|
$ hg debugrevspec 'p1(wdir())'
|
|
|
|
7
|
2017-05-21 23:44:22 +03:00
|
|
|
$ hg debugrevspec 'p2(wdir())'
|
2017-05-21 23:05:53 +03:00
|
|
|
$ hg debugrevspec 'parents(wdir())'
|
|
|
|
7
|
2017-05-21 22:31:45 +03:00
|
|
|
$ hg debugrevspec 'wdir()^1'
|
|
|
|
7
|
|
|
|
$ hg debugrevspec 'wdir()^2'
|
|
|
|
$ hg debugrevspec 'wdir()^3'
|
|
|
|
hg: parse error: ^ expects a number 0, 1, or 2
|
|
|
|
[255]
|
2017-05-19 17:36:45 +03:00
|
|
|
For tests consistency
|
|
|
|
$ hg up 9
|
|
|
|
1 files updated, 0 files merged, 0 files removed, 0 files unresolved
|
2014-08-16 08:44:16 +04:00
|
|
|
$ hg debugrevspec 'tip or wdir()'
|
|
|
|
9
|
2015-03-16 10:17:06 +03:00
|
|
|
2147483647
|
2014-08-16 08:44:16 +04:00
|
|
|
$ hg debugrevspec '0:tip and wdir()'
|
2015-06-28 10:08:07 +03:00
|
|
|
$ log '0:wdir()' | tail -3
|
|
|
|
8
|
|
|
|
9
|
|
|
|
2147483647
|
|
|
|
$ log 'wdir():0' | head -3
|
|
|
|
2147483647
|
|
|
|
9
|
|
|
|
8
|
|
|
|
$ log 'wdir():wdir()'
|
|
|
|
2147483647
|
2015-03-16 10:17:06 +03:00
|
|
|
$ log '(all() + wdir()) & min(. + wdir())'
|
|
|
|
9
|
|
|
|
$ log '(all() + wdir()) & max(. + wdir())'
|
|
|
|
2147483647
|
2017-06-10 13:41:42 +03:00
|
|
|
$ log 'first(wdir() + .)'
|
2015-03-16 10:17:06 +03:00
|
|
|
2147483647
|
2017-06-10 13:41:42 +03:00
|
|
|
$ log 'last(. + wdir())'
|
2015-03-16 10:17:06 +03:00
|
|
|
2147483647
|
2014-08-16 08:44:16 +04:00
|
|
|
|
2017-06-03 14:39:33 +03:00
|
|
|
Test working-directory integer revision and node id
|
|
|
|
(BUG: '0:wdir()' is still needed to populate wdir revision)
|
|
|
|
|
|
|
|
$ hg debugrevspec '0:wdir() & 2147483647'
|
|
|
|
2147483647
|
|
|
|
$ hg debugrevspec '0:wdir() & rev(2147483647)'
|
|
|
|
2147483647
|
|
|
|
$ hg debugrevspec '0:wdir() & ffffffffffffffffffffffffffffffffffffffff'
|
|
|
|
2147483647
|
2016-08-19 12:26:04 +03:00
|
|
|
$ hg debugrevspec '0:wdir() & ffffffffffff'
|
|
|
|
2147483647
|
2017-06-03 14:39:33 +03:00
|
|
|
$ hg debugrevspec '0:wdir() & id(ffffffffffffffffffffffffffffffffffffffff)'
|
|
|
|
2147483647
|
|
|
|
$ hg debugrevspec '0:wdir() & id(ffffffffffff)'
|
2016-08-19 12:26:04 +03:00
|
|
|
2147483647
|
|
|
|
|
|
|
|
$ cd ..
|
|
|
|
|
|
|
|
Test short 'ff...' hash collision
|
|
|
|
(BUG: '0:wdir()' is still needed to populate wdir revision)
|
|
|
|
|
|
|
|
$ hg init wdir-hashcollision
|
|
|
|
$ cd wdir-hashcollision
|
|
|
|
$ cat <<EOF >> .hg/hgrc
|
|
|
|
> [experimental]
|
2017-09-28 20:19:06 +03:00
|
|
|
> evolution.createmarkers=True
|
2016-08-19 12:26:04 +03:00
|
|
|
> EOF
|
|
|
|
$ echo 0 > a
|
|
|
|
$ hg ci -qAm 0
|
|
|
|
$ for i in 2463 2961 6726 78127; do
|
|
|
|
> hg up -q 0
|
|
|
|
> echo $i > a
|
|
|
|
> hg ci -qm $i
|
|
|
|
> done
|
|
|
|
$ hg up -q null
|
|
|
|
$ hg log -r '0:wdir()' -T '{rev}:{node} {shortest(node, 3)}\n'
|
|
|
|
0:b4e73ffab476aa0ee32ed81ca51e07169844bc6a b4e
|
|
|
|
1:fffbae3886c8fbb2114296380d276fd37715d571 fffba
|
|
|
|
2:fffb6093b00943f91034b9bdad069402c834e572 fffb6
|
|
|
|
3:fff48a9b9de34a4d64120c29548214c67980ade3 fff4
|
|
|
|
4:ffff85cff0ff78504fcdc3c0bc10de0c65379249 ffff8
|
|
|
|
2147483647:ffffffffffffffffffffffffffffffffffffffff fffff
|
|
|
|
$ hg debugobsolete fffbae3886c8fbb2114296380d276fd37715d571
|
2017-07-16 03:33:14 +03:00
|
|
|
obsoleted 1 changesets
|
2016-08-19 12:26:04 +03:00
|
|
|
|
|
|
|
$ hg debugrevspec '0:wdir() & fff'
|
|
|
|
abort: 00changelog.i@fff: ambiguous identifier!
|
|
|
|
[255]
|
|
|
|
$ hg debugrevspec '0:wdir() & ffff'
|
|
|
|
abort: 00changelog.i@ffff: ambiguous identifier!
|
|
|
|
[255]
|
|
|
|
$ hg debugrevspec '0:wdir() & fffb'
|
|
|
|
abort: 00changelog.i@fffb: ambiguous identifier!
|
|
|
|
[255]
|
|
|
|
BROKEN should be '2' (node lookup uses unfiltered repo since dc25ed84bee8)
|
|
|
|
$ hg debugrevspec '0:wdir() & id(fffb)'
|
|
|
|
2
|
|
|
|
$ hg debugrevspec '0:wdir() & ffff8'
|
|
|
|
4
|
|
|
|
$ hg debugrevspec '0:wdir() & fffff'
|
|
|
|
2147483647
|
|
|
|
|
|
|
|
$ cd ..
|
2017-06-03 14:39:33 +03:00
|
|
|
|
2016-08-20 12:15:19 +03:00
|
|
|
Test branch() with wdir()
|
|
|
|
|
2016-08-19 12:26:04 +03:00
|
|
|
$ cd repo
|
|
|
|
|
2016-08-20 12:15:19 +03:00
|
|
|
$ log '0:wdir() & branch("literal:é")'
|
|
|
|
8
|
|
|
|
9
|
|
|
|
2147483647
|
|
|
|
$ log '0:wdir() & branch("re:é")'
|
|
|
|
8
|
|
|
|
9
|
|
|
|
2147483647
|
|
|
|
$ log '0:wdir() & branch("re:^a")'
|
|
|
|
0
|
|
|
|
2
|
|
|
|
$ log '0:wdir() & branch(8)'
|
|
|
|
8
|
|
|
|
9
|
|
|
|
2147483647
|
|
|
|
|
|
|
|
branch(wdir()) returns all revisions belonging to the working branch. The wdir
|
|
|
|
itself isn't returned unless it is explicitly populated.
|
|
|
|
|
|
|
|
$ log 'branch(wdir())'
|
|
|
|
8
|
|
|
|
9
|
|
|
|
$ log '0:wdir() & branch(wdir())'
|
|
|
|
8
|
|
|
|
9
|
|
|
|
2147483647
|
|
|
|
|
2010-08-30 08:23:32 +04:00
|
|
|
$ log 'outgoing()'
|
|
|
|
8
|
|
|
|
9
|
|
|
|
$ log 'outgoing("../remote1")'
|
|
|
|
8
|
|
|
|
9
|
|
|
|
$ log 'outgoing("../remote2")'
|
|
|
|
3
|
|
|
|
5
|
|
|
|
6
|
|
|
|
7
|
|
|
|
9
|
|
|
|
$ log 'p1(merge())'
|
|
|
|
5
|
|
|
|
$ log 'p2(merge())'
|
|
|
|
4
|
|
|
|
$ log 'parents(merge())'
|
|
|
|
4
|
|
|
|
5
|
2012-08-13 23:50:45 +04:00
|
|
|
$ log 'p1(branchpoint())'
|
|
|
|
0
|
|
|
|
2
|
|
|
|
$ log 'p2(branchpoint())'
|
|
|
|
$ log 'parents(branchpoint())'
|
|
|
|
0
|
|
|
|
2
|
2010-08-30 08:23:32 +04:00
|
|
|
$ log 'removes(a)'
|
|
|
|
2
|
|
|
|
6
|
|
|
|
$ log 'roots(all())'
|
|
|
|
0
|
|
|
|
$ log 'reverse(2 or 3 or 4 or 5)'
|
|
|
|
5
|
|
|
|
4
|
|
|
|
3
|
|
|
|
2
|
2012-07-04 20:38:07 +04:00
|
|
|
$ log 'reverse(all())'
|
|
|
|
9
|
|
|
|
8
|
|
|
|
7
|
|
|
|
6
|
|
|
|
5
|
|
|
|
4
|
|
|
|
3
|
|
|
|
2
|
|
|
|
1
|
|
|
|
0
|
2015-01-10 15:31:59 +03:00
|
|
|
$ log 'reverse(all()) & filelog(b)'
|
|
|
|
4
|
|
|
|
1
|
2010-10-11 18:44:19 +04:00
|
|
|
$ log 'rev(5)'
|
|
|
|
5
|
2010-08-30 08:23:32 +04:00
|
|
|
$ log 'sort(limit(reverse(all()), 3))'
|
|
|
|
7
|
|
|
|
8
|
|
|
|
9
|
|
|
|
$ log 'sort(2 or 3 or 4 or 5, date)'
|
|
|
|
2
|
|
|
|
3
|
|
|
|
5
|
|
|
|
4
|
|
|
|
$ log 'tagged()'
|
|
|
|
6
|
2010-10-10 21:41:36 +04:00
|
|
|
$ log 'tag()'
|
|
|
|
6
|
|
|
|
$ log 'tag(1.0)'
|
|
|
|
6
|
|
|
|
$ log 'tag(tip)'
|
|
|
|
9
|
2012-05-31 02:13:33 +04:00
|
|
|
|
2016-05-03 06:36:44 +03:00
|
|
|
Test order of revisions in compound expression
|
|
|
|
----------------------------------------------
|
|
|
|
|
2016-06-22 16:02:25 +03:00
|
|
|
The general rule is that only the outermost (= leftmost) predicate can
|
|
|
|
enforce its ordering requirement. The other predicates should take the
|
|
|
|
ordering defined by it.
|
|
|
|
|
2016-05-03 06:36:44 +03:00
|
|
|
'A & B' should follow the order of 'A':
|
|
|
|
|
|
|
|
$ log '2:0 & 0::2'
|
|
|
|
2
|
|
|
|
1
|
|
|
|
0
|
|
|
|
|
2016-06-23 22:37:09 +03:00
|
|
|
'head()' combines sets in right order:
|
2016-06-22 16:02:25 +03:00
|
|
|
|
|
|
|
$ log '2:0 & head()'
|
|
|
|
2
|
2016-06-23 22:37:09 +03:00
|
|
|
1
|
|
|
|
0
|
2016-06-22 16:02:25 +03:00
|
|
|
|
2016-05-03 06:52:50 +03:00
|
|
|
'x:y' takes ordering parameter into account:
|
|
|
|
|
|
|
|
$ try -p optimized '3:0 & 0:3 & not 2:1'
|
|
|
|
* optimized:
|
|
|
|
(difference
|
|
|
|
(and
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '3')
|
|
|
|
(symbol '0'))
|
2016-05-03 06:52:50 +03:00
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '0')
|
|
|
|
(symbol '3')))
|
2016-05-03 06:52:50 +03:00
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2')
|
|
|
|
(symbol '1')))
|
2016-05-03 06:52:50 +03:00
|
|
|
* set:
|
|
|
|
<filteredset
|
|
|
|
<filteredset
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset- 0:4>,
|
|
|
|
<spanset+ 0:4>>,
|
2016-05-03 06:52:50 +03:00
|
|
|
<not
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset+ 1:3>>>
|
2016-05-03 06:52:50 +03:00
|
|
|
3
|
|
|
|
0
|
|
|
|
|
2016-06-22 16:02:25 +03:00
|
|
|
'a + b', which is optimized to '_list(a b)', should take the ordering of
|
|
|
|
the left expression:
|
|
|
|
|
|
|
|
$ try --optimize '2:0 & (0 + 1 + 2)'
|
|
|
|
(and
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2')
|
|
|
|
(symbol '0'))
|
2016-06-22 16:02:25 +03:00
|
|
|
(group
|
|
|
|
(or
|
2016-08-07 11:04:05 +03:00
|
|
|
(list
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '0')
|
|
|
|
(symbol '1')
|
|
|
|
(symbol '2')))))
|
2016-06-22 16:02:25 +03:00
|
|
|
* optimized:
|
|
|
|
(and
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2')
|
|
|
|
(symbol '0'))
|
2016-06-22 16:02:25 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '_list')
|
|
|
|
(string '0\x001\x002')))
|
2016-06-22 16:02:25 +03:00
|
|
|
* set:
|
2016-06-26 12:41:28 +03:00
|
|
|
<filteredset
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset- 0:3>,
|
2016-06-26 12:41:28 +03:00
|
|
|
<baseset [0, 1, 2]>>
|
2016-06-22 16:02:25 +03:00
|
|
|
2
|
2016-06-26 12:41:28 +03:00
|
|
|
1
|
|
|
|
0
|
2016-06-22 16:02:25 +03:00
|
|
|
|
|
|
|
'A + B' should take the ordering of the left expression:
|
|
|
|
|
|
|
|
$ try --optimize '2:0 & (0:1 + 2)'
|
|
|
|
(and
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2')
|
|
|
|
(symbol '0'))
|
2016-06-22 16:02:25 +03:00
|
|
|
(group
|
|
|
|
(or
|
2016-08-07 11:04:05 +03:00
|
|
|
(list
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '0')
|
|
|
|
(symbol '1'))
|
|
|
|
(symbol '2')))))
|
2016-06-22 16:02:25 +03:00
|
|
|
* optimized:
|
|
|
|
(and
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2')
|
|
|
|
(symbol '0'))
|
2016-06-22 16:02:25 +03:00
|
|
|
(or
|
2016-08-07 11:04:05 +03:00
|
|
|
(list
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '0')
|
|
|
|
(symbol '1'))
|
|
|
|
(symbol '2'))))
|
2016-06-22 16:02:25 +03:00
|
|
|
* set:
|
2016-06-26 12:17:12 +03:00
|
|
|
<filteredset
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset- 0:3>,
|
2016-06-26 12:17:12 +03:00
|
|
|
<addset
|
2017-08-29 09:44:47 +03:00
|
|
|
<spanset+ 0:2>,
|
|
|
|
<baseset [2]>>>
|
2016-06-22 16:02:25 +03:00
|
|
|
2
|
2016-06-26 12:17:12 +03:00
|
|
|
1
|
|
|
|
0
|
2016-06-22 16:02:25 +03:00
|
|
|
|
|
|
|
'_intlist(a b)' should behave like 'a + b':
|
|
|
|
|
|
|
|
$ trylist --optimize '2:0 & %ld' 0 1 2
|
|
|
|
(and
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2')
|
|
|
|
(symbol '0'))
|
2016-06-22 16:02:25 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '_intlist')
|
|
|
|
(string '0\x001\x002')))
|
2016-06-22 16:02:25 +03:00
|
|
|
* optimized:
|
2017-08-31 02:05:12 +03:00
|
|
|
(andsmally
|
2016-06-22 16:02:25 +03:00
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2')
|
|
|
|
(symbol '0'))
|
2017-08-31 02:05:12 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '_intlist')
|
|
|
|
(string '0\x001\x002')))
|
2016-06-22 16:02:25 +03:00
|
|
|
* set:
|
|
|
|
<filteredset
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset- 0:3>,
|
2016-06-26 12:41:28 +03:00
|
|
|
<baseset+ [0, 1, 2]>>
|
2016-06-22 16:02:25 +03:00
|
|
|
2
|
|
|
|
1
|
|
|
|
0
|
|
|
|
|
|
|
|
$ trylist --optimize '%ld & 2:0' 0 2 1
|
|
|
|
(and
|
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '_intlist')
|
|
|
|
(string '0\x002\x001'))
|
2016-06-22 16:02:25 +03:00
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2')
|
|
|
|
(symbol '0')))
|
2016-06-22 16:02:25 +03:00
|
|
|
* optimized:
|
|
|
|
(and
|
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '_intlist')
|
|
|
|
(string '0\x002\x001'))
|
2016-06-22 16:02:25 +03:00
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2')
|
|
|
|
(symbol '0')))
|
2016-06-22 16:02:25 +03:00
|
|
|
* set:
|
|
|
|
<filteredset
|
2016-05-03 06:52:50 +03:00
|
|
|
<baseset [0, 2, 1]>,
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset- 0:3>>
|
2016-05-03 06:52:50 +03:00
|
|
|
0
|
2016-06-22 16:02:25 +03:00
|
|
|
2
|
|
|
|
1
|
|
|
|
|
|
|
|
'_hexlist(a b)' should behave like 'a + b':
|
|
|
|
|
|
|
|
$ trylist --optimize --bin '2:0 & %ln' `hg log -T '{node} ' -r0:2`
|
|
|
|
(and
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2')
|
|
|
|
(symbol '0'))
|
2016-06-22 16:02:25 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '_hexlist')
|
|
|
|
(string '*'))) (glob)
|
2016-06-22 16:02:25 +03:00
|
|
|
* optimized:
|
|
|
|
(and
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2')
|
|
|
|
(symbol '0'))
|
2016-06-22 16:02:25 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '_hexlist')
|
|
|
|
(string '*'))) (glob)
|
2016-06-22 16:02:25 +03:00
|
|
|
* set:
|
2016-06-26 12:41:28 +03:00
|
|
|
<filteredset
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset- 0:3>,
|
2016-06-26 12:41:28 +03:00
|
|
|
<baseset [0, 1, 2]>>
|
2016-06-22 16:02:25 +03:00
|
|
|
2
|
2016-06-26 12:41:28 +03:00
|
|
|
1
|
|
|
|
0
|
2016-06-22 16:02:25 +03:00
|
|
|
|
|
|
|
$ trylist --optimize --bin '%ln & 2:0' `hg log -T '{node} ' -r0+2+1`
|
|
|
|
(and
|
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '_hexlist')
|
|
|
|
(string '*')) (glob)
|
2016-06-22 16:02:25 +03:00
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2')
|
|
|
|
(symbol '0')))
|
2016-06-22 16:02:25 +03:00
|
|
|
* optimized:
|
2017-08-31 02:05:12 +03:00
|
|
|
(andsmally
|
2016-06-22 16:02:25 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '_hexlist')
|
|
|
|
(string '*')) (glob)
|
2017-08-31 02:05:12 +03:00
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2')
|
|
|
|
(symbol '0')))
|
2016-06-22 16:02:25 +03:00
|
|
|
* set:
|
|
|
|
<baseset [0, 2, 1]>
|
|
|
|
0
|
|
|
|
2
|
|
|
|
1
|
|
|
|
|
2016-06-26 12:41:28 +03:00
|
|
|
'_list' should not go through the slow follow-order path if order doesn't
|
|
|
|
matter:
|
|
|
|
|
|
|
|
$ try -p optimized '2:0 & not (0 + 1)'
|
|
|
|
* optimized:
|
|
|
|
(difference
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2')
|
|
|
|
(symbol '0'))
|
2016-06-26 12:41:28 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '_list')
|
|
|
|
(string '0\x001')))
|
2016-06-26 12:41:28 +03:00
|
|
|
* set:
|
|
|
|
<filteredset
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset- 0:3>,
|
2016-06-26 12:41:28 +03:00
|
|
|
<not
|
|
|
|
<baseset [0, 1]>>>
|
|
|
|
2
|
|
|
|
|
|
|
|
$ try -p optimized '2:0 & not (0:2 & (0 + 1))'
|
|
|
|
* optimized:
|
|
|
|
(difference
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2')
|
|
|
|
(symbol '0'))
|
2016-06-26 12:41:28 +03:00
|
|
|
(and
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '0')
|
|
|
|
(symbol '2'))
|
2016-06-26 12:41:28 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '_list')
|
|
|
|
(string '0\x001'))))
|
2016-06-26 12:41:28 +03:00
|
|
|
* set:
|
|
|
|
<filteredset
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset- 0:3>,
|
2016-06-26 12:41:28 +03:00
|
|
|
<not
|
|
|
|
<baseset [0, 1]>>>
|
|
|
|
2
|
|
|
|
|
2016-06-01 14:54:04 +03:00
|
|
|
because 'present()' does nothing other than suppressing an error, the
|
|
|
|
ordering requirement should be forwarded to the nested expression
|
|
|
|
|
|
|
|
$ try -p optimized 'present(2 + 0 + 1)'
|
|
|
|
* optimized:
|
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'present')
|
2016-06-01 14:54:04 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '_list')
|
|
|
|
(string '2\x000\x001')))
|
2016-06-01 14:54:04 +03:00
|
|
|
* set:
|
|
|
|
<baseset [2, 0, 1]>
|
|
|
|
2
|
|
|
|
0
|
|
|
|
1
|
2016-06-22 16:02:25 +03:00
|
|
|
|
|
|
|
$ try --optimize '2:0 & present(0 + 1 + 2)'
|
|
|
|
(and
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2')
|
|
|
|
(symbol '0'))
|
2016-06-22 16:02:25 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'present')
|
2016-06-22 16:02:25 +03:00
|
|
|
(or
|
2016-08-07 11:04:05 +03:00
|
|
|
(list
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '0')
|
|
|
|
(symbol '1')
|
|
|
|
(symbol '2')))))
|
2016-06-22 16:02:25 +03:00
|
|
|
* optimized:
|
|
|
|
(and
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2')
|
|
|
|
(symbol '0'))
|
2016-06-22 16:02:25 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'present')
|
2016-06-22 16:02:25 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '_list')
|
|
|
|
(string '0\x001\x002'))))
|
2016-06-22 16:02:25 +03:00
|
|
|
* set:
|
2016-06-01 14:54:04 +03:00
|
|
|
<filteredset
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset- 0:3>,
|
2016-06-01 14:54:04 +03:00
|
|
|
<baseset [0, 1, 2]>>
|
2016-06-22 16:02:25 +03:00
|
|
|
2
|
2016-06-01 14:54:04 +03:00
|
|
|
1
|
|
|
|
0
|
2016-06-22 16:02:25 +03:00
|
|
|
|
|
|
|
'reverse()' should take effect only if it is the outermost expression:
|
|
|
|
|
|
|
|
$ try --optimize '0:2 & reverse(all())'
|
|
|
|
(and
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '0')
|
|
|
|
(symbol '2'))
|
2016-06-22 16:02:25 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'reverse')
|
2016-06-22 16:02:25 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'all')
|
2016-06-22 16:02:25 +03:00
|
|
|
None)))
|
|
|
|
* optimized:
|
|
|
|
(and
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '0')
|
|
|
|
(symbol '2'))
|
2016-06-22 16:02:25 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'reverse')
|
2016-06-22 16:02:25 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'all')
|
2017-08-20 20:55:11 +03:00
|
|
|
None)))
|
2016-06-22 16:02:25 +03:00
|
|
|
* set:
|
|
|
|
<filteredset
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset+ 0:3>,
|
|
|
|
<spanset+ 0:10>>
|
2016-06-22 16:02:25 +03:00
|
|
|
0
|
2016-05-03 07:36:12 +03:00
|
|
|
1
|
|
|
|
2
|
2016-06-22 16:02:25 +03:00
|
|
|
|
|
|
|
'sort()' should take effect only if it is the outermost expression:
|
|
|
|
|
|
|
|
$ try --optimize '0:2 & sort(all(), -rev)'
|
|
|
|
(and
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '0')
|
|
|
|
(symbol '2'))
|
2016-06-22 16:02:25 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'sort')
|
2016-06-22 16:02:25 +03:00
|
|
|
(list
|
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'all')
|
2016-06-22 16:02:25 +03:00
|
|
|
None)
|
|
|
|
(negate
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'rev')))))
|
2016-06-22 16:02:25 +03:00
|
|
|
* optimized:
|
|
|
|
(and
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '0')
|
|
|
|
(symbol '2'))
|
2016-06-22 16:02:25 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'sort')
|
2016-06-22 16:02:25 +03:00
|
|
|
(list
|
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'all')
|
2017-08-20 20:55:11 +03:00
|
|
|
None)
|
2017-09-03 15:17:25 +03:00
|
|
|
(string '-rev'))))
|
2016-06-22 16:02:25 +03:00
|
|
|
* set:
|
|
|
|
<filteredset
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset+ 0:3>,
|
|
|
|
<spanset+ 0:10>>
|
2016-06-22 16:02:25 +03:00
|
|
|
0
|
2016-05-03 07:36:12 +03:00
|
|
|
1
|
|
|
|
2
|
|
|
|
|
|
|
|
invalid argument passed to noop sort():
|
|
|
|
|
|
|
|
$ log '0:2 & sort()'
|
|
|
|
hg: parse error: sort requires one or two arguments
|
|
|
|
[255]
|
|
|
|
$ log '0:2 & sort(all(), -invalid)'
|
|
|
|
hg: parse error: unknown sort key '-invalid'
|
|
|
|
[255]
|
2016-06-22 16:02:25 +03:00
|
|
|
|
|
|
|
for 'A & f(B)', 'B' should not be affected by the order of 'A':
|
|
|
|
|
|
|
|
$ try --optimize '2:0 & first(1 + 0 + 2)'
|
|
|
|
(and
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2')
|
|
|
|
(symbol '0'))
|
2016-06-22 16:02:25 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'first')
|
2016-06-22 16:02:25 +03:00
|
|
|
(or
|
2016-08-07 11:04:05 +03:00
|
|
|
(list
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '1')
|
|
|
|
(symbol '0')
|
|
|
|
(symbol '2')))))
|
2016-06-22 16:02:25 +03:00
|
|
|
* optimized:
|
|
|
|
(and
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2')
|
|
|
|
(symbol '0'))
|
2016-06-22 16:02:25 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'first')
|
2016-06-22 16:02:25 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '_list')
|
|
|
|
(string '1\x000\x002'))))
|
2016-06-22 16:02:25 +03:00
|
|
|
* set:
|
2017-06-10 13:41:42 +03:00
|
|
|
<filteredset
|
2015-04-09 17:56:06 +03:00
|
|
|
<baseset [1]>,
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset- 0:3>>
|
2016-06-22 16:02:25 +03:00
|
|
|
1
|
|
|
|
|
|
|
|
$ try --optimize '2:0 & not last(0 + 2 + 1)'
|
|
|
|
(and
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2')
|
|
|
|
(symbol '0'))
|
2016-06-22 16:02:25 +03:00
|
|
|
(not
|
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'last')
|
2016-06-22 16:02:25 +03:00
|
|
|
(or
|
2016-08-07 11:04:05 +03:00
|
|
|
(list
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '0')
|
|
|
|
(symbol '2')
|
|
|
|
(symbol '1'))))))
|
2016-06-22 16:02:25 +03:00
|
|
|
* optimized:
|
|
|
|
(difference
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2')
|
|
|
|
(symbol '0'))
|
2016-06-22 16:02:25 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'last')
|
2016-06-22 16:02:25 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '_list')
|
|
|
|
(string '0\x002\x001'))))
|
2016-06-22 16:02:25 +03:00
|
|
|
* set:
|
|
|
|
<filteredset
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset- 0:3>,
|
2016-06-22 16:02:25 +03:00
|
|
|
<not
|
2015-04-09 17:56:06 +03:00
|
|
|
<baseset [1]>>>
|
2016-06-22 16:02:25 +03:00
|
|
|
2
|
|
|
|
0
|
|
|
|
|
|
|
|
for 'A & (op)(B)', 'B' should not be affected by the order of 'A':
|
|
|
|
|
|
|
|
$ try --optimize '2:0 & (1 + 0 + 2):(0 + 2 + 1)'
|
|
|
|
(and
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2')
|
|
|
|
(symbol '0'))
|
2016-06-22 16:02:25 +03:00
|
|
|
(range
|
|
|
|
(group
|
|
|
|
(or
|
2016-08-07 11:04:05 +03:00
|
|
|
(list
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '1')
|
|
|
|
(symbol '0')
|
|
|
|
(symbol '2'))))
|
2016-06-22 16:02:25 +03:00
|
|
|
(group
|
|
|
|
(or
|
2016-08-07 11:04:05 +03:00
|
|
|
(list
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '0')
|
|
|
|
(symbol '2')
|
|
|
|
(symbol '1'))))))
|
2016-06-22 16:02:25 +03:00
|
|
|
* optimized:
|
|
|
|
(and
|
|
|
|
(range
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2')
|
|
|
|
(symbol '0'))
|
2016-06-22 16:02:25 +03:00
|
|
|
(range
|
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '_list')
|
|
|
|
(string '1\x000\x002'))
|
2016-06-22 16:02:25 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '_list')
|
|
|
|
(string '0\x002\x001'))))
|
2016-06-22 16:02:25 +03:00
|
|
|
* set:
|
|
|
|
<filteredset
|
2017-06-10 18:21:38 +03:00
|
|
|
<spanset- 0:3>,
|
2016-05-03 06:52:50 +03:00
|
|
|
<baseset [1]>>
|
2016-06-22 16:02:25 +03:00
|
|
|
1
|
|
|
|
|
2017-08-20 20:55:11 +03:00
|
|
|
'A & B' can be rewritten as 'flipand(B, A)' by weight.
|
2016-06-22 16:02:25 +03:00
|
|
|
|
|
|
|
$ try --optimize 'contains("glob:*") & (2 + 0 + 1)'
|
|
|
|
(and
|
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'contains')
|
|
|
|
(string 'glob:*'))
|
2016-06-22 16:02:25 +03:00
|
|
|
(group
|
|
|
|
(or
|
2016-08-07 11:04:05 +03:00
|
|
|
(list
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '2')
|
|
|
|
(symbol '0')
|
|
|
|
(symbol '1')))))
|
2016-06-22 16:02:25 +03:00
|
|
|
* optimized:
|
2017-08-31 02:05:12 +03:00
|
|
|
(andsmally
|
2016-06-22 16:02:25 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'contains')
|
|
|
|
(string 'glob:*'))
|
2017-08-31 02:05:12 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '_list')
|
|
|
|
(string '2\x000\x001')))
|
2016-06-22 16:02:25 +03:00
|
|
|
* set:
|
|
|
|
<filteredset
|
2016-06-26 12:41:28 +03:00
|
|
|
<baseset+ [0, 1, 2]>,
|
2016-06-22 16:02:25 +03:00
|
|
|
<contains 'glob:*'>>
|
|
|
|
0
|
|
|
|
1
|
2016-06-26 12:41:28 +03:00
|
|
|
2
|
|
|
|
|
|
|
|
and in this example, 'A & B' is rewritten as 'B & A', but 'A' overrides
|
|
|
|
the order appropriately:
|
2016-06-22 16:02:25 +03:00
|
|
|
|
|
|
|
$ try --optimize 'reverse(contains("glob:*")) & (0 + 2 + 1)'
|
|
|
|
(and
|
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'reverse')
|
2016-06-22 16:02:25 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'contains')
|
|
|
|
(string 'glob:*')))
|
2016-06-22 16:02:25 +03:00
|
|
|
(group
|
|
|
|
(or
|
2016-08-07 11:04:05 +03:00
|
|
|
(list
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '0')
|
|
|
|
(symbol '2')
|
|
|
|
(symbol '1')))))
|
2016-06-22 16:02:25 +03:00
|
|
|
* optimized:
|
2017-08-31 02:05:12 +03:00
|
|
|
(andsmally
|
2016-06-22 16:02:25 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'reverse')
|
2016-06-22 16:02:25 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol 'contains')
|
|
|
|
(string 'glob:*')))
|
2017-08-31 02:05:12 +03:00
|
|
|
(func
|
2017-09-03 15:17:25 +03:00
|
|
|
(symbol '_list')
|
|
|
|
(string '0\x002\x001')))
|
2016-06-22 16:02:25 +03:00
|
|
|
* set:
|
|
|
|
<filteredset
|
2016-06-26 12:41:28 +03:00
|
|
|
<baseset- [0, 1, 2]>,
|
2016-06-22 16:02:25 +03:00
|
|
|
<contains 'glob:*'>>
|
|
|
|
2
|
2016-06-26 12:41:28 +03:00
|
|
|
1
|
2016-06-22 16:02:25 +03:00
|
|
|
0
|
|
|
|
|
2014-03-14 04:20:03 +04:00
|
|
|
test sort revset
|
|
|
|
--------------------------------------------
|
|
|
|
|
|
|
|
test when adding two unordered revsets
|
|
|
|
|
|
|
|
$ log 'sort(keyword(issue) or modifies(b))'
|
|
|
|
4
|
|
|
|
6
|
|
|
|
|
|
|
|
test when sorting a reversed collection in the same way it is
|
|
|
|
|
|
|
|
$ log 'sort(reverse(all()), -rev)'
|
|
|
|
9
|
|
|
|
8
|
|
|
|
7
|
|
|
|
6
|
|
|
|
5
|
|
|
|
4
|
|
|
|
3
|
|
|
|
2
|
|
|
|
1
|
|
|
|
0
|
|
|
|
|
|
|
|
test when sorting a reversed collection
|
|
|
|
|
|
|
|
$ log 'sort(reverse(all()), rev)'
|
|
|
|
0
|
|
|
|
1
|
|
|
|
2
|
|
|
|
3
|
|
|
|
4
|
|
|
|
5
|
|
|
|
6
|
|
|
|
7
|
|
|
|
8
|
|
|
|
9
|
|
|
|
|
|
|
|
|
|
|
|
test sorting two sorted collections in different orders
|
|
|
|
|
|
|
|
$ log 'sort(outgoing() or reverse(removes(a)), rev)'
|
|
|
|
2
|
|
|
|
6
|
|
|
|
8
|
|
|
|
9
|
|
|
|
|
|
|
|
test sorting two sorted collections in different orders backwards
|
|
|
|
|
|
|
|
$ log 'sort(outgoing() or reverse(removes(a)), -rev)'
|
|
|
|
9
|
|
|
|
8
|
|
|
|
6
|
|
|
|
2
|
|
|
|
|
2016-06-15 14:37:24 +03:00
|
|
|
test empty sort key which is noop
|
|
|
|
|
|
|
|
$ log 'sort(0 + 2 + 1, "")'
|
|
|
|
0
|
|
|
|
2
|
|
|
|
1
|
|
|
|
|
2016-05-14 13:46:18 +03:00
|
|
|
test invalid sort keys
|
|
|
|
|
|
|
|
$ log 'sort(all(), -invalid)'
|
|
|
|
hg: parse error: unknown sort key '-invalid'
|
|
|
|
[255]
|
|
|
|
|
revset: make sort() do dumb multi-pass sorting for multiple keys (issue5218)
Our invert() function was too clever to not take length into account. I could
fix the problem by appending '\xff' as a terminator (opposite to '\0'), but
it turned out to be slower than simple multi-pass sorting.
New implementation is pretty straightforward, which just calls sort() from the
last key. We can do that since Python sort() is guaranteed to be stable. It
doesn't sound nice to call sort() multiple times, but actually it is faster.
That's probably because we have fewer Python codes in hot loop, and can avoid
heavy string and list manipulation.
revset #0: sort(0:10000, 'branch')
0) 0.412753
1) 0.393254
revset #1: sort(0:10000, '-branch')
0) 0.455377
1) 0.389191 85%
revset #2: sort(0:10000, 'date')
0) 0.408082
1) 0.376332 92%
revset #3: sort(0:10000, '-date')
0) 0.406910
1) 0.380498 93%
revset #4: sort(0:10000, 'desc branch user date rev')
0) 0.542996
1) 0.486397 89%
revset #5: sort(0:10000, '-desc -branch -user -date -rev')
0) 0.965032
1) 0.518426 53%
2016-04-23 10:09:30 +03:00
|
|
|
$ cd ..
|
|
|
|
|
|
|
|
test sorting by multiple keys including variable-length strings
|
|
|
|
|
|
|
|
$ hg init sorting
|
|
|
|
$ cd sorting
|
|
|
|
$ cat <<EOF >> .hg/hgrc
|
|
|
|
> [ui]
|
|
|
|
> logtemplate = '{rev} {branch|p5}{desc|p5}{author|p5}{date|hgdate}\n'
|
|
|
|
> [templatealias]
|
|
|
|
> p5(s) = pad(s, 5)
|
|
|
|
> EOF
|
|
|
|
$ hg branch -qf b12
|
|
|
|
$ hg ci -m m111 -u u112 -d '111 10800'
|
|
|
|
$ hg branch -qf b11
|
|
|
|
$ hg ci -m m12 -u u111 -d '112 7200'
|
|
|
|
$ hg branch -qf b111
|
|
|
|
$ hg ci -m m11 -u u12 -d '111 3600'
|
|
|
|
$ hg branch -qf b112
|
|
|
|
$ hg ci -m m111 -u u11 -d '120 0'
|
|
|
|
$ hg branch -qf b111
|
|
|
|
$ hg ci -m m112 -u u111 -d '110 14400'
|
|
|
|
created new head
|
|
|
|
|
|
|
|
compare revisions (has fast path):
|
|
|
|
|
|
|
|
$ hg log -r 'sort(all(), rev)'
|
|
|
|
0 b12 m111 u112 111 10800
|
|
|
|
1 b11 m12 u111 112 7200
|
|
|
|
2 b111 m11 u12 111 3600
|
|
|
|
3 b112 m111 u11 120 0
|
|
|
|
4 b111 m112 u111 110 14400
|
|
|
|
|
|
|
|
$ hg log -r 'sort(all(), -rev)'
|
|
|
|
4 b111 m112 u111 110 14400
|
|
|
|
3 b112 m111 u11 120 0
|
|
|
|
2 b111 m11 u12 111 3600
|
|
|
|
1 b11 m12 u111 112 7200
|
|
|
|
0 b12 m111 u112 111 10800
|
|
|
|
|
|
|
|
compare variable-length strings (issue5218):
|
|
|
|
|
|
|
|
$ hg log -r 'sort(all(), branch)'
|
|
|
|
1 b11 m12 u111 112 7200
|
|
|
|
2 b111 m11 u12 111 3600
|
|
|
|
4 b111 m112 u111 110 14400
|
|
|
|
3 b112 m111 u11 120 0
|
|
|
|
0 b12 m111 u112 111 10800
|
|
|
|
|
|
|
|
$ hg log -r 'sort(all(), -branch)'
|
|
|
|
0 b12 m111 u112 111 10800
|
|
|
|
3 b112 m111 u11 120 0
|
|
|
|
2 b111 m11 u12 111 3600
|
|
|
|
4 b111 m112 u111 110 14400
|
|
|
|
1 b11 m12 u111 112 7200
|
|
|
|
|
|
|
|
$ hg log -r 'sort(all(), desc)'
|
|
|
|
2 b111 m11 u12 111 3600
|
|
|
|
0 b12 m111 u112 111 10800
|
|
|
|
3 b112 m111 u11 120 0
|
|
|
|
4 b111 m112 u111 110 14400
|
|
|
|
1 b11 m12 u111 112 7200
|
|
|
|
|
|
|
|
$ hg log -r 'sort(all(), -desc)'
|
|
|
|
1 b11 m12 u111 112 7200
|
|
|
|
4 b111 m112 u111 110 14400
|
|
|
|
0 b12 m111 u112 111 10800
|
|
|
|
3 b112 m111 u11 120 0
|
|
|
|
2 b111 m11 u12 111 3600
|
|
|
|
|
|
|
|
$ hg log -r 'sort(all(), user)'
|
|
|
|
3 b112 m111 u11 120 0
|
|
|
|
1 b11 m12 u111 112 7200
|
|
|
|
4 b111 m112 u111 110 14400
|
|
|
|
0 b12 m111 u112 111 10800
|
|
|
|
2 b111 m11 u12 111 3600
|
|
|
|
|
|
|
|
$ hg log -r 'sort(all(), -user)'
|
|
|
|
2 b111 m11 u12 111 3600
|
|
|
|
0 b12 m111 u112 111 10800
|
|
|
|
1 b11 m12 u111 112 7200
|
|
|
|
4 b111 m112 u111 110 14400
|
|
|
|
3 b112 m111 u11 120 0
|
|
|
|
|
|
|
|
compare dates (tz offset should have no effect):
|
|
|
|
|
|
|
|
$ hg log -r 'sort(all(), date)'
|
|
|
|
4 b111 m112 u111 110 14400
|
|
|
|
0 b12 m111 u112 111 10800
|
|
|
|
2 b111 m11 u12 111 3600
|
|
|
|
1 b11 m12 u111 112 7200
|
|
|
|
3 b112 m111 u11 120 0
|
|
|
|
|
|
|
|
$ hg log -r 'sort(all(), -date)'
|
|
|
|
3 b112 m111 u11 120 0
|
|
|
|
1 b11 m12 u111 112 7200
|
|
|
|
0 b12 m111 u112 111 10800
|
|
|
|
2 b111 m11 u12 111 3600
|
|
|
|
4 b111 m112 u111 110 14400
|
|
|
|
|
|
|
|
be aware that 'sort(x, -k)' is not exactly the same as 'reverse(sort(x, k))'
|
|
|
|
because '-k' reverses the comparison, not the list itself:
|
|
|
|
|
|
|
|
$ hg log -r 'sort(0 + 2, date)'
|
|
|
|
0 b12 m111 u112 111 10800
|
|
|
|
2 b111 m11 u12 111 3600
|
|
|
|
|
|
|
|
$ hg log -r 'sort(0 + 2, -date)'
|
|
|
|
0 b12 m111 u112 111 10800
|
|
|
|
2 b111 m11 u12 111 3600
|
|
|
|
|
|
|
|
$ hg log -r 'reverse(sort(0 + 2, date))'
|
|
|
|
2 b111 m11 u12 111 3600
|
|
|
|
0 b12 m111 u112 111 10800
|
|
|
|
|
|
|
|
sort by multiple keys:
|
|
|
|
|
|
|
|
$ hg log -r 'sort(all(), "branch -rev")'
|
|
|
|
1 b11 m12 u111 112 7200
|
|
|
|
4 b111 m112 u111 110 14400
|
|
|
|
2 b111 m11 u12 111 3600
|
|
|
|
3 b112 m111 u11 120 0
|
|
|
|
0 b12 m111 u112 111 10800
|
|
|
|
|
|
|
|
$ hg log -r 'sort(all(), "-desc -date")'
|
|
|
|
1 b11 m12 u111 112 7200
|
|
|
|
4 b111 m112 u111 110 14400
|
|
|
|
3 b112 m111 u11 120 0
|
|
|
|
0 b12 m111 u112 111 10800
|
|
|
|
2 b111 m11 u12 111 3600
|
|
|
|
|
|
|
|
$ hg log -r 'sort(all(), "user -branch date rev")'
|
|
|
|
3 b112 m111 u11 120 0
|
|
|
|
4 b111 m112 u111 110 14400
|
|
|
|
1 b11 m12 u111 112 7200
|
|
|
|
0 b12 m111 u112 111 10800
|
|
|
|
2 b111 m11 u12 111 3600
|
|
|
|
|
2016-06-13 20:20:00 +03:00
|
|
|
toposort prioritises graph branches
|
|
|
|
|
|
|
|
$ hg up 2
|
|
|
|
0 files updated, 0 files merged, 0 files removed, 0 files unresolved
|
|
|
|
$ touch a
|
|
|
|
$ hg addremove
|
|
|
|
adding a
|
|
|
|
$ hg ci -m 't1' -u 'tu' -d '130 0'
|
|
|
|
created new head
|
|
|
|
$ echo 'a' >> a
|
|
|
|
$ hg ci -m 't2' -u 'tu' -d '130 0'
|
|
|
|
$ hg book book1
|
|
|
|
$ hg up 4
|
|
|
|
0 files updated, 0 files merged, 1 files removed, 0 files unresolved
|
|
|
|
(leaving bookmark book1)
|
|
|
|
$ touch a
|
|
|
|
$ hg addremove
|
|
|
|
adding a
|
|
|
|
$ hg ci -m 't3' -u 'tu' -d '130 0'
|
|
|
|
|
|
|
|
$ hg log -r 'sort(all(), topo)'
|
|
|
|
7 b111 t3 tu 130 0
|
|
|
|
4 b111 m112 u111 110 14400
|
|
|
|
3 b112 m111 u11 120 0
|
|
|
|
6 b111 t2 tu 130 0
|
|
|
|
5 b111 t1 tu 130 0
|
|
|
|
2 b111 m11 u12 111 3600
|
|
|
|
1 b11 m12 u111 112 7200
|
|
|
|
0 b12 m111 u112 111 10800
|
|
|
|
|
|
|
|
$ hg log -r 'sort(all(), -topo)'
|
|
|
|
0 b12 m111 u112 111 10800
|
|
|
|
1 b11 m12 u111 112 7200
|
|
|
|
2 b111 m11 u12 111 3600
|
|
|
|
5 b111 t1 tu 130 0
|
|
|
|
6 b111 t2 tu 130 0
|
|
|
|
3 b112 m111 u11 120 0
|
|
|
|
4 b111 m112 u111 110 14400
|
|
|
|
7 b111 t3 tu 130 0
|
|
|
|
|
|
|
|
$ hg log -r 'sort(all(), topo, topo.firstbranch=book1)'
|
|
|
|
6 b111 t2 tu 130 0
|
|
|
|
5 b111 t1 tu 130 0
|
|
|
|
7 b111 t3 tu 130 0
|
|
|
|
4 b111 m112 u111 110 14400
|
|
|
|
3 b112 m111 u11 120 0
|
|
|
|
2 b111 m11 u12 111 3600
|
|
|
|
1 b11 m12 u111 112 7200
|
|
|
|
0 b12 m111 u112 111 10800
|
|
|
|
|
|
|
|
topographical sorting can't be combined with other sort keys, and you can't
|
|
|
|
use the topo.firstbranch option when topo sort is not active:
|
|
|
|
|
|
|
|
$ hg log -r 'sort(all(), "topo user")'
|
|
|
|
hg: parse error: topo sort order cannot be combined with other sort keys
|
|
|
|
[255]
|
|
|
|
|
|
|
|
$ hg log -r 'sort(all(), user, topo.firstbranch=book1)'
|
|
|
|
hg: parse error: topo.firstbranch can only be used when using the topo sort key
|
|
|
|
[255]
|
|
|
|
|
2016-08-07 08:58:49 +03:00
|
|
|
topo.firstbranch should accept any kind of expressions:
|
|
|
|
|
|
|
|
$ hg log -r 'sort(0, topo, topo.firstbranch=(book1))'
|
|
|
|
0 b12 m111 u112 111 10800
|
|
|
|
|
revset: make sort() do dumb multi-pass sorting for multiple keys (issue5218)
Our invert() function was too clever to not take length into account. I could
fix the problem by appending '\xff' as a terminator (opposite to '\0'), but
it turned out to be slower than simple multi-pass sorting.
New implementation is pretty straightforward, which just calls sort() from the
last key. We can do that since Python sort() is guaranteed to be stable. It
doesn't sound nice to call sort() multiple times, but actually it is faster.
That's probably because we have fewer Python codes in hot loop, and can avoid
heavy string and list manipulation.
revset #0: sort(0:10000, 'branch')
0) 0.412753
1) 0.393254
revset #1: sort(0:10000, '-branch')
0) 0.455377
1) 0.389191 85%
revset #2: sort(0:10000, 'date')
0) 0.408082
1) 0.376332 92%
revset #3: sort(0:10000, '-date')
0) 0.406910
1) 0.380498 93%
revset #4: sort(0:10000, 'desc branch user date rev')
0) 0.542996
1) 0.486397 89%
revset #5: sort(0:10000, '-desc -branch -user -date -rev')
0) 0.965032
1) 0.518426 53%
2016-04-23 10:09:30 +03:00
|
|
|
$ cd ..
|
|
|
|
$ cd repo
|