mercurial/context.py
changeset 34556 7a8a16f8ea22
parent 34479 99c3dee3f6ce
child 34681 4dc8a2ee0f4f
--- a/mercurial/context.py	Mon Oct 02 14:05:30 2017 -0700
+++ b/mercurial/context.py	Mon Oct 02 14:05:30 2017 -0700
@@ -1933,8 +1933,13 @@
         ``write()`` can be called successfully.
         """
         wvfs = self._repo.wvfs
-        if wvfs.isdir(self._path) and not wvfs.islink(self._path):
-            wvfs.removedirs(self._path)
+        f = self._path
+        if wvfs.isdir(f) and not wvfs.islink(f):
+            wvfs.rmtree(f, forcibly=True)
+        for p in reversed(list(util.finddirs(f))):
+            if wvfs.isfileorlink(p):
+                wvfs.unlink(p)
+                break
 
     def setflags(self, l, x):
         self._repo.wvfs.setflags(self._path, l, x)