Class: PuppetLint::Lexer::Token

Inherits:
Object
  • Object
show all
Defined in:
lib/puppet-lint/lexer/token.rb

Overview

Public: Stores a fragment of the manifest and the information about its location in the manifest.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(type, value, line, column) ⇒ Token

Public: Initialise a new Token object.

type - An upper case Symbol describing the type of Token. value - The String value of the Token. line - The Integer line number where the Token can be found in the

manifest.

column - The Integer number of characters from the start of the line to

the start of the Token.

Returns the instantiated Token.



47
48
49
50
51
52
53
54
55
56
# File 'lib/puppet-lint/lexer/token.rb', line 47

def initialize(type, value, line, column)
  @value = value
  @type = type
  @line = line
  @column = column
  @next_token = nil
  @prev_token = nil
  @next_code_token = nil
  @prev_code_token = nil
end

Instance Attribute Details

#columnObject (readonly)

Public: Returns the Integer column number of the line of the manifest text where the Token can be found.



21
22
23
# File 'lib/puppet-lint/lexer/token.rb', line 21

def column
  @column
end

#lineObject (readonly)

Public: Returns the Integer line number of the manifest text where the Token can be found.



17
18
19
# File 'lib/puppet-lint/lexer/token.rb', line 17

def line
  @line
end

#next_code_tokenObject

Public: Gets/sets the next code token (skips whitespace, comments, etc) in the manifest.



31
32
33
# File 'lib/puppet-lint/lexer/token.rb', line 31

def next_code_token
  @next_code_token
end

#next_tokenObject

Public: Gets/sets the next token in the manifest.



24
25
26
# File 'lib/puppet-lint/lexer/token.rb', line 24

def next_token
  @next_token
end

#prev_code_tokenObject

Public: Gets/sets the previous code tokne (skips whitespace, comments, etc) in the manifest.



35
36
37
# File 'lib/puppet-lint/lexer/token.rb', line 35

def prev_code_token
  @prev_code_token
end

#prev_tokenObject

Public: Gets/sets the previous token in the manifest.



27
28
29
# File 'lib/puppet-lint/lexer/token.rb', line 27

def prev_token
  @prev_token
end

#rawObject

Public: Returns the raw value of the Token.



13
14
15
# File 'lib/puppet-lint/lexer/token.rb', line 13

def raw
  @raw
end

#typeObject

Public: Returns the Symbol type of the Token.



7
8
9
# File 'lib/puppet-lint/lexer/token.rb', line 7

def type
  @type
end

#valueObject

Public: Returns the String value of the Token.



10
11
12
# File 'lib/puppet-lint/lexer/token.rb', line 10

def value
  @value
end

Instance Method Details

#find_token_of(direction, type, opts = {}) ⇒ Object

Internal: Search from this token to find the next token of a given type in a given direction.

direction - A Symbol direction to search (:next or :prev). type - A Symbol type of the token to find, or an Array of Symbols. opts - An optional Hash

:value       - A token value to search for in addition to type
:skip_blocks - A Boolean to specify whether { } blocks should be
               skipped over (defaults to true).

Returns a PuppetLint::Lexer::Token object if a matching token could be found, otherwise nil.



171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
# File 'lib/puppet-lint/lexer/token.rb', line 171

def find_token_of(direction, type, opts = {})
  return nil unless [:next, :prev].include?(direction)

  opts[:skip_blocks] ||= true
  to_find = Array[*type]

  token_iter = send("#{direction}_token".to_sym)
  until token_iter.nil?
    if to_find.include?(token_iter.type)
      return token_iter if opts[:value].nil? || token_iter.value == opts[:value]
    end

    opening_token = direction == :next ? 'L' : 'R'
    closing_token = direction == :next ? 'R' : 'L'

    if opts[:skip_blocks]
      case token_iter.type
      when "#{opening_token}BRACE".to_sym
        token_iter = token_iter.send("#{direction}_token_of".to_sym, ["#{closing_token}BRACE".to_sym, opts])
      when "#{opening_token}BRACK".to_sym
        token_iter = token_iter.send("#{direction}_token_of".to_sym, ["#{closing_token}BRACK".to_sym, opts])
      when "#{opening_token}PAREN".to_sym
        token_iter = token_iter.send("#{direction}_token_of".to_sym, ["#{closing_token}PAREN".to_sym, opts])
      end
    end
    token_iter = token_iter.send("#{direction}_token".to_sym)
  end
  nil
