sparse: move code for clearing rules to core
authorGregory Szorc <gregory.szorc@gmail.com>
Sat, 08 Jul 2017 13:19:38 -0700
changeset 33354 4695f1829045
parent 33353 160efb559f67
child 33355 9087f9997f42
sparse: move code for clearing rules to core This is a pretty straightforward port.
hgext/sparse.py
mercurial/sparse.py
--- a/hgext/sparse.py	Fri Jul 07 11:51:10 2017 -0700
+++ b/hgext/sparse.py	Sat Jul 08 13:19:38 2017 -0700
@@ -365,7 +365,7 @@
         _import(ui, repo, pats, opts, force=force)
 
     if clearrules:
-        _clear(ui, repo, pats, force=force)
+        sparse.clearrules(repo, force=force)
 
     if refresh:
         try:
@@ -503,17 +503,6 @@
         _verbose_output(ui, opts, profilecount, includecount, excludecount,
                         *fcounts)
 
-def _clear(ui, repo, files, force=False):
-    with repo.wlock():
-        raw = repo.vfs.tryread('sparse')
-        includes, excludes, profiles = sparse.parseconfig(ui, raw)
-
-        if includes or excludes:
-            oldstatus = repo.status()
-            oldsparsematch = sparse.matcher(repo)
-            sparse.writeconfig(repo, set(), set(), profiles)
-            sparse.refreshwdir(repo, oldstatus, oldsparsematch, force)
-
 def _verbose_output(ui, opts, profilecount, includecount, excludecount, added,
                     dropped, lookup):
     """Produce --verbose and templatable output
--- a/mercurial/sparse.py	Fri Jul 07 11:51:10 2017 -0700
+++ b/mercurial/sparse.py	Sat Jul 08 13:19:38 2017 -0700
@@ -494,3 +494,21 @@
         refreshwdir(repo, origstatus, origsparsematch, force=True)
 
     prunetemporaryincludes(repo)
+
+def clearrules(repo, force=False):
+    """Clears include/exclude rules from the sparse config.
+
+    The remaining sparse config only has profiles, if defined. The working
+    directory is refreshed, as needed.
+    """
+    with repo.wlock():
+        raw = repo.vfs.tryread('sparse')
+        includes, excludes, profiles = parseconfig(repo.ui, raw)
+
+        if not includes and not excludes:
+            return
+
+        oldstatus = repo.status()
+        oldmatch = matcher(repo)
+        writeconfig(repo, set(), set(), profiles)
+        refreshwdir(repo, oldstatus, oldmatch, force=force)