aasm/lib/aasm/state_machine.rb

54 lines
1.5 KiB
Ruby

module AASM
class StateMachine
# the following four methods provide the storage of all state machines
attr_accessor :states, :events, :initial_state, :config, :name, :global_callbacks
def initialize(name)
@initial_state = nil
@states = []
@events = {}
@global_callbacks = {}
@config = AASM::Configuration.new
@name = name
end
# called internally by Ruby 1.9 after clone()
def initialize_copy(orig)
super
@states = orig.states.collect { |state| state.clone }
@events = {}
orig.events.each_pair { |name, event| @events[name] = event.clone }
@global_callbacks = @global_callbacks.dup
end
def add_state(state_name, klass, options)
set_initial_state(state_name, options)
# allow reloading, extending or redefining a state
@states.delete(state_name) if @states.include?(state_name)
@states << AASM::Core::State.new(state_name, klass, self, options)
end
def add_event(name, options, &block)
@events[name] = AASM::Core::Event.new(name, self, options, &block)
end
def add_global_callbacks(name, *callbacks, &block)
@global_callbacks[name] ||= []
callbacks.each do |callback|
@global_callbacks[name] << callback unless @global_callbacks[name].include? callback
end
@global_callbacks[name] << block if block
end
private
def set_initial_state(name, options)
@initial_state = name if options[:initial] || !initial_state
end
end # StateMachine
end # AASM