class AASM::Core::Transition

Experimental RBS support (using type sampling data from the type_fusion project).

# sig/aasm/core/transition.rbs

class AASM::Core::Transition
  def initialize: (AASM::Core::Event event, Hash opts, ) -> void
end

def ==(obj)

def ==(obj)
  @from == obj.from && @to == obj.to
end

def _fire_callbacks(code, record, args)

def _fire_callbacks(code, record, args)
  Invoker.new(code, record, args).invoke
end

def allowed?(obj, *args)

def allowed?(obj, *args)
  invoke_callbacks_compatible_with_guard(@guards, obj, args, :guard => true) &&
  invoke_callbacks_compatible_with_guard(@unless, obj, args, :unless => true)
end

def execute(obj, *args)

def execute(obj, *args)
  invoke_callbacks_compatible_with_guard(event.state_machine.global_callbacks[:after_all_transitions], obj, args)
  invoke_callbacks_compatible_with_guard(@after, obj, args)
end

def from?(value)

def from?(value)
  @from == value
end

def initialize(event, opts, &block)

Experimental RBS support (using type sampling data from the type_fusion project).

def initialize: (AASM::Core::Event event, from | Symbol | to | Symbol opts, ) -> void

This signature was generated using 1 sample from 1 application.

def initialize(event, opts, &block)
  add_options_from_dsl(opts, [:on_transition, :guard, :after, :success], &block) if block
  @event = event
  @from = opts[:from]
  @to = opts[:to]
  @guards = Array(opts[:guards]) + Array(opts[:guard]) + Array(opts[:if])
  @unless = Array(opts[:unless]) #TODO: This could use a better name
  @failures = []
  if opts[:on_transition]
    warn '[DEPRECATION] :on_transition is deprecated, use :after instead'
    opts[:after] = Array(opts[:after]) + Array(opts[:on_transition])
  end
  @after = Array(opts[:after])
  @after = @after[0] if @after.size == 1
  @success = Array(opts[:success])
  @success = @success[0] if @success.size == 1
  @opts = opts
end

def initialize_copy(orig)

called internally by Ruby 1.9 after clone()
def initialize_copy(orig)
  super
  @guards = @guards.dup
  @unless = @unless.dup
  @opts   = {}
  orig.opts.each_pair { |name, setting| @opts[name] = setting.is_a?(Hash) || setting.is_a?(Array) ? setting.dup : setting }
end

def invoke_callbacks_compatible_with_guard(code, record, args, options={})

def invoke_callbacks_compatible_with_guard(code, record, args, options={})
  if record.respond_to?(:aasm)
    record.aasm(event.state_machine.name).from_state = @from if record.aasm(event.state_machine.name).respond_to?(:from_state=)
    record.aasm(event.state_machine.name).to_state = @to if record.aasm(event.state_machine.name).respond_to?(:to_state=)
  end
  Invoker.new(code, record, args)
         .with_options(options)
         .with_failures(failures)
         .invoke
end

def invoke_success_callbacks(obj, *args)

def invoke_success_callbacks(obj, *args)
  _fire_callbacks(@success, obj, args)
end