class Cucumber::StepMother

This is the meaty part of Cucumber that ties everything together.

def after(scenario) #:nodoc:

:nodoc:
def after(scenario) #:nodoc:
  @current_scenario = nil
  return if options[:dry_run]
  @programming_languages.each do |programming_language|
    programming_language.after(scenario)
  end
end

def after_configuration(configuration) #:nodoc

:nodoc
def after_configuration(configuration) #:nodoc
  @programming_languages.each do |programming_language|
    programming_language.after_configuration(configuration)
  end
end  

def after_step #:nodoc:

:nodoc:
def after_step #:nodoc:
  return if options[:dry_run]
  @programming_languages.each do |programming_language|
    programming_language.execute_after_step(@current_scenario)
  end
end

def announce(msg) #:nodoc:

:nodoc:
def announce(msg) #:nodoc:
  @visitor.announce(msg)
end

def before(scenario) #:nodoc:

:nodoc:
def before(scenario) #:nodoc:
  return if options[:dry_run] || @current_scenario
  @current_scenario = scenario
  @programming_languages.each do |programming_language|
    programming_language.before(scenario)
  end
end

def before_and_after(scenario, skip_hooks=false) #:nodoc:

:nodoc:
def before_and_after(scenario, skip_hooks=false) #:nodoc:
  before(scenario) unless skip_hooks
  yield scenario
  after(scenario) unless skip_hooks
  scenario_visited(scenario)
end

def best_matches(step_name, step_matches) #:nodoc:

:nodoc:
def best_matches(step_name, step_matches) #:nodoc:
  no_groups      = step_matches.select {|step_match| step_match.args.length == 0}
  max_arg_length = step_matches.map {|step_match| step_match.args.length }.max
  top_groups     = step_matches.select {|step_match| step_match.args.length == max_arg_length }
  if no_groups.any?
    longest_regexp_length = no_groups.map {|step_match| step_match.text_length }.max
    no_groups.select {|step_match| step_match.text_length == longest_regexp_length }
  elsif top_groups.any?
    shortest_capture_length = top_groups.map {|step_match| step_match.args.inject(0) {|sum, c| sum + c.length } }.min
    top_groups.select {|step_match| step_match.args.inject(0) {|sum, c| sum + c.length } == shortest_capture_length }
  else
    top_groups
  end
end

def clear! #:nodoc:

:nodoc:
def clear! #:nodoc:
  step_definitions.clear
  hooks.clear
  steps.clear
  scenarios.clear
end

def initialize

def initialize
  @unsupported_programming_languages = []
  @programming_languages = []
  @language_map = {}
  load_natural_language('en')
end

def load_code_file(step_def_file)

def load_code_file(step_def_file)
  if programming_language = programming_language_for(step_def_file)
    log.debug("  * #{step_def_file}\n")
    step_definitions = programming_language.step_definitions_for(step_def_file)
    register_step_definitions(step_definitions)
  else
    log.debug("  * #{step_def_file} [NOT SUPPORTED]\n")
  end
end

def load_code_files(step_def_files)

def load_code_files(step_def_files)
  log.debug("Code:\n")
  step_def_files.each do |step_def_file|
    load_code_file(step_def_file)
  end
  log.debug("\n")
end

def load_natural_language(lang)


languages (if they support aliasing). See #load_programming_language
Step Definition keywords for all of the registered programming
Loads a natural language. This has the effect of aliasing
def load_natural_language(lang)
  Parser::NaturalLanguage.get(self, lang)
end

def load_plain_text_features(feature_files)

def load_plain_text_features(feature_files)
  features = Ast::Features.new
  log.debug("Features:\n")
  feature_files.each do |f|
    feature_file = FeatureFile.new(f)
    feature = feature_file.parse(self, options)
    if feature
      features.add_feature(feature)
      log.debug("  * #{f}\n")
    end
  end
  log.debug("\n")
  features
