Sha256: e3fb384df6bdee544eef3984fb38483c1083c53f90f31c8630b683ce7c0aa488

Contents?: true

Size: 1.06 KB

Versions: 4

Compression:

Stored size: 1.06 KB

Contents

# frozen_string_literal: true

module RuboCop
  module Cop
    module Naming
      # This cop makes sure that certain binary operator methods have their
      # sole  parameter named `other`.
      #
      # @example
      #
      #   # bad
      #   def +(amount); end
      #
      #   # good
      #   def +(other); end
      class BinaryOperatorParameterName < Base
        MSG = 'When defining the `%<opr>s` operator, ' \
              'name its argument `other`.'

        OP_LIKE_METHODS = %i[eql? equal?].freeze
        EXCLUDED = %i[+@ -@ [] []= << === `].freeze

        def_node_matcher :op_method_candidate?, <<~PATTERN
          (def [#op_method? $_] (args $(arg [!:other !:_other])) _)
        PATTERN

        def on_def(node)
          op_method_candidate?(node) do |name, arg|
            add_offense(arg, message: format(MSG, opr: name))
          end
        end

        private

        def op_method?(name)
          return false if EXCLUDED.include?(name)

          !/\A\w/.match?(name) || OP_LIKE_METHODS.include?(name)
        end
      end
    end
  end
end

Version data entries

4 entries across 4 versions & 2 rubygems

Version Path
grape-extra_validators-2.0.0 vendor/bundle/ruby/2.6.0/gems/rubocop-0.90.0/lib/rubocop/cop/naming/binary_operator_parameter_name.rb
rubocop-0.90.0 lib/rubocop/cop/naming/binary_operator_parameter_name.rb
rubocop-0.89.1 lib/rubocop/cop/naming/binary_operator_parameter_name.rb
rubocop-0.89.0 lib/rubocop/cop/naming/binary_operator_parameter_name.rb