Class: RuboCop::Cop::Lint::UselessTimes
Overview
This cop checks for uses of ‘Integer#times` that will never yield (when the integer <= 0) or that will only ever yield once (`1.times`).
This cop is marked as unsafe as ‘times` returns its receiver, which is usually OK, but might change behavior.
Constant Summary collapse
- MSG =
'Useless call to `%<count>i.times` detected.'
- RESTRICT_ON_SEND =
%i[times].freeze
Instance Attribute Summary
Attributes inherited from Base
Instance Method Summary collapse
- #block_arg(node) ⇒ Object
- #block_reassigns_arg?(node) ⇒ Object
- #on_send(node) ⇒ Object
- #times_call?(node) ⇒ Object
Methods included from AutoCorrector
Methods inherited from Base
#add_global_offense, #add_offense, autocorrect_incompatible_with, badge, #callbacks_needed, callbacks_needed, #config_to_allow_offenses, #config_to_allow_offenses=, #cop_config, #cop_name, cop_name, department, documentation_url, exclude_from_registry, #excluded_file?, #external_dependency_checksum, inherited, #initialize, joining_forces, lint?, match?, #message, #offenses, #on_investigation_end, #on_new_investigation, #on_other_file, #ready, #relevant_file?, support_autocorrect?, support_multiple_source?, #target_rails_version, #target_ruby_version
Methods included from ExcludeLimit
Methods included from AutocorrectLogic
#autocorrect?, #autocorrect_enabled?, #autocorrect_requested?, #correctable?, #disable_uncorrectable?, #safe_autocorrect?
Methods included from IgnoredNode
#ignore_node, #ignored_node?, #part_of_ignored_node?
Methods included from Util
Constructor Details
This class inherits a constructor from RuboCop::Cop::Base
Instance Method Details
#block_arg(node) ⇒ Object
36 37 38 |
# File 'lib/rubocop/cop/lint/useless_times.rb', line 36 def_node_matcher :block_arg, <<~PATTERN (block _ (args (arg $_)) ...) PATTERN |
#block_reassigns_arg?(node) ⇒ Object
41 42 43 |
# File 'lib/rubocop/cop/lint/useless_times.rb', line 41 def_node_search :block_reassigns_arg?, <<~PATTERN (lvasgn %) PATTERN |
#on_send(node) ⇒ Object
45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 |
# File 'lib/rubocop/cop/lint/useless_times.rb', line 45 def on_send(node) return unless (count, proc_name = times_call?(node)) return if count > 1 # Get the block node if applicable node = node.block_node if node.block_literal? add_offense(node, message: format(MSG, count: count)) do |corrector| next unless own_line?(node) if never_process?(count, node) remove_node(corrector, node) elsif !proc_name.empty? autocorrect_block_pass(corrector, node, proc_name) else autocorrect_block(corrector, node) end end end |
#times_call?(node) ⇒ Object
31 32 33 |
# File 'lib/rubocop/cop/lint/useless_times.rb', line 31 def_node_matcher :times_call?, <<~PATTERN (send (int $_) :times (block-pass (sym $_))?) PATTERN |