Class: Rouge::Lexers::YAML

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

Direct Known Subclasses

Digdag

Constant Summary collapse

SPECIAL_VALUES =
Regexp.union(%w(true false null))

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

Instance 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


13
14
15
16
# File 'lib/rouge/lexers/yaml.rb', line 13

def self.analyze_text(text)
  # look for the %YAML directive
  return 1 if text =~ /\A\s*%YAML/m
end

Instance Method Details

#continue_indent(match) ⇒ Object


61
62
63
64
# File 'lib/rouge/lexers/yaml.rb', line 61

def continue_indent(match)
  puts "    yaml: continue_indent" if @debug
  @next_indent += match.size
end

#dedent?(level) ⇒ Boolean

Returns:

  • (Boolean)

36
37
38
# File 'lib/rouge/lexers/yaml.rb', line 36

def dedent?(level)
  level < self.indent
end

#indentObject


31
32
33
34
# File 'lib/rouge/lexers/yaml.rb', line 31

def indent
  raise 'empty indent stack!' if @indent_stack.empty?
  @indent_stack.last
end

#indent?(level) ⇒ Boolean

Returns:

  • (Boolean)

40
41
42
# File 'lib/rouge/lexers/yaml.rb', line 40

def indent?(level)
  level > self.indent
end

#reset_indentObject

reset the indentation levels


24
25
26
27
28
29
# File 'lib/rouge/lexers/yaml.rb', line 24

def reset_indent
  puts "    yaml: reset_indent" if @debug
  @indent_stack = [0]
  @next_indent = 0
  @block_scalar_indent = nil
end

#save_indent(match) ⇒ Object

Save a possible indentation level


45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
# File 'lib/rouge/lexers/yaml.rb', line 45

def save_indent(match)
  @next_indent = match.size
  puts "    yaml: indent: #{self.indent}/#@next_indent" if @debug
  puts "    yaml: popping indent stack - before: #@indent_stack" if @debug
  if dedent?(@next_indent)
    @indent_stack.pop while dedent?(@next_indent)
    puts "    yaml: popping indent stack - after: #@indent_stack" if @debug
    puts "    yaml: indent: #{self.indent}/#@next_indent" if @debug

    # dedenting to a state not previously indented to is an error
    [match[0...self.indent], match[self.indent..-1]]
  else
    [match, '']
  end
end

#set_indent(match, opts = {}) ⇒ Object


66
67
68
69
70
71
72
73
# File 'lib/rouge/lexers/yaml.rb', line 66

def set_indent(match, opts={})
  if indent < @next_indent
    puts "    yaml: indenting #{indent}/#{@next_indent}" if @debug
    @indent_stack << @next_indent
  end

  @next_indent += match.size unless opts[:implicit]
end