Commit 775bab2d authored by wenjie.zheng's avatar wenjie.zheng

InteractionWorkflow.py: deploy property accessors as many as possible.

parent e8215657
...@@ -140,14 +140,15 @@ class InteractionWorkflow(IdAsReferenceMixin("", "prefix"), Workflow): ...@@ -140,14 +140,15 @@ class InteractionWorkflow(IdAsReferenceMixin("", "prefix"), Workflow):
getSecurityManager(), self, ob): getSecurityManager(), self, ob):
return default return default
status = self._getStatusOf(ob) status = self._getStatusOf(ob)
default_expr = vdef.getDefaultExpr()
if status is not None and name in status: if status is not None and name in status:
value = status[name] value = status[name]
# Not set yet. Use a default. # Not set yet. Use a default.
elif vdef.default_expr is not None: elif default_expr is not None:
ec = createExprContext(StateChangeInfo(ob, self, status)) ec = createExprContext(StateChangeInfo(ob, self, status))
value = Expression(vdef.default_expr)(ec) value = Expression(default_expr)(ec)
else: else:
value = vdef.default_value value = vdef.getInitialValue()
return value return value
...@@ -161,7 +162,7 @@ class InteractionWorkflow(IdAsReferenceMixin("", "prefix"), Workflow): ...@@ -161,7 +162,7 @@ class InteractionWorkflow(IdAsReferenceMixin("", "prefix"), Workflow):
return tdef is not None and self._checkTransitionGuard(tdef, ob) return tdef is not None and self._checkTransitionGuard(tdef, ob)
def _checkTransitionGuard(self, tdef, document, **kw): def _checkTransitionGuard(self, tdef, document, **kw):
if tdef.temporary_document_disallowed: if tdef.getTemporaryDocumentDisallowed():
isTempDocument = getattr(document, 'isTempDocument', None) isTempDocument = getattr(document, 'isTempDocument', None)
if isTempDocument is not None: if isTempDocument is not None:
if isTempDocument(): if isTempDocument():
...@@ -253,7 +254,7 @@ class InteractionWorkflow(IdAsReferenceMixin("", "prefix"), Workflow): ...@@ -253,7 +254,7 @@ class InteractionWorkflow(IdAsReferenceMixin("", "prefix"), Workflow):
for t_id in transition_list: for t_id in transition_list:
tdef = self._getOb('interaction_' + t_id ) tdef = self._getOb('interaction_' + t_id )
assert tdef.trigger_type == TRIGGER_WORKFLOW_METHOD assert tdef.getTriggerType() == TRIGGER_WORKFLOW_METHOD
filtered_transition_list.append(tdef.getId()) filtered_transition_list.append(tdef.getId())
former_status = {} former_status = {}
...@@ -284,7 +285,7 @@ class InteractionWorkflow(IdAsReferenceMixin("", "prefix"), Workflow): ...@@ -284,7 +285,7 @@ class InteractionWorkflow(IdAsReferenceMixin("", "prefix"), Workflow):
for t_id in transition_list: for t_id in transition_list:
tdef = self._getOb('interaction_' + t_id ) tdef = self._getOb('interaction_' + t_id )
assert tdef.trigger_type == TRIGGER_WORKFLOW_METHOD assert tdef.getTriggerType() == TRIGGER_WORKFLOW_METHOD
former_status = {} former_status = {}
econtext = None econtext = None
sci = None sci = None
...@@ -296,19 +297,20 @@ class InteractionWorkflow(IdAsReferenceMixin("", "prefix"), Workflow): ...@@ -296,19 +297,20 @@ class InteractionWorkflow(IdAsReferenceMixin("", "prefix"), Workflow):
for vdef in self.objectValues(portal_type='Variable'): for vdef in self.objectValues(portal_type='Variable'):
id = vdef.getId() id = vdef.getId()
if not vdef.for_status: if not vdef.getForStatus():
continue continue
expr = None expr = None
if id in tdef_exprs: if id in tdef_exprs:
expr = tdef_exprs[id] expr = tdef_exprs[id]
elif not vdef.update_always and id in former_status: elif not vdef.getAutomaticUpdate() and id in former_status:
# Preserve former value # Preserve former value
value = former_status[id] value = former_status[id]
else: else:
if vdef.default_expr is not None: default_expr = vdef.getDefaultExpr()
expr = vdef.default_expr if default_expr is not None:
expr = Expression(default_expr)
else: else:
value = vdef.default_value value = vdef.getInitialValue()
if expr is not None: if expr is not None:
# Evaluate an expression. # Evaluate an expression.
if econtext is None: if econtext is None:
...@@ -386,7 +388,7 @@ class InteractionWorkflow(IdAsReferenceMixin("", "prefix"), Workflow): ...@@ -386,7 +388,7 @@ class InteractionWorkflow(IdAsReferenceMixin("", "prefix"), Workflow):
if action in sdef.getDestinationIdList(): if action in sdef.getDestinationIdList():
tdef = self._getOb(action, None) tdef = self._getOb(action, None)
if (tdef is not None and if (tdef is not None and
tdef.trigger_type == TRIGGER_USER_ACTION and tdef.getTriggerType() == TRIGGER_USER_ACTION and
self._checkTransitionGuard(tdef, document, **kw)): self._checkTransitionGuard(tdef, document, **kw)):
return 1 return 1
return 0 return 0
......
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