Module: RuboCop::Cop::StringHelp

Included in:
StringLiteralsHelp, RuboCop::Cop::Style::CharacterLiteral
Defined in:
lib/rubocop/cop/mixin/string_help.rb

Overview

Classes that include this module just implement functions to determine what is an offense and how to do auto-correction. They get help with adding offenses for the faulty string nodes, and with filtering out nodes.

Instance Method Summary collapse

Instance Method Details

#inside_interpolation?(node) ⇒ Boolean

Returns:

  • (Boolean)


28
29
30
31
# File 'lib/rubocop/cop/mixin/string_help.rb', line 28

def inside_interpolation?(node)
  # A :begin node inside a :dstr node is an interpolation.
  node.ancestors.drop_while { |a| !a.begin_type? }.any?(&:dstr_type?)
end

#on_regexp(node) ⇒ Object



24
25
26
# File 'lib/rubocop/cop/mixin/string_help.rb', line 24

def on_regexp(node)
  ignore_node(node)
end

#on_str(node) ⇒ Object



11
12
13
14
15
16
17
18
19
20
21
22
# File 'lib/rubocop/cop/mixin/string_help.rb', line 11

def on_str(node)
  # Constants like __FILE__ are handled as strings,
  # but don't respond to begin.
  return unless node.loc.respond_to?(:begin) && node.loc.begin
  return if part_of_ignored_node?(node)

  if offense?(node)
    add_offense(node, :expression) { opposite_style_detected }
  else
    correct_style_detected
  end
end