Class: Rouge::Lexers::Gherkin

Inherits:
RegexLexer show all
Defined in:
lib/rouge/lexers/gherkin.rb

Constant Summary

Constants inherited from RegexLexer

RegexLexer::MAX_NULL_SCANS

Constants included from Token::Tokens

Token::Tokens::Num, Token::Tokens::Str

Instance Attribute Summary

Attributes inherited from Rouge::Lexer

#options

Class Method Summary collapse

Methods inherited from RegexLexer

append, #delegate, get_state, #get_state, #goto, #group, #groups, #in_state?, #pop!, prepend, #push, #recurse, replace_state, #reset!, #reset_stack, #stack, start, start_procs, state, #state, #state?, state_definitions, states, #step, #stream_tokens, #token

Methods inherited from Rouge::Lexer

aliases, all, #as_bool, #as_lexer, #as_list, #as_string, #as_token, assert_utf8!, #bool_option, debug_enabled?, demo, demo_file, desc, disable_debug!, enable_debug!, filenames, find, find_fancy, guess, guess_by_filename, guess_by_mimetype, guess_by_source, guesses, #hash_option, #initialize, lex, #lex, #lexer_option, #list_option, mimetypes, option, option_docs, #reset!, #stream_tokens, #string_option, #tag, tag, title, #token_option

Methods included from Token::Tokens

token

Constructor Details

This class inherits a constructor from Rouge::Lexer

Class Method Details

.analyze_text(text) ⇒ Object


15
16
17
# File 'lib/rouge/lexers/gherkin.rb', line 15

def self.analyze_text(text)
  return 1 if text.shebang? 'cucumber'
end

.keywordsObject

self-modifying method that loads the keywords file


20
21
22
23
# File 'lib/rouge/lexers/gherkin.rb', line 20

def self.keywords
  load Pathname.new(__FILE__).dirname.join('gherkin/keywords.rb')
  keywords
end

.step_regexObject


25
26
27
28
29
30
31
32
33
34
35
36
37
# File 'lib/rouge/lexers/gherkin.rb', line 25

def self.step_regex
  # in Gherkin's config, keywords that end in < don't
  # need word boundaries at the ends - all others do.
  @step_regex ||= Regexp.new(
    keywords[:step].map do |w|
      if w.end_with? '<'
        Regexp.escape(w.chop)
      else
        "#{Regexp.escape(w)}\\b"
      end
    end.join('|')
  )
end