Sha256: 7385341b1fe36508f83af21fcb43575dada503ce78155bf9ddec237ca954b163
Contents?: true
Size: 1.88 KB
Versions: 1
Compression:
Stored size: 1.88 KB
Contents
module RuboCop module Cop module Ezcater # Use `dig` for deeply nested access. # # @example # # # good # my_hash.dig('foo', 'bar') # my_array.dig(0, 1) # # # bad # my_hash['foo']['bar'] # my_hash['foo'] && my_hash['foo']['bar'] # my_array[0][1] class StyleDig < Cop extend TargetRubyVersion minimum_target_ruby_version 2.3 MSG = "Use `dig` for nested access.".freeze def_node_matcher :nested_access_match, <<-PATTERN (send (send (send _receiver !:[]) :[] _) :[] _) PATTERN def on_send(node) return unless nested_access_match(node) && !assignment?(node) match_node = node # walk to outermost access node match_node = match_node.parent while access_node?(match_node.parent) add_offense(match_node, :expression, MSG) end def autocorrect(node) access_node = node source_args = [access_node.first_argument.source] while access_node?(access_node.children.first) access_node = access_node.children.first source_args << access_node.first_argument.source end root_node = access_node.children.first lambda do |corrector| range = Parser::Source::Range.new(node.source_range.source_buffer, root_node.source_range.end_pos, node.source_range.end_pos) corrector.replace(range, ".dig(#{source_args.reverse.join(', ')})") end end private def assignment?(node) node.parent&.assignment? && (node.parent.children.first == node) end def access_node?(node) node&.send_type? && node.method_name == :[] end end end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
ezcater_rubocop-0.50.0 | lib/rubocop/cop/ezcater/style_dig.rb |