Commit a831ee72 authored by Nicolas Dumazet's avatar Nicolas Dumazet

if all simulation movements are delivered, no need to check further

git-svn-id: https://svn.erp5.org/repos/public/erp5/trunk@36566 20353a03-c40f-0410-a6d1-a30d3c3de9de
parent be6274b2
No related merge requests found
...@@ -227,19 +227,22 @@ class BusinessPath(Path, Predicate): ...@@ -227,19 +227,22 @@ class BusinessPath(Path, Predicate):
def isBuildable(self, explanation): def isBuildable(self, explanation):
""" """
""" """
# check if there is at least one simulation movement which is not
# delivered
result = False
if self.isCompleted(explanation) or self.isFrozen(explanation): if self.isCompleted(explanation) or self.isFrozen(explanation):
return False # No need to build what was already built or frozen return False # No need to build what was already built or frozen
# check if there is at least one simulation movement which is not
# delivered
for simulation_movement in self.getRelatedSimulationMovementValueList( for simulation_movement in self.getRelatedSimulationMovementValueList(
explanation): explanation):
if simulation_movement.getDeliveryValue() is None: if simulation_movement.getDeliveryValue() is None:
result = True
break break
else:
# if all simulation movements are delivered, we can bail out
return False
predecessor = self.getPredecessorValue() predecessor = self.getPredecessorValue()
if predecessor is None: if predecessor is None:
return result return True
# XXX FIXME TODO # XXX FIXME TODO
# For now isPartiallyCompleted is used, as it was # For now isPartiallyCompleted is used, as it was
# assumed to not implement isPartiallyBuildable, so in reality # assumed to not implement isPartiallyBuildable, so in reality
...@@ -250,9 +253,7 @@ class BusinessPath(Path, Predicate): ...@@ -250,9 +253,7 @@ class BusinessPath(Path, Predicate):
# #
# Such cases are Business Processes using sequence not related # Such cases are Business Processes using sequence not related
# to simulation tree with much of compensations # to simulation tree with much of compensations
if predecessor.isPartiallyCompleted(explanation): return predecessor.isPartiallyCompleted(explanation)
return result
return False
def isPartiallyBuildable(self, explanation): def isPartiallyBuildable(self, explanation):
""" """
......
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