In the mercurial list Stanimir Stamenkov asked how to get rid of intermediate merges in the log to simplify reading the history (and to not care about missing some of the details).
Update: Since Mercurial 2.4 [1] you can simply use
hg log -Gr "branchpoint()"
I did some tests for that and I think the nicest representation I found is this:
hg log -Gr "(all() - merge()) or head()"
This article shows examples for this. To find more revset options, run hg help revsets
.
It showed that in the end the revisions converged again - and it shows the actual states of the development.
$ hg log -Gr "(all() - merge()) or head()"
@ Änderung: 7:52fe4a8ec3cc
|\ Marke: tip
| | Vorgänger: 6:7d3026216270
| | Vorgänger: 5:848c390645ac
| | Nutzer: Arne Babenhauserheide <bab@draketo.de>
| | Datum: Tue Aug 14 15:09:54 2012 +0200
| | Zusammenfassung: merge
| |
| \
| |\
| | o Änderung: 3:55ba56aa8299
| | | Vorgänger: 0:385d95ab1fea
| | | Nutzer: Arne Babenhauserheide <bab@draketo.de>
| | | Datum: Tue Aug 14 15:09:40 2012 +0200
| | | Zusammenfassung: 4
| | |
| o | Änderung: 2:b500d0a90d40
| |/ Vorgänger: 0:385d95ab1fea
| | Nutzer: Arne Babenhauserheide <bab@draketo.de>
| | Datum: Tue Aug 14 15:09:39 2012 +0200
| | Zusammenfassung: 3
| |
o | Änderung: 1:8cc66166edc9
|/ Nutzer: Arne Babenhauserheide <bab@draketo.de>
| Datum: Tue Aug 14 15:09:38 2012 +0200
| Zusammenfassung: 2
|
o Änderung: 0:385d95ab1fea
Nutzer: Arne Babenhauserheide <bab@draketo.de>
Datum: Tue Aug 14 15:09:38 2012 +0200
Zusammenfassung: 1
The shortest representation is without the heads, though. It does not represent the current state of development if the last commit was a merge or if some branches were not merged. Otherwise it is equivalent.
$ hg log -Gr "(all() - merge())"
o Änderung: 3:55ba56aa8299
| Vorgänger: 0:385d95ab1fea
| Nutzer: Arne Babenhauserheide <bab@draketo.de>
| Datum: Tue Aug 14 15:09:40 2012 +0200
| Zusammenfassung: 4
|
| o Änderung: 2:b500d0a90d40
|/ Vorgänger: 0:385d95ab1fea
| Nutzer: Arne Babenhauserheide <bab@draketo.de>
| Datum: Tue Aug 14 15:09:39 2012 +0200
| Zusammenfassung: 3
|
| o Änderung: 1:8cc66166edc9
|/ Nutzer: Arne Babenhauserheide <bab@draketo.de>
| Datum: Tue Aug 14 15:09:38 2012 +0200
| Zusammenfassung: 2
|
o Änderung: 0:385d95ab1fea
Nutzer: Arne Babenhauserheide <bab@draketo.de>
Datum: Tue Aug 14 15:09:38 2012 +0200
Zusammenfassung: 1
The vanilla-log looks like this:
$ hg log -G
@ Änderung: 7:52fe4a8ec3cc
|\ Marke: tip
| | Vorgänger: 6:7d3026216270
| | Vorgänger: 5:848c390645ac
| | Nutzer: Arne Babenhauserheide <bab@draketo.de>
| | Datum: Tue Aug 14 15:09:54 2012 +0200
| | Zusammenfassung: merge
| |
| o Änderung: 6:7d3026216270
| |\ Vorgänger: 2:b500d0a90d40
| | | Vorgänger: 4:8dbc55213c9f
| | | Nutzer: Arne Babenhauserheide <bab@draketo.de>
| | | Datum: Tue Aug 14 15:09:45 2012 +0200
| | | Zusammenfassung: merged 4
| | |
o | | Änderung: 5:848c390645ac
|\| | Vorgänger: 3:55ba56aa8299
| | | Vorgänger: 2:b500d0a90d40
| | | Nutzer: Arne Babenhauserheide <bab@draketo.de>
| | | Datum: Tue Aug 14 15:09:43 2012 +0200
| | | Zusammenfassung: merged 2
| | |
+---o Änderung: 4:8dbc55213c9f
| | | Vorgänger: 3:55ba56aa8299
| | | Vorgänger: 1:8cc66166edc9
| | | Nutzer: Arne Babenhauserheide <bab@draketo.de>
| | | Datum: Tue Aug 14 15:09:41 2012 +0200
| | | Zusammenfassung: merged 1
| | |
o | | Änderung: 3:55ba56aa8299
| | | Vorgänger: 0:385d95ab1fea
| | | Nutzer: Arne Babenhauserheide <bab@draketo.de>
| | | Datum: Tue Aug 14 15:09:40 2012 +0200
| | | Zusammenfassung: 4
| | |
| o | Änderung: 2:b500d0a90d40
|/ / Vorgänger: 0:385d95ab1fea
| | Nutzer: Arne Babenhauserheide <bab@draketo.de>
| | Datum: Tue Aug 14 15:09:39 2012 +0200
| | Zusammenfassung: 3
| |
| o Änderung: 1:8cc66166edc9
|/ Nutzer: Arne Babenhauserheide <bab@draketo.de>
| Datum: Tue Aug 14 15:09:38 2012 +0200
| Zusammenfassung: 2
|
o Änderung: 0:385d95ab1fea
Nutzer: Arne Babenhauserheide <bab@draketo.de>
Datum: Tue Aug 14 15:09:38 2012 +0200
Zusammenfassung: 1
To create the test repo, I just used a few short loops in the shell:
hg init test ; cd test
for i in 1 2 3 4; do echo $i > $i ; hg ci -Am "$i"; hg up -r -$i; done
for i in 1 2 3 4; do echo $i > $i ; hg ci -Am "$i"; hg up -r -$i; hg merge $i ; hg ci -m "merged $i"; done
for i in $(hg heads --template "{node} ") ; do hg merge $i ; hg ci -m "merge"; done
Do you have better representations for viewing convoluted history?
PS: Yes, you can rewrite history, but that’s a really bad idea if you have many people who closely interact and publish early and often.
Links:
[1] http://mercurial.selenic.com/wiki/WhatsNew#Mercurial_2.4_.282012-11-1.29