class Cucumber::Ast::StepInvocation

:nodoc:

def accept(visitor)

def accept(visitor)
  return if Cucumber.wants_to_quit
  invoke(visitor.runtime, visitor.configuration)
  visit_step_result(visitor)
end

def actual_keyword

def actual_keyword
  repeat_keywords = rubify([language.keywords('but'), language.keywords('and')]).flatten.uniq.reject{|kw| kw == '* '}
  if repeat_keywords.index(@step.keyword) && previous
    previous.actual_keyword
  else
    keyword == '* ' ? language.code_keywords.first : keyword
  end
end

def background?

def background?
  @background
end

def backtrace_line

def backtrace_line
  @step.backtrace_line
end

def dom_id

def dom_id
  @step.dom_id
end

def failed(configuration, e, clear_backtrace)

def failed(configuration, e, clear_backtrace)
  e.set_backtrace([]) if e.backtrace.nil? || clear_backtrace
  e.backtrace << @step.backtrace_line unless @step.backtrace_line.nil?
  e = filter_backtrace(e)
  @exception = e
  if(configuration.strict? || !(Undefined === e) || e.nested?)
    @reported_exception = e
  else
    @reported_exception = nil
  end
end

def file_colon_line

def file_colon_line
  @step.file_colon_line
end

def filter_backtrace(e)

This is to work around double ":in " segments in JRuby backtraces. JRuby bug?
def filter_backtrace(e)
  return e if Cucumber.use_full_backtrace
  e.backtrace.each{|line| line.gsub!(PWD_PATTERN, "./")}
  filtered = (e.backtrace || []).reject do |line|
    BACKTRACE_FILTER_PATTERNS.detect { |p| line =~ p }
  end
  if ENV['CUCUMBER_TRUNCATE_OUTPUT']
    # Strip off file locations
    filtered = filtered.map do |line|
      line =~ /(.*):in `/ ? $1 : line
    end
  end
  e.set_backtrace(filtered)
  e
end

def find_step_match!(runtime, configuration)

def find_step_match!(runtime, configuration)
  return if @step_match
  begin
    @step_match = runtime.step_match(@name)
  rescue Undefined => e
    failed(configuration, e, true)
    status!(:undefined)
    @step_match = NoStepMatch.new(@step, @name)
  rescue Ambiguous => e
    failed(configuration, e, false)
    status!(:failed)
    @step_match = NoStepMatch.new(@step, @name)
  end
  runtime.step_visited(self)
end

def gherkin_statement

def gherkin_statement
  @step.gherkin_statement
end

def initialize(step, name, multiline_arg, matched_cells)

def initialize(step, name, multiline_arg, matched_cells)
  @step, @name, @multiline_arg, @matched_cells = step, name, multiline_arg, matched_cells
  status!(:skipped)
  @skip_invoke = @exception = @step_match = @different_table = @reported_exception = @background = nil
end

def invoke(runtime, configuration)

def invoke(runtime, configuration)
  find_step_match!(runtime, configuration)
  unless @skip_invoke || configuration.dry_run? || @exception || @step_collection.exception
    @skip_invoke = true
    begin
      @step_match.invoke(@multiline_arg)
      runtime.after_step
      status!(:passed)
    rescue Pending => e
      failed(configuration, e, false)
      status!(:pending)
    rescue Undefined => e
      failed(configuration, e, false)
      status!(:undefined)
    rescue Cucumber::Ast::Table::Different => e
      @different_table = e.table
      failed(configuration, e, false)
      status!(:failed)
    rescue Exception => e
      failed(configuration, e, false)
      status!(:failed)
    end
  end
end

def keyword

def keyword
  @step.keyword
end

def language

def language
  @step.language || raise("Language is required on #{@step}")
end

def multiline_arg

def multiline_arg
  @step.multiline_arg
end

def previous

def previous
  @step_collection.previous_step(self)
end

def skip_invoke!

def skip_invoke!
  @skip_invoke = true
end

def source_indent

def source_indent
  @step.feature_element.source_indent(text_length)
end

def status!(status)

def status!(status)
  @status = status
  @matched_cells.each do |cell|
    cell.status = status
  end
end

def text_length

def text_length
  @step.text_length(@name)
end

def to_sexp

def to_sexp
  [:step_invocation, @step.line, @step.keyword, @name, (@multiline_arg.nil? ? nil : @multiline_arg.to_sexp)].compact
end

def visit_step_result(visitor)

def visit_step_result(visitor)
  visitor.visit_step_result(
    keyword,
    @step_match,
    (@different_table || @multiline_arg),
    @status,
    @reported_exception,
    source_indent,
    @background,
    file_colon_line
  )
end

def worst_status(statuses)

def worst_status(statuses)
  SEVERITY[statuses.map{|status| SEVERITY.index(status)}.max]
end