diff mercurial/dirstate.py @ 34933:0217f75b6e59 stable

dirstate: move clear onto dirstatemap class A future diff will move the lazy loading aspect of dirstate to the dirstatemap class. This means it requires a slightly different strategy of clearing than just reinstantiating the object (since just reinstantiating the object will lazily load the on disk data again later instead of remaining permanently empty). So let's give it it's own clear function. Differential Revision: https://phab.mercurial-scm.org/D1252
author Durham Goode <durham@fb.com>
date Thu, 26 Oct 2017 16:15:31 -0700
parents e8a89ed7ce96
children 6e66033f91cc
line wrap: on
line diff
--- a/mercurial/dirstate.py	Fri Oct 27 18:19:07 2017 +0200
+++ b/mercurial/dirstate.py	Thu Oct 26 16:15:31 2017 -0700
@@ -593,8 +593,7 @@
         return path
 
     def clear(self):
-        self._map = dirstatemap(self._ui, self._opener, self._root)
-        self._map.setparents(nullid, nullid)
+        self._map.clear()
         self._lastnormaltime = 0
         self._updatedfiles.clear()
         self._dirty = True
@@ -1210,6 +1209,11 @@
         # for consistent view between _pl() and _read() invocations
         self._pendingmode = None
 
+    def clear(self):
+        self._map = {}
+        self.copymap = {}
+        self.setparents(nullid, nullid)
+
     def iteritems(self):
         return self._map.iteritems()