sparse: move code for clearing rules to core
This is a pretty straightforward port.
--- 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)