Sha256: 01dd324a2182011e6115b44575b79b11f40f9d71fef63014a6d76292e8bbd6c2

Contents?: true

Size: 1.36 KB

Versions: 33

Compression:

Stored size: 1.36 KB

Contents

# frozen_string_literal: true

module RuboCop
  module Cop
    module Style
      # This cop checks for loops which iterate a constant number of times,
      # using a Range literal and `#each`. This can be done more readably using
      # `Integer#times`.
      #
      # This check only applies if the block takes no parameters.
      #
      # @example
      #   # bad
      #   (1..5).each { }
      #
      #   # good
      #   5.times { }
      #
      # @example
      #   # bad
      #   (0...10).each {}
      #
      #   # good
      #   10.times {}
      class EachForSimpleLoop < Base
        extend AutoCorrector

        MSG = 'Use `Integer#times` for a simple loop which iterates a fixed ' \
              'number of times.'

        def on_block(node)
          return unless offending_each_range(node)

          send_node = node.send_node

          range = send_node.receiver.source_range.join(send_node.loc.selector)

          add_offense(range) do |corrector|
            range_type, min, max = offending_each_range(node)

            max += 1 if range_type == :irange

            corrector.replace(node.send_node, "#{max - min}.times")
          end
        end

        private

        def_node_matcher :offending_each_range, <<~PATTERN
          (block (send (begin (${irange erange} (int $_) (int $_))) :each) (args) ...)
        PATTERN
      end
    end
  end
end

Version data entries

33 entries across 33 versions & 3 rubygems

Version Path
plaid-14.13.0 vendor/bundle/ruby/3.0.0/gems/rubocop-0.91.1/lib/rubocop/cop/style/each_for_simple_loop.rb
plaid-14.12.1 vendor/bundle/ruby/3.0.0/gems/rubocop-0.91.1/lib/rubocop/cop/style/each_for_simple_loop.rb
plaid-14.12.0 vendor/bundle/ruby/2.6.0/gems/rubocop-0.91.1/lib/rubocop/cop/style/each_for_simple_loop.rb
plaid-14.11.1 vendor/bundle/ruby/2.6.0/gems/rubocop-0.91.1/lib/rubocop/cop/style/each_for_simple_loop.rb
plaid-14.10.0 vendor/bundle/ruby/2.6.0/gems/rubocop-0.91.1/lib/rubocop/cop/style/each_for_simple_loop.rb
plaid-14.7.0 vendor/bundle/ruby/2.6.0/gems/rubocop-0.91.1/lib/rubocop/cop/style/each_for_simple_loop.rb
rubocop-1.10.0 lib/rubocop/cop/style/each_for_simple_loop.rb
rubocop-1.9.1 lib/rubocop/cop/style/each_for_simple_loop.rb
rubocop-1.9.0 lib/rubocop/cop/style/each_for_simple_loop.rb
rubocop-1.8.1 lib/rubocop/cop/style/each_for_simple_loop.rb
rubocop-1.8.0 lib/rubocop/cop/style/each_for_simple_loop.rb
rubocop-1.7.0 lib/rubocop/cop/style/each_for_simple_loop.rb
rubocop-1.6.1 lib/rubocop/cop/style/each_for_simple_loop.rb
rubocop-1.6.0 lib/rubocop/cop/style/each_for_simple_loop.rb
rubocop-1.5.2 lib/rubocop/cop/style/each_for_simple_loop.rb
rubocop-1.5.1 lib/rubocop/cop/style/each_for_simple_loop.rb
rubocop-1.5.0 lib/rubocop/cop/style/each_for_simple_loop.rb
rubocop-1.4.2 lib/rubocop/cop/style/each_for_simple_loop.rb
rubocop-1.4.1 lib/rubocop/cop/style/each_for_simple_loop.rb
rubocop-1.4.0 lib/rubocop/cop/style/each_for_simple_loop.rb