Class: Flor::Pro::Schedule
- Inherits:
-
Flor::Procedure
- Object
- Node
- Flor::Procedure
- Flor::Pro::Schedule
- Defined in:
- lib/flor/punit/schedule.rb
Constant Summary
Constants inherited from Flor::Procedure
Flor::Procedure::RVARS, Flor::Procedure::TRUE_ATTS
Instance Attribute Summary
Attributes inherited from Node
Instance Method Summary collapse
- #pre_execute ⇒ Object
- #receive ⇒ Object
- #receive_last ⇒ Object
-
#wrap_cancel_children(h = {}) ⇒ Object
“schedule” keeps track of its children, but does not cascade ‘cancel’ to them, unless the cancel flavour is ‘kill’.
Methods inherited from Flor::Procedure
[], core?, #debug_msg, #debug_tree, #end, #flank, #heap, inherited, make, names, #prepare_on_receive_last, #trigger_on_error
Methods inherited from Node
#child_id, #cnodes, #cnodes_any?, #cnodes_empty?, #deref, #descendant_of?, #domain, #exid, #fei, #from, #h, #initialize, #lookup_tree, #lookup_value, #message_or_node_payload, #nid, #node_closed?, #node_ended?, #node_open?, #node_payload, #node_payload_ret, #node_status, #node_status_flavour, #on_error_parent, #parent, #payload, #payload_ret, #point, #reheap, #to_procedure_node, #tree
Constructor Details
This class inherits a constructor from Flor::Node
Instance Method Details
#pre_execute ⇒ Object
48 49 50 51 |
# File 'lib/flor/punit/schedule.rb', line 48 def pre_execute @node['atts'] = [] end |
#receive ⇒ Object
77 78 79 80 81 |
# File 'lib/flor/punit/schedule.rb', line 77 def receive return [] if @node['scheduled'] super end |
#receive_last ⇒ Object
53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 |
# File 'lib/flor/punit/schedule.rb', line 53 def receive_last fun = @fcid > 0 ? payload['ret'] : nil fail Flor::FlorError.new( "missing a function to call when the scheduler triggers", self ) unless fun m = apply(fun, [], tree[2], anid: false).first t, s = @node['atts'].find { |k, v| %w[ cron at in every ].include?(k) } || @node['atts'].find { |k, v| k == nil } fail Flor::FlorError.new( "missing a schedule", self ) unless s @node['scheduled'] = true wrap_schedule('type' => t, 'string' => s, 'message' => m) + flank end |
#wrap_cancel_children(h = {}) ⇒ Object
“schedule” keeps track of its children, but does not cascade ‘cancel’ to them, unless the cancel flavour is ‘kill’.
86 87 88 89 |
# File 'lib/flor/punit/schedule.rb', line 86 def wrap_cancel_children(h={}) h['flavour'] == 'kill' ? super : [] end |