Re: New converstion tool: svn2git.py

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Wed, 19 Nov 2008, Neil Schemenauer wrote:

> Hi,
> 
> I'm working on a tool to do conversions from SVN to git using a SVN
> dump.  It's in early development but perhaps some people would be
> interested in it:
> 
>     http://python.ca/nas/python/svn2git.py
> 
> I would like to improve it so that it intelligently converts SVN
> branches and tags into git branches (when possible).  The basic idea
> is to map SVN paths into git branches, e.g. trunk -> master,
> branches/foo -> branch-foo, tags/bar -> tags-bar.  Next, specific
> SVN dump actions like:
> 
>     Node-path: branches/foo
>     Node-kind: dir
>     Node-action: add
>     Node-copyfrom-rev: 3
>     Node-copyfrom-path: trunk
> 
> need to be detected and the commit needs to performed with the
> correct parent.  One complication is that SVN can create a branch or
> tag from anywhere, for example, the action
> 
>     Node-path: tags/bar
>     Node-kind: dir
>     Node-action: add
>     Node-copyfrom-rev: 3
>     Node-copyfrom-path: trunk/subdir
> 
> would create tags/bar based on revision 3 of trunk/subdir.  There
> doesn't seem to be a good way to convert that into git.  I was
> thinking that the tags-bar branch in that case would have no parent.

Probably the best thing in git would be to have the parent of the initial 
commit on that branch be revision 3 of trunk; it will look like a big 
rename of everything from subdir/* into the project root directory, which 
is essentially what happened.

> Would git still efficently pack that or would you end up with extra
> blobs?

git will only ever store a single copy of identical file contents, 
regardless of anything at all. Furthermore, when making a pack, git 
compresses everything in the pack against everything else in the pack. Its 
heuristics also ignore the leading directory names in guessing which blobs 
are likely to help in compression (because there's a good chance that 
anything named "Makefile" anywhere is useful in compressing anything else 
named "Makefile").

	-Daniel
*This .sig left intentionally blank*
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux