diff hgsubversion/wrappers.py @ 787:4bbc6bf947f5 1.2.1

replay: fetch full revision at most once per run (issue252) Before this change, hgsubversion was fetching full revisions from the first revision the project was created to the first revision containing converted data. Unfortunately, some projects exhibits such spans longer than 500 revisions, during which hgsubversion was uselessly scanning the whole tree. The fix is not technically perfect, we could record somewhere that while no data was converted we scanned the project already, instead of scanning once at every hgsubversion run until a revision is converted. But it should be good enough unless someone runs hgsubversion once for every target revision. One repository exhibiting this behaviour: svn://svn.zankasoftware.com/zanka
author Patrick Mezard <pmezard@gmail.com>
date Sun, 13 Feb 2011 20:10:52 +0100
parents 7913a82a8cdd
children d50858a8a17b
line wrap: on
line diff
--- a/hgsubversion/wrappers.py
+++ b/hgsubversion/wrappers.py
@@ -294,6 +294,7 @@ def pull(repo, source, heads=[], force=F
     try:
         try:
             # start converting revisions
+            firstrun = True
             for r in svn.revisions(start=start, stop=stopat_rev):
                 if (r.author is None and
                     r.message == 'This is an empty revision for padding.'):
@@ -320,7 +321,8 @@ def pull(repo, source, heads=[], force=F
                         util.progress(ui, 'pull', r.revnum - start, total=total)
 
                         meta.save_tbdelta(tbdelta)
-                        close = pullfuns[have_replay](ui, meta, svn, r, tbdelta)
+                        close = pullfuns[have_replay](ui, meta, svn, r, tbdelta,
+                                                      firstrun)
                         meta.committags(r, close)
                         for branch, parent in close.iteritems():
                             if parent in (None, node.nullid):
@@ -329,6 +331,7 @@ def pull(repo, source, heads=[], force=F
 
                         meta.save()
                         converted = True
+                        firstrun = False
 
                     except svnwrap.SubversionRepoCanNotReplay, e: #pragma: no cover
                         ui.status('%s\n' % e.message)