changeset 618:82bfc96a1311

svnrepo: support new discovery module introduced in 3d0591a66118
author Augie Fackler <durin42@gmail.com>
date Sat, 12 Jun 2010 20:55:23 -0500 (2010-06-13)
parents da21c351d937
children 8beb5e28c23b
files hgsubversion/__init__.py hgsubversion/svnrepo.py
diffstat 2 files changed, 20 insertions(+), 1 deletions(-) [+]
line wrap: on
line diff
--- a/hgsubversion/__init__.py
+++ b/hgsubversion/__init__.py
@@ -75,6 +75,20 @@ wrapcmds = { # cmd: generic, target, fix
     ]),
 }
 
+
+# only need the discovery variant of this code when we drop hg < 1.6
+try:
+    from mercurial import discovery
+    def findoutgoing(orig, *args, **opts):
+        capable = getattr(args[1], 'capable', lambda x: False)
+        if capable('subversion'):
+            return wrappers.outgoing(*args, **opts)
+        else:
+            return orig(*args, **opts)
+    extensions.wrapfunction(discovery, 'findoutgoing', findoutgoing)
+except ImportError:
+    pass
+
 def uisetup(ui):
     """insert command wrappers for a bunch of commands"""
     docvals = {'extension': 'hgsubversion'}
--- a/hgsubversion/svnrepo.py
+++ b/hgsubversion/svnrepo.py
@@ -36,7 +36,12 @@ def generate_repo_class(ui, repo):
         Filter for instance methods which require the first argument
         to be a remote Subversion repository instance.
         """
-        original = getattr(repo, fn.__name__)
+        original = getattr(repo, fn.__name__, None)
+
+        # remove when dropping support for hg < 1.6.
+        if original is None and fn.__name__ == 'findoutgoing':
+            return
+
         def wrapper(self, *args, **opts):
             capable = getattr(args[0], 'capable', lambda x: False)
             if capable('subversion'):