Mercurial > hg-stable
diff tests/test-bookmarks.t @ 37896:04ceb267271a
bookmarks: cache reverse mapping (issue5868)
I chose a simpler implementation. If the initial cost of building reverse
mapping is significant, we'll have to move it under @propertycache.
The nodemap could be a dict of sets, but I think keeping a sorted list is
better since each node is likely to have zero/one bookmark.
Micro-benchmark with 1001 bookmarks and 1001 revisions:
$ for n in `seq 0 1000`; do touch $n; hg book book$n; hg ci -qAm$n; done
$ hg bookmarks --time > /dev/null
(orig) time: real 0.040 secs (user 0.050+0.000 sys 0.000+0.000)
(new) time: real 0.040 secs (user 0.040+0.000 sys 0.010+0.000)
$ hg log -T '{bookmarks}\n' --time > /dev/null
(orig) time: real 0.160 secs (user 0.160+0.000 sys 0.000+0.000)
(new) time: real 0.090 secs (user 0.100+0.000 sys 0.000+0.000)
author | Yuya Nishihara <yuya@tcha.org> |
---|---|
date | Sat, 05 May 2018 11:42:42 +0900 |
parents | 4df06d2f60e1 |
children | 2f7104984857 |
line wrap: on
line diff
--- a/tests/test-bookmarks.t Sat May 05 11:44:43 2018 +0900 +++ b/tests/test-bookmarks.t Sat May 05 11:42:42 2018 +0900 @@ -68,6 +68,9 @@ X 0:f7b1eb17ad24 * X2 0:f7b1eb17ad24 Y -1:000000000000 + $ hg log -T '{bookmarks % "{rev} {bookmark}\n"}' + 0 X + 0 X2 $ echo b > b $ hg add b @@ -299,6 +302,11 @@ Y 2:db815d6d32e6 Z 0:f7b1eb17ad24 * x y 2:db815d6d32e6 + $ hg log -T '{bookmarks % "{rev} {bookmark}\n"}' + 2 Y + 2 x y + 1 X2 + 0 Z look up stripped bookmark name @@ -445,6 +453,11 @@ Y 2:db815d6d32e6 * Z 2:db815d6d32e6 x y 2:db815d6d32e6 + $ hg log -T '{bookmarks % "{rev} {bookmark}\n"}' + 2 Y + 2 Z + 2 x y + 1 X2 revision but no bookmark name