Class: Flor::Pro::Abort

Inherits:
Flor::Procedure show all
Defined in:
lib/flor/punit/abort.rb

Constant Summary

Constants inherited from Flor::Procedure

Flor::Procedure::RVARS, Flor::Procedure::TRUE_ATTS

Instance Attribute Summary

Attributes inherited from Node

#message

Instance Method Summary collapse

Methods inherited from Flor::Procedure

[], core?, #debug_msg, #debug_tree, #end, #flank, #heap, inherited, make, names, #pre_execute, #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

#receive_lastObject



28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
# File 'lib/flor/punit/abort.rb', line 28

def receive_last

  fla = heap == 'kabort' ? 'kill' : 'cancel'

  nodes = @execution['nodes']
  nids = nodes.keys.dup

  @execution['nodes'].values.each do |n|

#p n.select { |k, v| %w[ nid can parent cnodes ].include?(k) }
    nid = n['nid']
    pa = nodes[n['parent']]

    nids.delete(nid) if pa && pa['cnodes'].include?(nid)
  end
#p nids

  wrap_cancel_nodes(nids, { 'flavour' => fla })
    .each { |m| m['from'] = '9' }
      # since '9' isn't the parent of any node
end