Sha256: b1d959de1e974041f171d8aee36f328241cb4b8964cda8763fb141795b36af68

Contents?: true

Size: 1.7 KB

Versions: 3

Compression:

Stored size: 1.7 KB

Contents

require 'pp'

def type_indexes(type)
  type_indexes = []
  tokens.each_index do |token_idx|
    if tokens[token_idx].type == type
      depth = 0
      start = token_idx
      tokens[(token_idx + 1)..-1].each_index do |case_token_idx|
        idx = case_token_idx + token_idx + 1
        if tokens[idx].type == :LBRACE
          depth += 1
          if depth == 2
            type_indexes << {:start => start, :end => idx}
          end
        elsif tokens[idx].type == :RBRACE
          if depth == 2
            start = idx
          end
          depth -= 1
          if depth == 0
            type_indexes << {:start => start, :end => idx}
            break
          end
        end
      end
    end
  end
  type_indexes
end

def notify_tokens(type, sep_type, message)
  type_indexes(type).each do |kase|
    type_tokens = tokens[kase[:start]..kase[:end]]
    type_tokens.index do |r|
      if r.type == sep_type
        s = r.prev_token
        while (s.type != :NEWLINE) && (s.type != :LBRACE)
          if s.type == :NAME || (s.type == :CLASSREF && !s.value.include?('::'))
            notify :warning, {
              :message => message,
              :line    => s.line,
              :column  => s.column,
              :token   => s,
            }
          end
          s = s.prev_token
        end
      end
    end
  end
end

PuppetLint.new_check(:unquoted_string_in_case) do
  def check
    notify_tokens(:CASE, :COLON, 'unquoted string in case')
  end

  def fix(problem)
    problem[:token].type = :SSTRING
  end
end

PuppetLint.new_check(:unquoted_string_in_selector) do
  def check
    notify_tokens(:QMARK, :FARROW, 'unquoted string in selector')
  end

  def fix(problem)
    problem[:token].type = :SSTRING
  end
end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
puppet-lint-unquoted_string-check-2.2.0 lib/puppet-lint/plugins/check_unquoted_string_in_case.rb
puppet-lint-unquoted_string-check-2.1.0 lib/puppet-lint/plugins/check_unquoted_string_in_case.rb
puppet-lint-unquoted_string-check-2.0.0 lib/puppet-lint/plugins/check_unquoted_string_in_case.rb