Sha256: e8bfb0623dc0fe47e3db5d144b55e092819741423d14e34f3e7f0ed0b10c4230

Contents?: true

Size: 1.82 KB

Versions: 15

Compression:

Stored size: 1.82 KB

Contents

# frozen_string_literal: true

module RuboCop
  module Cop
    module Lint
      # This cop checks for the use of local variable names from an outer scope
      # in block arguments or block-local variables. This mirrors the warning
      # given by `ruby -cw` prior to Ruby 2.6:
      # "shadowing outer local variable - foo".
      #
      # NOTE: Shadowing of variables in block passed to `Ractor.new` is allowed
      # because `Ractor` should not access outer variables.
      # eg. following style is encouraged:
      #
      #   worker_id, pipe = env
      #   Ractor.new(worker_id, pipe) do |worker_id, pipe|
      #   end
      #
      # @example
      #
      #   # bad
      #
      #   def some_method
      #     foo = 1
      #
      #     2.times do |foo| # shadowing outer `foo`
      #       do_something(foo)
      #     end
      #   end
      #
      # @example
      #
      #   # good
      #
      #   def some_method
      #     foo = 1
      #
      #     2.times do |bar|
      #       do_something(bar)
      #     end
      #   end
      class ShadowingOuterLocalVariable < Base
        MSG = 'Shadowing outer local variable - `%<variable>s`.'

        # @!method ractor_block?(node)
        def_node_matcher :ractor_block?, <<~PATTERN
          (block (send (const nil? :Ractor) :new ...) ...)
        PATTERN

        def self.joining_forces
          VariableForce
        end

        def before_declaring_variable(variable, variable_table)
          return if variable.should_be_unused?
          return if ractor_block?(variable.scope.node)

          outer_local_variable = variable_table.find_variable(variable.name)
          return unless outer_local_variable

          message = format(MSG, variable: variable.name)
          add_offense(variable.declaration_node, message: message)
        end
      end
    end
  end
end

Version data entries

15 entries across 15 versions & 4 rubygems

Version Path
scrapbook-0.3.2 vendor/ruby/2.7.0/gems/rubocop-1.26.0/lib/rubocop/cop/lint/shadowing_outer_local_variable.rb
scrapbook-0.3.1 vendor/ruby/2.7.0/gems/rubocop-1.26.0/lib/rubocop/cop/lint/shadowing_outer_local_variable.rb
rubocop-1.26.1 lib/rubocop/cop/lint/shadowing_outer_local_variable.rb
op_connect-0.1.2 vendor/bundle/ruby/3.1.0/gems/rubocop-1.26.0/lib/rubocop/cop/lint/shadowing_outer_local_variable.rb
rubocop-1.26.0 lib/rubocop/cop/lint/shadowing_outer_local_variable.rb
rubocop-1.25.1 lib/rubocop/cop/lint/shadowing_outer_local_variable.rb
rubocop-1.25.0 lib/rubocop/cop/lint/shadowing_outer_local_variable.rb
phillipug-foodie-0.1.0 .vendor/ruby/3.0.0/gems/rubocop-1.24.0/lib/rubocop/cop/lint/shadowing_outer_local_variable.rb
rubocop-1.24.1 lib/rubocop/cop/lint/shadowing_outer_local_variable.rb
rubocop-1.24.0 lib/rubocop/cop/lint/shadowing_outer_local_variable.rb
rubocop-1.23.0 lib/rubocop/cop/lint/shadowing_outer_local_variable.rb
rubocop-1.22.3 lib/rubocop/cop/lint/shadowing_outer_local_variable.rb
rubocop-1.22.2 lib/rubocop/cop/lint/shadowing_outer_local_variable.rb
rubocop-1.22.1 lib/rubocop/cop/lint/shadowing_outer_local_variable.rb
rubocop-1.22.0 lib/rubocop/cop/lint/shadowing_outer_local_variable.rb