mirror of
https://github.com/facebook/sapling.git
synced 2024-10-10 08:47:12 +03:00
9bf6b674a6
Summary: Change the legacy Python graph render to Rust renderer. Reviewed By: DurhamG Differential Revision: D24317802 fbshipit-source-id: 4c3dc3a6dd02b7ebe79596a8e77f4b6b139d2e20
74 lines
2.6 KiB
Perl
74 lines
2.6 KiB
Perl
#chg-compatible
|
|
|
|
$ configure dummyssh
|
|
$ enable amend rebase
|
|
$ setconfig ui.interactive=true
|
|
|
|
Create a commit graph using obsmarkers.
|
|
|
|
$ newrepo
|
|
$ drawdag << EOS
|
|
> O J M # amend: A -> D -> F
|
|
> | | | # amend: B -> C
|
|
> B C E G I L # rebase: C -> E
|
|
> |/ / / | | # split: A -> H, I
|
|
> A D F H K N # rebase: C -> J
|
|
> \|/ \|/ # fold: I, J -> M
|
|
> Z Z # split: H -> K, L
|
|
> # fold: K, L, M -> N
|
|
> # split: E -> G, O
|
|
> EOS
|
|
|
|
It's possible for obsmarkers to get duplicated with slightly different
|
|
timestamps, due to floating-point number precision issues. This can
|
|
cause problems for mutation import, so fake the situation by deliberately
|
|
duplicating obsmarkers.
|
|
|
|
$ cat > $TESTTMP/dupobsmarkers.py <<EOF
|
|
> from edenscm.mercurial import obsolete, registrar
|
|
> cmdtable = {}
|
|
> command = registrar.command(cmdtable)
|
|
> @command('debugdupobsmarkers')
|
|
> def debugdupobsmarkers(ui, repo, **opts):
|
|
> newmarkers = []
|
|
> for marker in repo.obsstore._all:
|
|
> newmarker = list(marker)
|
|
> newmarker[4] = (newmarker[4][0] - 0.001, newmarker[4][1])
|
|
> newmarkers.append(tuple(newmarker))
|
|
> with repo.lock(), repo.svfs("obsstore", "ab") as f:
|
|
> f.write(b"".join(obsolete.encodemarkers(newmarkers, False, repo.obsstore._version)))
|
|
> EOF
|
|
|
|
$ hg debugdupobsmarkers --config extensions.dupobsmarkers=$TESTTMP/dupobsmarkers.py
|
|
|
|
Backfill the obsmarkers into mutation information.
|
|
|
|
$ setconfig mutation.record=true mutation.enabled=true mutation.date="0 0"
|
|
$ hg debugmutationfromobsmarkers
|
|
wrote 10 of 10 entries for 10 commits
|
|
|
|
The successors and predecessors information should be correct.
|
|
|
|
$ hg unhide $B
|
|
$ tglogm
|
|
o 11164ffef7a9 'O'
|
|
│
|
|
o e1beb503e4fb 'G'
|
|
│
|
|
│ x 917a077edb8d 'B' (Rewritten using rewrite into 69a19cab35b2) (Rewritten using split into e1beb503e4fb, 11164ffef7a9)
|
|
│ │
|
|
│ │ o 69a19cab35b2 'N'
|
|
│ │ │
|
|
o │ │ 847007ced9a7 'F'
|
|
├───╯
|
|
│ x ac2f7407182b 'A' (Rewritten using rewrite into 69a19cab35b2) (Rewritten using rewrite into 847007ced9a7)
|
|
├─╯
|
|
o 48b9aae0607f 'Z'
|
|
|
|
$ hg debugmutation -r $O
|
|
* 11164ffef7a9840cc182930dae0e032875937b6a split by test at 1970-01-01T00:00:01 (split into this and: e1beb503e4fb1cec5df43ac57edfcff177d705ec) from:
|
|
e900f94a0435abcada5fcbc21f0ff399981ad817 rebase by test at 1970-01-01T00:00:00 from:
|
|
daf025dd63009f8b02a358a8b98a29347717170f amend by test at 1970-01-01T00:00:00 from:
|
|
917a077edb8d775c96bc95d34025c800b243ce6f
|
|
|