exchange: pass includepats and excludepats as arguments to getbundle()
authorPulkit Goyal <pulkit@yandex-team.ru>
Tue, 16 Oct 2018 17:53:26 +0300
changeset 40542 440f5b65be57
parent 40541 c311424ea579
child 40543 a2c4502e409b
exchange: pass includepats and excludepats as arguments to getbundle() This will help in implementing narrow stream clones. Also narrow extension used to add these arguments, now we add them by default if they are not empty. Since reading includepats and excludepats on the server only works when narrow is enabled, we check if narrow if enabled or not before passing them. Differential Revision: https://phab.mercurial-scm.org/D5119
hgext/narrow/narrowbundle2.py
mercurial/exchange.py
mercurial/wireprototypes.py
--- a/hgext/narrow/narrowbundle2.py	Thu Nov 01 16:51:21 2018 -0700
+++ b/hgext/narrow/narrowbundle2.py	Tue Oct 16 17:53:26 2018 +0300
@@ -260,8 +260,6 @@
     getbundleargs['depth'] = 'plain'
     getbundleargs['oldincludepats'] = 'csv'
     getbundleargs['oldexcludepats'] = 'csv'
-    getbundleargs['includepats'] = 'csv'
-    getbundleargs['excludepats'] = 'csv'
     getbundleargs['known'] = 'csv'
 
     # Extend changegroup serving to handle requests from narrow clients.
--- a/mercurial/exchange.py	Thu Nov 01 16:51:21 2018 -0700
+++ b/mercurial/exchange.py	Tue Oct 16 17:53:26 2018 +0300
@@ -40,6 +40,7 @@
     streamclone,
     url as urlmod,
     util,
+    wireprototypes,
 )
 from .utils import (
     stringutil,
@@ -1633,6 +1634,13 @@
     kwargs['common'] = pullop.common
     kwargs['heads'] = pullop.heads or pullop.rheads
 
+    # check server supports narrow and then adding includepats and excludepats
+    servernarrow = pullop.remote.capable(wireprototypes.NARROWCAP)
+    if servernarrow and pullop.includepats:
+        kwargs['includepats'] = pullop.includepats
+    if servernarrow and pullop.excludepats:
+        kwargs['excludepats'] = pullop.excludepats
+
     if streaming:
         kwargs['cg'] = False
         kwargs['stream'] = True
--- a/mercurial/wireprototypes.py	Thu Nov 01 16:51:21 2018 -0700
+++ b/mercurial/wireprototypes.py	Tue Oct 16 17:53:26 2018 +0300
@@ -162,6 +162,8 @@
     'cg': 'boolean',
     'cbattempted': 'boolean',
     'stream': 'boolean',
+    'includepats': 'csv',
+    'excludepats': 'csv',
 }
 
 class baseprotocolhandler(interfaceutil.Interface):