lib/openwfe/expressions/fe_do.rb in ruote-0.9.19 vs lib/openwfe/expressions/fe_do.rb in ruote-0.9.20
- old
+ new
@@ -1,57 +1,41 @@
-#
#--
-# Copyright (c) 2007-2008, John Mettraux, OpenWFE.org
-# All rights reserved.
+# Copyright (c) 2007-2009, John Mettraux, jmettraux@gmail.com
#
-# Redistribution and use in source and binary forms, with or without
-# modification, are permitted provided that the following conditions are met:
+# Permission is hereby granted, free of charge, to any person obtaining a copy
+# of this software and associated documentation files (the "Software"), to deal
+# in the Software without restriction, including without limitation the rights
+# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+# copies of the Software, and to permit persons to whom the Software is
+# furnished to do so, subject to the following conditions:
#
-# . Redistributions of source code must retain the above copyright notice, this
-# list of conditions and the following disclaimer.
+# The above copyright notice and this permission notice shall be included in
+# all copies or substantial portions of the Software.
#
-# . Redistributions in binary form must reproduce the above copyright notice,
-# this list of conditions and the following disclaimer in the documentation
-# and/or other materials provided with the distribution.
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+# THE SOFTWARE.
#
-# . Neither the name of the "OpenWFE" nor the names of its contributors may be
-# used to endorse or promote products derived from this software without
-# specific prior written permission.
-#
-# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
-# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
-# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
-# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
-# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
-# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
-# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
-# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
-# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
-# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
-# POSSIBILITY OF SUCH DAMAGE.
+# Made in Japan.
#++
-#
-#
-# "made in Japan"
-#
-# John Mettraux at openwfe.org
-#
require 'openwfe/utils'
+require 'openwfe/expressions/value'
require 'openwfe/expressions/flowexpression'
-#
-# redo / undo (cancel)
-#
-
module OpenWFE
#
- # Every expression in OpenWFEru accepts a 'tag' attribute. This tag
+ # Every expression in Ruote accepts a 'tag' attribute. This tag
# can later be referenced by an 'undo' or 'redo' expression.
+ #
# Tags are active as soon as an expression is applied and they vanish
# when the expression replies to its parent expression or is cancelled.
#
# Calling for the undo of a non-existent tag throws no error, the flow
# simply resumes.
@@ -69,88 +53,115 @@
#
# In this example, as soon as the participant charly is over, the sequence
# 'side_job' gets undone (cancelled). If the sequence 'side_job' was
# already over, the "undo" will have no effect.
#
+ # Note that since Ruote 0.9.20, it's OK to simply write :
+ #
+ # undo "side_job"
+ #
+ # Since Ruote 0.9.20, putting a condition on 'undo' is accepted :
+ #
+ # undo 'side_job', :if => '${f:something_went_wrong} == true'
+ #
class UndoExpression < FlowExpression
+ include ValueMixin
+ include ConditionMixin
- names :undo
+ names :undo#, :cancel
- def apply (workitem)
+ def reply (workitem)
- tag = lookup_tag(workitem)
+ conditional = eval_condition(:if, workitem, :unless)
- undo_self = false
+ return reply_to_parent(workitem) if conditional == false
- if tag
- #OpenWFE::call_in_thread(fei.expression_name, self) do
- process_tag tag
- #end
+ if tag = lookup_tag(workitem)
- undo_self = tag.fei.ancestor_of?(@fei)
- end
+ get_workqueue.push(self, :process_tag, tag, workitem)
- reply_to_parent(workitem) unless undo_self
+ else
+
+ reply_to_parent(workitem)
+ end
end
#
# Calls the expression pool cancel() method upon the tagged
# expression.
#
- def process_tag (tag)
+ def process_tag (tag, workitem)
- ldebug do
- "process_tag() #{fei.to_debug_s} to undo #{tag.fei.to_debug_s}"
- end
+ ldebug { "process_tag() #{fei.to_debug_s} to undo #{tag.fei.to_debug_s}" }
- #get_expression_pool.cancel_and_reply_to_parent(
- # tag.raw_expression.fei, tag.workitem)
-
exp = get_expression_pool.fetch_expression(tag.raw_expression.fei)
+ #
+ # cancel target
+
get_expression_pool.cancel(tag.raw_expression.fei)
get_expression_pool.reply_to_parent(exp, tag.workitem, false)
#
# 'remove' is set to false, cancel already removed the
# expression
- end
- #def reply (workitem)
- #end
+ undoing_self = tag.fei.ancestor_of?(@fei)
+ reply_to_parent(workitem) unless undoing_self
+ end
+
protected
- def lookup_tag (workitem)
+ def lookup_tag (workitem)
- tagname = lookup_attribute :ref, workitem
+ tagname = workitem.get_result || lookup_attribute(:ref, workitem)
+ tagname = tagname.to_s
- tag = lookup_variable tagname
+ return nil unless tagname
- lwarn { "lookup_tag() no tag named '#{tagname}' found" } \
- unless tag
+ tag = lookup_variable(tagname)
- tag
- end
+ lwarn { "lookup_tag() no tag named '#{tagname}' found" } unless tag
+
+ tag
+ end
end
#
- # Every expression in OpenWFEru accepts a 'tag' attribute. This tag
+ # Every expression in Ruote accepts a 'tag' attribute. This tag
# can later be referenced by an 'undo' or 'redo' expression.
#
+ # Tags are active as soon as an expression is applied and they vanish
+ # when the expression replies to its parent expression or is cancelled.
+ #
# Calling for the undo of a non-existent tag throws no error, the flow
# simply resumes.
#
+ # concurrence do
+ # sequence :tag => 'side_job' do
+ # participant 'alice'
+ # participant 'bob'
+ # end
+ # _redo :ref => 'side_job'
+ # end
+ #
+ # Note that since Ruote 0.9.20, it's OK to simply write :
+ #
+ # _redo "that_step"
+ #
+ # and condition on redo are accepted as well :
+ #
+ # <redo ref="that_step" if="${f:misaligned} == true" />
+ #
class RedoExpression < UndoExpression
names :redo
- def process_tag (tag)
+ def process_tag (tag, workitem)
- ldebug do
- "process_tag() #{fei.to_debug_s} to redo #{tag.fei.to_debug_s}"
- end
+ ldebug { "process_tag() #{fei.to_debug_s} to redo #{tag.fei.to_debug_s}" }
#
# cancel
get_expression_pool.cancel(tag.fei)
@@ -158,10 +169,12 @@
#
# [re]apply
tag.raw_expression.application_context = @application_context
- get_expression_pool.apply tag.raw_expression, tag.workitem
+ get_expression_pool.apply(tag.raw_expression, tag.workitem)
+
+ reply_to_parent(workitem)
end
end
end