bundle2: pull bookmark the old way if no bundle2 listkeys support (issue4701)
authorPierre-Yves David <pierre-yves.david@fb.com>
Mon, 08 Jun 2015 13:32:38 -0700
changeset 25479 f00a63a43c4b
parent 25478 d19787db6fe0
child 25480 d410336fdb3c
bundle2: pull bookmark the old way if no bundle2 listkeys support (issue4701) All known server implementations have listkeys support with bundle2, but people in the process of implementing new servers may not. Let's be nice with them.
mercurial/exchange.py
--- a/mercurial/exchange.py	Mon Jun 08 15:10:15 2015 -0500
+++ b/mercurial/exchange.py	Mon Jun 08 13:32:38 2015 -0700
@@ -955,8 +955,12 @@
     discovery to reduce the chance and impact of race conditions."""
     if pullop.remotebookmarks is not None:
         return
-    if not _canusebundle2(pullop): # all bundle2 server now support listkeys
-        pullop.remotebookmarks = pullop.remote.listkeys('bookmarks')
+    if (_canusebundle2(pullop)
+            and 'listkeys' in bundle2.bundle2caps(pullop.remote)):
+        # all known bundle2 servers now support listkeys, but lets be nice with
+        # new implementation.
+        return
+    pullop.remotebookmarks = pullop.remote.listkeys('bookmarks')
 
 
 @pulldiscovery('changegroup')