Class: Rouge::Lexers::Gherkin
- Inherits:
-
RegexLexer
- Object
- Rouge::Lexer
- RegexLexer
- Rouge::Lexers::Gherkin
- Defined in:
- lib/rouge/lexers/gherkin.rb
Constant Summary
Constants inherited from RegexLexer
Class Method Summary collapse
- .analyze_text(text) ⇒ Object
-
.keywords ⇒ Object
self-modifying method that loads the keywords file.
- .step_regex ⇒ Object
Methods inherited from RegexLexer
#delegate, get_state, #get_state, #group, #in_state?, #pop!, #push, #reset!, #reset_stack, #run_callback, #run_rule, #stack, start, start_procs, #state, state, #state?, states, #step, #stream_tokens, #token
Methods inherited from Rouge::Lexer
aliases, all, assert_utf8!, #debug, default_options, demo, demo_file, desc, filenames, find, find_fancy, guess, guess_by_filename, guess_by_mimetype, guess_by_source, guesses, #initialize, lex, #lex, mimetypes, #option, #options, #reset!, #stream_tokens, tag, #tag
Constructor Details
This class inherits a constructor from Rouge::Lexer
Class Method Details
.analyze_text(text) ⇒ Object
12 13 14 |
# File 'lib/rouge/lexers/gherkin.rb', line 12 def self.analyze_text(text) return 1 if text.shebang? 'cucumber' end |
.keywords ⇒ Object
self-modifying method that loads the keywords file
17 18 19 20 |
# File 'lib/rouge/lexers/gherkin.rb', line 17 def self.keywords load Pathname.new(__FILE__).dirname.join('gherkin/keywords.rb') keywords end |
.step_regex ⇒ Object
22 23 24 25 26 27 28 29 30 31 32 33 34 |
# File 'lib/rouge/lexers/gherkin.rb', line 22 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 |