Mercurial > hg
view contrib/git-viz/hg-viz @ 9431:d1b135f2f415
convert: fix history topology when using hg.tagsbranch
When using hg.tagsbranch, all conversions fail at
transcribing the source repo topology with conversion
scenarios interleaving:
- initial repo conversion,
- then upstream tag
- then later incremental conversion
The problem is caused by the usage of the last source
revid as source revid for the tagnode in the revision
map.
On a later incremental conversion, when resolving some
child commit of the true last source revid, convert
will parent the nodes to the tag node. If using
tagsbranch you get a bad topology where all incremental
commit nodes end up in the tag branch.
Analysis and test by Edouard Gomez <ed.gomez@free.fr>
author | Patrick Mezard <pmezard@gmail.com> |
---|---|
date | Sun, 06 Sep 2009 15:29:14 +0200 |
parents | d8abb687d501 |
children |
line wrap: on
line source
#!/bin/sh set -e if test x"$1" != x ; then cd $1 fi if [ ! -d ".hg" ]; then echo "${1:-.} is not a mercurial repository" 1>&2 echo "Aborting" 1>&2 exit 1 fi if [ ! -d ".git" ]; then mkdir -v ".git" fi if [ -e ".git/HEAD" ]; then if [ ! -e ".git/HEAD.hg-viz-save" ]; then mv -v ".git/HEAD" ".git/HEAD.hg-viz-save" else rm -vf ".git/HEAD" fi fi hg history | head -1 | awk -F: '{print $3}' > .git/HEAD git-viz