end

def load_programming_language(ext)


twice will return the same instance.
Instances are cached, so calling with the same argument
Loads and registers programming language implementation.
def load_programming_language(ext)
  return @language_map[ext] if @language_map[ext]
  programming_language_class = constantize("Cucumber::#{ext.capitalize}Support::#{ext.capitalize}Language")
  programming_language = programming_language_class.new(self)
  programming_language.alias_adverbs(@adverbs || [])
  @programming_languages << programming_language
  @language_map[ext] = programming_language
  programming_language
end

def log

def log
  @log ||= Logger.new(STDOUT)
end

def max_step_definition_length #:nodoc:

:nodoc:
def max_step_definition_length #:nodoc:
  @max_step_definition_length ||= step_definitions.map{|step_definition| step_definition.text_length}.max
end

def options

Returns the options passed on the command line.
def options
  @options ||= {}
end

def programming_language_for(step_def_file) #:nodoc:

:nodoc:
def programming_language_for(step_def_file) #:nodoc:
  if ext = File.extname(step_def_file)[1..-1]
    return nil if @unsupported_programming_languages.index(ext)
    begin
      load_programming_language(ext)
    rescue LoadError
      @unsupported_programming_languages << ext
      nil
    end
  else
    nil
  end
end

def register_adverbs(adverbs) #:nodoc:

:nodoc:
def register_adverbs(adverbs) #:nodoc:
  @adverbs ||= []
  @adverbs += adverbs
  @adverbs.uniq!
  @programming_languages.each do |programming_language|
    programming_language.alias_adverbs(@adverbs)
  end
end

def register_step_definition(step_definition)

contract (API).
or any other kind of object that implements the StepDefintion
Registers a StepDefinition. This can be a Ruby StepDefintion,
def register_step_definition(step_definition)
  step_definitions.each do |already|
    raise Redundant.new(already, step_definition) if already.same_regexp?(step_definition.regexp)
  end
  step_definitions << step_definition
  step_definition
end

def register_step_definitions(step_definitions)

def register_step_definitions(step_definitions)
  step_definitions.each{|step_definition| register_step_definition(step_definition)}
end

def scenario_visited(scenario) #:nodoc:

:nodoc:
def scenario_visited(scenario) #:nodoc:
  scenarios << scenario unless scenarios.index(scenario)
end

def scenarios(status = nil) #:nodoc:

:nodoc:
def scenarios(status = nil) #:nodoc:
  @scenarios ||= []
  if(status)
    @scenarios.select{|scenario| scenario.status == status}
  else
    @scenarios
  end
end

def snippet_text(step_keyword, step_name, multiline_arg_class) #:nodoc:

:nodoc:
def snippet_text(step_keyword, step_name, multiline_arg_class) #:nodoc:
  @programming_languages.map do |programming_language|
    programming_language.snippet_text(step_keyword, step_name, multiline_arg_class)
  end.join("\n")
end

def step_definitions #:nodoc:

:nodoc:
def step_definitions #:nodoc:
  @step_definitions ||= []
end

def step_match(step_name, formatted_step_name=nil) #:nodoc:

:nodoc:
def step_match(step_name, formatted_step_name=nil) #:nodoc:
  matches = step_definitions.map { |d| d.step_match(step_name, formatted_step_name) }.compact
  raise Undefined.new(step_name) if matches.empty?
  matches = best_matches(step_name, matches) if matches.size > 1 && options[:guess]
  raise Ambiguous.new(step_name, matches, options[:guess]) if matches.size > 1
  matches[0]
end

def step_visited(step) #:nodoc:

:nodoc:
def step_visited(step) #:nodoc:
  steps << step unless steps.index(step)
end

def steps(status = nil) #:nodoc:

:nodoc:
def steps(status = nil) #:nodoc:
  @steps ||= []
  if(status)
    @steps.select{|step| step.status == status}
  else
    @steps
  end
end