Sha256: 25a434dde99d745802769391575ba911c4ccd176d58a4ff3be7ecd8137efbffd

Contents?: true

Size: 1.75 KB

Versions: 192

Compression:

Stored size: 1.75 KB

Contents

# frozen_string_literal: true

module RuboCop
  module Cop
    module Style
      # Checks for places where keyword arguments can be used instead of
      # boolean arguments when defining methods. `respond_to_missing?` method is allowed by default.
      # These are customizable with `AllowedMethods` option.
      #
      # @safety
      #   This cop is unsafe because changing a method signature will
      #   implicitly change behavior.
      #
      # @example
      #   # bad
      #   def some_method(bar = false)
      #     puts bar
      #   end
      #
      #   # bad - common hack before keyword args were introduced
      #   def some_method(options = {})
      #     bar = options.fetch(:bar, false)
      #     puts bar
      #   end
      #
      #   # good
      #   def some_method(bar: false)
      #     puts bar
      #   end
      #
      # @example AllowedMethods: ['some_method']
      #   # good
      #   def some_method(bar = false)
      #     puts bar
      #   end
      #
      class OptionalBooleanParameter < Base
        include AllowedMethods

        MSG = 'Prefer keyword arguments for arguments with a boolean default value; ' \
              'use `%<replacement>s` instead of `%<original>s`.'

        def on_def(node)
          return if allowed_method?(node.method_name)

          node.arguments.each do |arg|
            next unless arg.optarg_type?

            add_offense(arg, message: format_message(arg)) if arg.default_value.boolean_type?
          end
        end
        alias on_defs on_def

        private

        def format_message(argument)
          replacement = "#{argument.name}: #{argument.default_value.source}"

          format(MSG, original: argument.source, replacement: replacement)
        end
      end
    end
  end
end

Version data entries

192 entries across 185 versions & 18 rubygems

Version Path
rubocop-1.71.0 lib/rubocop/cop/style/optional_boolean_parameter.rb
rubocop-1.70.0 lib/rubocop/cop/style/optional_boolean_parameter.rb
minato_ruby_api_client-0.2.2 vendor/bundle/ruby/3.2.0/gems/rubocop-1.64.1/lib/rubocop/cop/style/optional_boolean_parameter.rb
rubocop-1.69.2 lib/rubocop/cop/style/optional_boolean_parameter.rb
rubocop-1.69.1 lib/rubocop/cop/style/optional_boolean_parameter.rb
rubocop-1.69.0 lib/rubocop/cop/style/optional_boolean_parameter.rb
rubocop-1.68.0 lib/rubocop/cop/style/optional_boolean_parameter.rb
rubocop-1.67.0 lib/rubocop/cop/style/optional_boolean_parameter.rb
rubocop-1.66.1 lib/rubocop/cop/style/optional_boolean_parameter.rb
rubocop-1.66.0 lib/rubocop/cop/style/optional_boolean_parameter.rb
rubocop-1.65.1 lib/rubocop/cop/style/optional_boolean_parameter.rb
blacklight-spotlight-3.6.0.beta8 vendor/bundle/ruby/3.2.0/gems/rubocop-1.64.1/lib/rubocop/cop/style/optional_boolean_parameter.rb
rubocop-1.65.0 lib/rubocop/cop/style/optional_boolean_parameter.rb
cm-admin-1.5.22 vendor/bundle/ruby/3.3.0/gems/rubocop-1.35.1/lib/rubocop/cop/style/optional_boolean_parameter.rb
cm-admin-1.5.21 vendor/bundle/ruby/3.3.0/gems/rubocop-1.35.1/lib/rubocop/cop/style/optional_boolean_parameter.rb
cm-admin-1.5.20 vendor/bundle/ruby/3.3.0/gems/rubocop-1.35.1/lib/rubocop/cop/style/optional_boolean_parameter.rb
katalyst-govuk-formbuilder-1.9.2 vendor/bundle/ruby/3.3.0/gems/rubocop-1.64.1/lib/rubocop/cop/style/optional_boolean_parameter.rb
rubocop-1.64.1 lib/rubocop/cop/style/optional_boolean_parameter.rb
rubocop-1.63.4 lib/rubocop/cop/style/optional_boolean_parameter.rb
rubocop-1.63.3 lib/rubocop/cop/style/optional_boolean_parameter.rb