module Cucumber::LanguageSupport::LanguageMethods

def add_hook(phase, hook)

def add_hook(phase, hook)
  hooks[phase.to_sym] << hook
  hook
end

def add_transform(transform)

def add_transform(transform)
  transforms.unshift transform
  transform
end

def after(scenario)

def after(scenario)
  execute_after(scenario)
  end_scenario
end

def after_configuration(configuration)

def after_configuration(configuration)
  hooks[:after_configuration].each do |hook|
    hook.invoke('AfterConfiguration', configuration)
  end
end

def around(scenario)

def around(scenario)
  execute_around(scenario) do
    yield
  end
end

def available_step_definition(regexp_source, file_colon_line)

def available_step_definition(regexp_source, file_colon_line)
  available_step_definition_hash[StepDefinitionLight.new(regexp_source, file_colon_line)] = nil
end

def available_step_definition_hash

def available_step_definition_hash
  @available_step_definition_hash ||= {}
end

def before(scenario)

def before(scenario)
  begin_scenario(scenario)
  execute_before(scenario)
end

def clear_hooks

def clear_hooks
  @hooks = nil
end

def execute_after(scenario)

def execute_after(scenario)
  hooks_for(:after, scenario).reverse_each do |hook|
    invoke(hook, 'After', scenario, true)
  end
end

def execute_after_step(scenario)

def execute_after_step(scenario)
  hooks_for(:after_step, scenario).each do |hook|
    invoke(hook, 'AfterStep', scenario)
  end
end

def execute_around(scenario, &block)

def execute_around(scenario, &block)
  hooks_for(:around, scenario).reverse.inject(block) do |blk, hook|
    proc do
      invoke(hook, 'Around', scenario, true) do
        blk.call(scenario)
      end
    end
  end.call
end

def execute_before(scenario)

def execute_before(scenario)
  hooks_for(:before, scenario).each do |hook|
    invoke(hook, 'Before', scenario, true)
  end
end

def execute_transforms(args)

def execute_transforms(args)
  args.map do |arg|
    matching_transform = transforms.detect {|transform| transform.match(arg) }
    matching_transform ? matching_transform.invoke(arg) : arg
  end
end

def hooks

def hooks
  @hooks ||= Hash.new{|h,k| h[k] = []}
end

def hooks_for(phase, scenario) #:nodoc:

:nodoc:
def hooks_for(phase, scenario) #:nodoc:
  hooks[phase.to_sym].select{|hook| scenario.accept_hook?(hook)}
end

def invoke(hook, location, scenario, exception_fails_scenario, &block)

def invoke(hook, location, scenario, exception_fails_scenario, &block)
  begin
    hook.invoke(location, scenario, &block)
  rescue Exception => exception
    if exception_fails_scenario
      scenario.fail!(exception)
    else
      raise
    end
  end
end

def invoked_step_definition(regexp_source, file_colon_line)

def invoked_step_definition(regexp_source, file_colon_line)
  invoked_step_definition_hash[StepDefinitionLight.new(regexp_source, file_colon_line)] = nil
end

def invoked_step_definition_hash

def invoked_step_definition_hash
  @invoked_step_definition_hash ||= {}
end

def transforms

def transforms
  @transforms ||= []
end

def unmatched_step_definitions

def unmatched_step_definitions
  available_step_definition_hash.keys - invoked_step_definition_hash.keys
end