Commit c120ccd9 authored by Nicolas Dumazet's avatar Nicolas Dumazet

rename visited_dict to visited_movement_dict to clarify what's in there.

git-svn-id: https://svn.erp5.org/repos/public/erp5/trunk@37097 20353a03-c40f-0410-a6d1-a30d3c3de9de
parent ea1d3191
...@@ -619,16 +619,17 @@ class SimulationMovement(Movement, PropertyRecordableMixin): ...@@ -619,16 +619,17 @@ class SimulationMovement(Movement, PropertyRecordableMixin):
class treeNode(dict): class treeNode(dict):
""" """
Used to cache accesses to ZODB objects. Used to cache accesses to ZODB objects.
The idea is to put in visited_dict the objects we've already The idea is to put in visited_movement_dict the objects we've already
loaded from ZODB in Step #2 to avoid loading them again in Step #3. loaded from ZODB in Step #2 to avoid loading them again in Step #3.
- self represents a single ZODB container c - self represents a single ZODB container c
- self.visited_dict contains an id->(ZODB obj) cache for subobjects of c - self.visited_movement_dict contains an id->(ZODB obj) cache for
subobjects of c
- self[id] contains the treeNode representing c[id] - self[id] contains the treeNode representing c[id]
""" """
def __init__(self): def __init__(self):
dict.__init__(self) dict.__init__(self)
self.visited_dict = dict() self.visited_movement_dict = dict()
path_tree = treeNode() path_tree = treeNode()
def updateTree(simulation_movement, path): def updateTree(simulation_movement, path):
...@@ -639,7 +640,7 @@ class SimulationMovement(Movement, PropertyRecordableMixin): ...@@ -639,7 +640,7 @@ class SimulationMovement(Movement, PropertyRecordableMixin):
for path_id in movement_path[:-1]: for path_id in movement_path[:-1]:
tree_node = tree_node.setdefault(path_id, treeNode()) tree_node = tree_node.setdefault(path_id, treeNode())
# and mark the object as visited # and mark the object as visited
tree_node.visited_dict[simulation_movement_id] = (simulation_movement, path) tree_node.visited_movement_dict[simulation_movement_id] = (simulation_movement, path)
portal_catalog = self.getPortalObject().portal_catalog portal_catalog = self.getPortalObject().portal_catalog
catalog_simulation_movement_list = portal_catalog( catalog_simulation_movement_list = portal_catalog(
...@@ -670,17 +671,17 @@ class SimulationMovement(Movement, PropertyRecordableMixin): ...@@ -670,17 +671,17 @@ class SimulationMovement(Movement, PropertyRecordableMixin):
""" """
object_id_list = document.objectIds() object_id_list = document.objectIds()
for id in object_id_list: for id in object_id_list:
if id not in tree_node.visited_dict: if id not in tree_node.visited_movement_dict:
# we had not visited it in step #2 # we had not visited it in step #2
subdocument = document._getOb(id) subdocument = document._getOb(id)
if subdocument.getPortalType() == "Simulation Movement": if subdocument.getPortalType() == "Simulation Movement":
path = subdocument.getCausalityValue() path = subdocument.getCausalityValue()
t = (subdocument, path) t = (subdocument, path)
tree_node.visited_dict[id] = t tree_node.visited_movement_dict[id] = t
if path in path_set_to_check: if path in path_set_to_check:
yield t yield t
for id, t in tree_node.visited_dict.iteritems(): for id, t in tree_node.visited_movement_dict.iteritems():
subdocument, path = t subdocument, path = t
to_check = path_set_to_check.copy() to_check = path_set_to_check.copy()
to_check.discard(path) to_check.discard(path)
......
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