subrepo: adjust subrepo prefix before calling subrepo.forget() (API)
authorMartin von Zweigbergk <martinvonz@google.com>
Thu, 07 Feb 2019 09:52:22 -0800
changeset 41627 f92844cb942c
parent 41626 2c549abc6b85
child 41628 ed046348675c
subrepo: adjust subrepo prefix before calling subrepo.forget() (API) Differential Revision: https://phab.mercurial-scm.org/D5883
mercurial/cmdutil.py
mercurial/subrepo.py
--- a/mercurial/cmdutil.py	Thu Feb 07 09:40:37 2019 -0800
+++ b/mercurial/cmdutil.py	Thu Feb 07 09:52:22 2019 -0800
@@ -2097,9 +2097,10 @@
 
     for subpath in sorted(wctx.substate):
         sub = wctx.sub(subpath)
+        submatch = matchmod.subdirmatcher(subpath, match)
+        subprefix = repo.wvfs.reljoin(prefix, subpath)
         try:
-            submatch = matchmod.subdirmatcher(subpath, match)
-            subbad, subforgot = sub.forget(submatch, prefix, dryrun=dryrun,
+            subbad, subforgot = sub.forget(submatch, subprefix, dryrun=dryrun,
                                            interactive=interactive)
             bad.extend([subpath + '/' + f for f in subbad])
             forgot.extend([subpath + '/' + f for f in subforgot])
--- a/mercurial/subrepo.py	Thu Feb 07 09:40:37 2019 -0800
+++ b/mercurial/subrepo.py	Thu Feb 07 09:52:22 2019 -0800
@@ -840,8 +840,7 @@
 
     @annotatesubrepoerror
     def forget(self, match, prefix, dryrun, interactive):
-        return cmdutil.forget(self.ui, self._repo, match,
-                              self.wvfs.reljoin(prefix, self._path),
+        return cmdutil.forget(self.ui, self._repo, match, prefix,
                               True, dryrun=dryrun, interactive=interactive)
 
     @annotatesubrepoerror