Since the subject of repository conversions has come up, a situation report...

I am in the very last stages of qualifying the Go port of reposurgeon.
Most importantly to your project, the Go code passed all of the
existing regression tests for reading Subversion stream dumps two days
ago. That is a big deal, as the stream dump reader was by *far* the
trickiest and most bug-prone part to translate.

Am now working on debugging a fairly peripheral feature called the
extractor harness.  This is what you use when a VCS doesn't have a
stream dump format and you have to call its CLI and mine the reports
from the CLI tools to get out the conyent and metadata. Not needed for
the GCC move.  The main application for it is actually lifting
Mercurial repositories - their export tools are weak and poorly
supported.

After that I want to get topological sorting of commits working in Go.
Also not needed for the GCC move, but I don't want to have any loose ends
dangling when I dive back into that.

Third and last item, clearing my current bug list.  The big one is
that last time I looked there was something wrong near execute-bit
propagation in interpreting Subversion dumps. But it is actually
possible that I've already fixed this in passing while verifying the
port - I found a suspicious failure to distinguish between "no
property set" and "an empty property set" last week.

I think I'm looking at somewhere between 7 and 14 days until I can start 
work on the GCC move again. Getting to this point has taken a year.

However, the hopes of a big speedup look like they'll be borne out.
Preliminary indications are that my test runs will be at least 12x
faster. In part due to Go and in part due to a new Great Beast, a 16-core
Threadripper machine with 128GB ram.  Finishing the move should now
be within the realm of the practically achievable.
-- 
                <a href="http://www.catb.org/~esr/";>Eric S. Raymond</a>


Reply via email to