require 'rbbt-util' require 'rbbt/workflow/annotate' module Workflow include AnnotatedModule module DependencyBlock attr_accessor :dependency def self.setup(block, dependency) block.extend DependencyBlock block.dependency = dependency block end end AnnotatedModule.add_consummable_annotation(self, :result_description => "", :result_type => nil, :extension => '', :dependencies => []) def helper(name, &block) helpers[name] = block end def desc(description) @description = description end def extension(extension) @extension = extension end def returns(description) @result_description = description end def dep(*dependency_list, &block) @dependencies ||= [] if Module === dependency_list.first or Hash === dependency_list.last @dependencies << dependency_list else @dependency_list ||= [] if block_given? dependency_list.unshift self if dependency_list.length == 1 dependency_list << block end dependencies.concat dependency_list end end def dep(*dependency, &block) @dependencies ||= [] if block_given? dependency.unshift self if dependency.length == 1 DependencyBlock.setup block, dependency if dependency.any? @dependencies << block else if Module === dependency.first @dependencies << dependency else @dependencies.concat dependency end end end def task(name, &block) if Hash === name type = name.first.last name = name.first.first else result_type = consume_result_type || :marshal end name = name.to_sym block = self.method(name) unless block_given? task_info = { :name => name, :inputs => consume_inputs, :description => consume_description, :input_types => consume_input_types, :result_type => (Array === type ? type.to_sym : type), :input_defaults => consume_input_defaults, :input_descriptions => consume_input_descriptions, :extension => consume_extension, :input_options => consume_input_options } task = Task.setup(task_info, &block) last_task = task tasks[name] = task task_dependencies[name] = consume_dependencies end def export_exec(*names) exec_exports.concat names exec_exports.uniq! exec_exports end def export_asynchronous(*names) asynchronous_exports.concat names asynchronous_exports.uniq! asynchronous_exports end def export_synchronous(*names) synchronous_exports.concat names synchronous_exports.uniq! synchronous_exports end end