This repository has been archived on 2017-04-03. You can view files and clone it, but cannot push or open issues or pull requests.
blog_post_tests/20121202222923.blog

10 lines
3.3 KiB
Plaintext
Raw Normal View History

2014-11-19 15:42:25 +00:00
Beware! The Reposturgeon!
<p>I had said I wasn&#8217;t going to do it, but&#8230;I experimented, and it turned out to be easier than I thought. Release 2.7 of <a href="http://www.catb.org/esr/reposurgeon/">reposurgeon</a> writes (as well as reading) Subversion repositories. With the untested support for darcs, which should work exactly as well as darcs fast-export and fast-import do, this now brings the set of fully-supported version-control systems to git, hg, bzr, svn, and darcs; reposurgeon can be used for repository surgery and interconversion on any of these.</p>
<p><span id="more-4721"></span></p>
<p>There are some significant limitations in the write-side Subversion support. For various ugly reasons having to do with the mismatch between Subversion&#8217;s ontology and that of git import streams, Subversion repositories won&#8217;t usually round-trip exactly through reposurgeon. File content histories will remain the same, but the timing of directory creations and deletions may change. The pathological things known in the Subversion world as &#8220;mixed-branch commits&#8221; are split apart at Subversion-read time and not reassembled when and if the repo state is written back out in Subversion form. Custom Subversion property settings (basically, everything but svn:ignore, svn:executable, and svn:mergeinfo) are lost on the way through. There are other problems of a similar nature, all documented in the <a href="http://www.catb.org/~esr/reposurgeon/reposurgeon.html">manual</a>.</p>
<p>A particularly unfortunate problem is that mergeinfo properties may be simplified or lost. Mapping between gitspace and Subversion merges is messy because a Subversion merge is more like what gitonauts call a &#8220;cherry-pick&#8221; than a git-space merge &#8211; I don&#8217;t have a general algorithm for this (it&#8217;s a research-level problem!) and don&#8217;t try to handle more than the most obvious branch-merge cases.</p>
<p>It could fairly be alleged that the capability to write Subversion repositories is more a cute stunt than anything that&#8217;s likely to be useful in a production situation. While I have regression tests for it that show it works on branching and merging commit graphs, I don&#8217;t think I&#8217;d actually want to trust it, yet, on a repository that wasn&#8217;t linear or only simply branching. Arcane combinations of branching, merging, and tagging could reveal subtle bugs without surprising me even slightly.</p>
<p>Still&#8230;having it work even as conditionally as it does seems something of an achievement. Not one I was expecting, either. I really only did it because someone on the Subversion dev list asked about write support, I wanted to reply by listing all the reasons it wouldn&#8217;t work &#8211; and then I found that I couldn&#8217;t actually make that list without trying to implement the feature. It was ever thus&#8230;</p>
<p>The only unconquered frontier of any significance in open-source VCSes is CVS, really. No way I&#8217;ll do write-side support for that (and I mean it this time!) but I&#8217;ve sent the maintainer of <a href="http://www.cobite.com/cvsps/">cvsps</a> a proof-of-concept patch that <em>almost</em> completely implements a fast-export stream dump for CVS repositories. We&#8217;ll see where that goes. </p>
<p><a href="http://www.catb.org/esr/reposurgeon/">Fear the reposturgeon!</a></p>