Sha256: 9e93e8fb518e8c11f1984e6f6ce19f0e2368c6bd124b088643e5b61994731d82
Contents?: true
Size: 1.1 KB
Versions: 4
Compression:
Stored size: 1.1 KB
Contents
# frozen_string_literal: true module RuboCop module Cop module Lint # This cop checks if each_with_object is called with an immutable # argument. Since the argument is the object that the given block shall # make calls on to build something based on the enumerable that # each_with_object iterates over, an immutable argument makes no sense. # It's definitely a bug. # # @example # # # bad # # sum = numbers.each_with_object(0) { |e, a| a += e } # # @example # # # good # # num = 0 # sum = numbers.each_with_object(num) { |e, a| a += e } class EachWithObjectArgument < Base MSG = 'The argument to each_with_object cannot be immutable.' def_node_matcher :each_with_object?, <<~PATTERN ({send csend} _ :each_with_object $_) PATTERN def on_send(node) each_with_object?(node) do |arg| return unless arg.immutable_literal? add_offense(node) end end alias on_csend on_send end end end end
Version data entries
4 entries across 4 versions & 2 rubygems