end

#inspectObject

Public: Produce a human friendly description of the Token when inspected.

Returns a String describing the Token.



62
63
64
# File 'lib/puppet-lint/lexer/token.rb', line 62

def inspect
  "<Token #{@type.inspect} (#{@value}) @#{@line}:#{@column}>"
end

#next_token_of(type, opts = {}) ⇒ Object

Public: Search from this token to find the next token of a given type.

type - A Symbol type of the token to find, or an Array of Symbols. opts - An optional Hash

:value       - A token value to search for in addition to type
:skip_blocks - A Boolean to specify whether { } blocks should be
               skipped over (defaults to true).

Returns a PuppetLint::Lexer::Token object if a matching token could be found, otherwise nil.



141
142
143
# File 'lib/puppet-lint/lexer/token.rb', line 141

def next_token_of(type, opts = {})
  find_token_of(:next, type, opts)
end

#prev_token_of(type, opts = {}) ⇒ Object

Public: Search from this token to find the previous token of a given type.

type - A Symbol type of the token to find, or an Array of Symbols. opts - An optional Hash

:value       - A token value to search for in addition to type
:skip_blocks - A Boolean to specify whether { } blocks should be
               skipped over (defaults to true).

Returns a PuppetLint::Lexer::Token object if a matching token could be found, otherwise nil.



155
156
157
# File 'lib/puppet-lint/lexer/token.rb', line 155

def prev_token_of(type, opts = {})
  find_token_of(:prev, type, opts)
end

#string_prefixObject



122
123
124
125
126
127
128
129
# File 'lib/puppet-lint/lexer/token.rb', line 122

def string_prefix
  no_enclose_tokens = Set.new([:UNENC_VARIABLE, :DQPRE, :DQMID, :HEREDOC_PRE, :HEREDOC_MID])
  if prev_token && no_enclose_tokens.include?(prev_token.type)
    ''
  else
    '}'
  end
end

#string_suffixObject



113
114
115
116
117
118
119
120
# File 'lib/puppet-lint/lexer/token.rb', line 113

def string_suffix
  no_enclose_tokens = Set.new([:UNENC_VARIABLE, :DQMID, :DQPOST, :HEREDOC_MID, :HEREDOC_POST])
  if next_token && no_enclose_tokens.include?(next_token.type)
    ''
  else
    '${'
  end
end

#to_manifestObject

Public: Produce a Puppet DSL representation of a Token.

Returns a Puppet DSL String.



69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
# File 'lib/puppet-lint/lexer/token.rb', line 69

def to_manifest
  case @type
  when :STRING
    "\"#{@value}\""
  when :SSTRING
    "'#{@value}'"
  when :DQPRE
    "\"#{@value}#{string_suffix}"
  when :DQPOST
    "#{string_prefix}#{@value}\""
  when :DQMID
    "#{string_prefix}#{@value}#{string_suffix}"
  when :VARIABLE
    enclose_token_types = Set[:DQPRE, :DQMID, :HEREDOC_PRE, :HEREDOC_MID].freeze
    if !@prev_code_token.nil? && enclose_token_types.include?(@prev_code_token.type)
      @raw.nil? ? @value : @raw
    else
      "$#{@value}"
    end
  when :UNENC_VARIABLE
    "$#{@value}"
  when :NEWLINE
    "\n"
  when :COMMENT
    "##{@value}"
  when :REGEX
    "/#{@value}/"
  when :MLCOMMENT
    @raw
  when :HEREDOC_OPEN
    "@(#{@value})"
  when :HEREDOC
    @raw
  when :HEREDOC_PRE
    "#{@value}#{string_suffix}"
  when :HEREDOC_POST
    "#{string_prefix}#{@raw}"
  when :HEREDOC_MID
    "#{string_prefix}#{@value}#{string_suffix}"
  else
    @value
  end
end