Class: EnumStateMachine::PathCollection

Inherits:
Array
  • Object
show all
Includes:
Assertions
Defined in:
lib/enum_state_machine/path_collection.rb

Overview

Represents a collection of paths that are generated based on a set of requirements regarding what states to start and end on

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods included from Assertions

#assert_exclusive_keys, #assert_valid_keys

Constructor Details

#initialize(object, machine, options = {}) ⇒ PathCollection

Creates a new collection of paths with the given requirements.

Configuration options:

  • :from - The initial state to start from

  • :to - The target end state

  • :deep - Whether to enable deep searches for the target state.

  • :guard - Whether to guard transitions with the if/unless conditionals defined for each one



29
30
31
32
33
34
35
36
37
38
39
40
41
# File 'lib/enum_state_machine/path_collection.rb', line 29

def initialize(object, machine, options = {})
  options = {:deep => false, :from => machine.states.match!(object).name}.merge(options)
  assert_valid_keys(options, :from, :to, :deep, :guard)
  
  @object = object
  @machine = machine
  @from_name = machine.states.fetch(options[:from]).name
  @to_name = options[:to] && machine.states.fetch(options[:to]).name
  @guard = options[:guard]
  @deep = options[:deep]
  
  initial_paths.each {|path| walk(path)}
end

Instance Attribute Details

#from_nameObject (readonly)

The initial state to start each path from



16
17
18
# File 'lib/enum_state_machine/path_collection.rb', line 16

def from_name
  @from_name
end

#machineObject (readonly)

The state machine these path are walking



13
14
15
# File 'lib/enum_state_machine/path_collection.rb', line 13

def machine
  @machine
end

#objectObject (readonly)

The object whose state machine is being walked



10
11
12
# File 'lib/enum_state_machine/path_collection.rb', line 10

def object
  @object
end

#to_nameObject (readonly)

The target state for each path



19
20
21
# File 'lib/enum_state_machine/path_collection.rb', line 19

def to_name
  @to_name
end

Instance Method Details

#eventsObject

Lists all of the events that can be fired through the paths in this collection.

For example,

paths.events  # => [:park, :ignite, :shift_up, ...]


69
70
71
# File 'lib/enum_state_machine/path_collection.rb', line 69

def events
  map {|path| path.events}.flatten.uniq
end

#from_statesObject

Lists all of the states that can be transitioned from through the paths in this collection.

For example,

paths.from_states # => [:parked, :idling, :first_gear, ...]


49
50
51
# File 'lib/enum_state_machine/path_collection.rb', line 49

def from_states
  map {|path| path.from_states}.flatten.uniq
end

#to_statesObject

Lists all of the states that can be transitioned to through the paths in this collection.

For example,

paths.to_states # => [:idling, :first_gear, :second_gear, ...]


59
60
61
# File 'lib/enum_state_machine/path_collection.rb', line 59

def to_states
  map {|path| path.to_states}.flatten.uniq
end