lib/ruote/util/subprocess.rb in ruote-2.1.11 vs lib/ruote/util/subprocess.rb in ruote-2.2.0
- old
+ new
@@ -1,7 +1,7 @@
#--
-# Copyright (c) 2005-2010, John Mettraux, jmettraux@gmail.com
+# Copyright (c) 2005-2011, John Mettraux, jmettraux@gmail.com
#
# 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
@@ -30,39 +30,59 @@
#++
# This method is used by the 'subprocess' expression and by the
# EngineParticipant.
#
- def self.lookup_subprocess (fexp, ref)
+ def self.lookup_subprocess(fexp, ref)
val = fexp.lookup_variable(ref)
# a classical subprocess stored in a variable ?
return [ '0', val ] if is_tree?(val)
return val if is_pos_tree?(val)
# maybe subprocess :ref => 'uri'
- subtree = fexp.context.parser.parse(ref) rescue nil
+ subtree = fexp.context.reader.read(ref) rescue nil
- _, subtree = Ruote::Exp::DefineExpression.reorganize(subtree) \
- if subtree && Ruote::Exp::DefineExpression.is_definition?(subtree)
+ if subtree && is_definition_tree?(subtree)
+ _, subtree = Ruote::Exp::DefineExpression.reorganize(subtree)
+ end
return [ '0', subtree ] if is_tree?(subtree)
# no luck ...
raise "no subprocess named '#{ref}' found"
end
- def self.is_tree? (a)
+ # Returns true if the argument is a process definition tree (whose root
+ # is 'define', 'process_definition' or 'workflow_definition'.
+ #
+ def self.is_definition_tree?(arg)
- a.is_a?(Array) && a[1].is_a?(Hash) && a.size == 3
+ Ruote::Exp::DefineExpression.is_definition?(arg) && is_tree?(arg)
end
- def self.is_pos_tree? (a)
+ # Returns true if the given argument is a process definition tree
+ # (its root doesn't need to be 'define' or 'process_definition' though).
+ #
+ def self.is_tree?(arg)
- a.is_a?(Array) && a.size == 2 && a[0].is_a?(String) && is_tree?(a[1])
+ arg.is_a?(Array) && arg.size == 3 &&
+ arg[0].is_a?(String) && arg[1].is_a?(Hash) && arg[2].is_a?(Array) &&
+ (arg.last.empty? || arg.last.find { |e| ! is_tree?(e) }.nil?)
+ end
+
+ # Mainly used by Ruote.lookup_subprocess, returns true if the argument is
+ # is an array [ position, tree ].
+ #
+ def self.is_pos_tree?(arg)
+
+ arg.is_a?(Array) &&
+ arg.size == 2 &&
+ arg[0].is_a?(String) &&
+ is_tree?(arg[1])
end
end