Commit 3f9076db authored by Xavier Thompson's avatar Xavier Thompson

Fix cypclass dict item deletion invalidating active iterators

parent f98b1b25
...@@ -286,6 +286,7 @@ cdef cypclass cypdict[K, V]: ...@@ -286,6 +286,7 @@ cdef cypclass cypdict[K, V]:
it = self._indices.find(key) it = self._indices.find(key)
end = self._indices.end() end = self._indices.end()
if it != end: if it != end:
if self._active_iterators == 0:
index = dereference(it).second index = dereference(it).second
Cy_DECREF(self._items[index].first) Cy_DECREF(self._items[index].first)
Cy_DECREF(self._items[index].second) Cy_DECREF(self._items[index].second)
...@@ -293,6 +294,9 @@ cdef cypclass cypdict[K, V]: ...@@ -293,6 +294,9 @@ cdef cypclass cypdict[K, V]:
if index < self._items.size() - 1: if index < self._items.size() - 1:
self._items[index] = self._items[self._indices.size() - 1] self._items[index] = self._items[self._indices.size() - 1]
self._items.pop_back() self._items.pop_back()
else:
with gil:
raise RuntimeError("Modifying a dictionary with active iterators")
else: else:
with gil: with gil:
raise KeyError("Deleting nonexistent item") raise KeyError("Deleting nonexistent item")
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment