lib/cucumber/ast/feature.rb
module Cucumber module Ast # Represents the root node of a parsed feature. class Feature #:nodoc: attr_accessor :file, :language attr_writer :features attr_reader :name def initialize(background, comment, tags, name, feature_elements) @background, @comment, @tags, @name, @feature_elements = background, comment, tags, name.strip, feature_elements background.feature = self if background @feature_elements.each do |feature_element| feature_element.feature = self end end def accept(visitor) return if Cucumber.wants_to_quit visitor.visit_comment(@comment) unless @comment.empty? visitor.visit_tags(@tags) visitor.visit_feature_name(@name) visitor.visit_background(@background) if @background @feature_elements.each do |feature_element| visitor.visit_feature_element(feature_element) end end def source_tag_names @tags.tag_names end def accept_hook?(hook) @tags.accept_hook?(hook) end def next_feature_element(feature_element, &proc) index = @feature_elements.index(feature_element) next_one = @feature_elements[index+1] proc.call(next_one) if next_one end def backtrace_line(step_name, line) "#{file_colon_line(line)}:in `#{step_name}'" end def file_colon_line(line) "#{@file}:#{line}" end def tag_count(tag) if @tags.respond_to?(:count) @tags.count(tag) # 1.9 else @tags.select{|t| t == tag}.length # 1.8 end end def feature_and_children_tag_count(tag) children_tag_count = @feature_elements.inject(0){|count, feature_element| count += feature_element.tag_count(tag)} children_tag_count + tag_count(tag) end def short_name first_line = name.split(/\n/)[0] if first_line =~ /#{language.keywords('feature', true)}:(.*)/ $1.strip else first_line end end def to_sexp sexp = [:feature, @file, @name] comment = @comment.to_sexp sexp += [comment] if comment tags = @tags.to_sexp sexp += tags if tags.any? sexp += [@background.to_sexp] if @background sexp += @feature_elements.map{|fe| fe.to_sexp} sexp end end end end