rubocop 1.31.2 → 1.57.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (532) hide show
  1. checksums.yaml +4 -4
  2. data/LICENSE.txt +1 -1
  3. data/README.md +7 -5
  4. data/config/default.yml +427 -56
  5. data/config/obsoletion.yml +28 -1
  6. data/exe/rubocop +1 -1
  7. data/lib/rubocop/arguments_env.rb +17 -0
  8. data/lib/rubocop/arguments_file.rb +17 -0
  9. data/lib/rubocop/cache_config.rb +29 -0
  10. data/lib/rubocop/cli/command/{auto_genenerate_config.rb → auto_generate_config.rb} +9 -2
  11. data/lib/rubocop/cli/command/execute_runner.rb +14 -9
  12. data/lib/rubocop/cli/command/init_dotfile.rb +1 -1
  13. data/lib/rubocop/cli/command/lsp.rb +19 -0
  14. data/lib/rubocop/cli/command/suggest_extensions.rb +61 -16
  15. data/lib/rubocop/cli.rb +60 -10
  16. data/lib/rubocop/comment_config.rb +60 -1
  17. data/lib/rubocop/config.rb +48 -20
  18. data/lib/rubocop/config_finder.rb +68 -0
  19. data/lib/rubocop/config_loader.rb +46 -68
  20. data/lib/rubocop/config_loader_resolver.rb +7 -7
  21. data/lib/rubocop/config_obsoletion/changed_parameter.rb +5 -0
  22. data/lib/rubocop/config_obsoletion/parameter_rule.rb +13 -1
  23. data/lib/rubocop/config_obsoletion.rb +9 -4
  24. data/lib/rubocop/config_validator.rb +1 -1
  25. data/lib/rubocop/cop/autocorrect_logic.rb +31 -13
  26. data/lib/rubocop/cop/badge.rb +9 -4
  27. data/lib/rubocop/cop/base.rb +116 -84
  28. data/lib/rubocop/cop/bundler/duplicated_gem.rb +1 -0
  29. data/lib/rubocop/cop/bundler/duplicated_group.rb +127 -0
  30. data/lib/rubocop/cop/bundler/gem_comment.rb +2 -2
  31. data/lib/rubocop/cop/bundler/gem_version.rb +2 -2
  32. data/lib/rubocop/cop/bundler/ordered_gems.rb +9 -1
  33. data/lib/rubocop/cop/commissioner.rb +19 -6
  34. data/lib/rubocop/cop/cop.rb +54 -34
  35. data/lib/rubocop/cop/corrector.rb +31 -11
  36. data/lib/rubocop/cop/correctors/alignment_corrector.rb +3 -3
  37. data/lib/rubocop/cop/correctors/each_to_for_corrector.rb +3 -3
  38. data/lib/rubocop/cop/correctors/for_to_each_corrector.rb +3 -3
  39. data/lib/rubocop/cop/correctors/lambda_literal_to_method_corrector.rb +7 -4
  40. data/lib/rubocop/cop/correctors/line_break_corrector.rb +1 -1
  41. data/lib/rubocop/cop/correctors/multiline_literal_brace_corrector.rb +23 -7
  42. data/lib/rubocop/cop/correctors/ordered_gem_corrector.rb +2 -7
  43. data/lib/rubocop/cop/correctors/parentheses_corrector.rb +58 -0
  44. data/lib/rubocop/cop/correctors/percent_literal_corrector.rb +2 -2
  45. data/lib/rubocop/cop/gemspec/dependency_version.rb +19 -21
  46. data/lib/rubocop/cop/gemspec/deprecated_attribute_assignment.rb +1 -1
  47. data/lib/rubocop/cop/gemspec/development_dependencies.rb +107 -0
  48. data/lib/rubocop/cop/gemspec/ordered_dependencies.rb +9 -1
  49. data/lib/rubocop/cop/gemspec/require_mfa.rb +1 -1
  50. data/lib/rubocop/cop/generator/require_file_injector.rb +3 -3
  51. data/lib/rubocop/cop/generator.rb +1 -2
  52. data/lib/rubocop/cop/internal_affairs/cop_description.rb +38 -12
  53. data/lib/rubocop/cop/internal_affairs/create_empty_file.rb +37 -0
  54. data/lib/rubocop/cop/internal_affairs/example_description.rb +42 -21
  55. data/lib/rubocop/cop/internal_affairs/example_heredoc_delimiter.rb +111 -0
  56. data/lib/rubocop/cop/internal_affairs/inherit_deprecated_cop_class.rb +1 -1
  57. data/lib/rubocop/cop/internal_affairs/lambda_or_proc.rb +46 -0
  58. data/lib/rubocop/cop/internal_affairs/location_expression.rb +37 -0
  59. data/lib/rubocop/cop/internal_affairs/location_line_equality_comparison.rb +3 -1
  60. data/lib/rubocop/cop/internal_affairs/node_matcher_directive.rb +6 -6
  61. data/lib/rubocop/cop/internal_affairs/node_type_predicate.rb +1 -1
  62. data/lib/rubocop/cop/internal_affairs/numblock_handler.rb +69 -0
  63. data/lib/rubocop/cop/internal_affairs/processed_source_buffer_name.rb +42 -0
  64. data/lib/rubocop/cop/internal_affairs/redundant_let_rubocop_config_new.rb +11 -3
  65. data/lib/rubocop/cop/internal_affairs/redundant_location_argument.rb +1 -1
  66. data/lib/rubocop/cop/internal_affairs/redundant_message_argument.rb +1 -1
  67. data/lib/rubocop/cop/internal_affairs/redundant_method_dispatch_node.rb +11 -2
  68. data/lib/rubocop/cop/internal_affairs/redundant_source_range.rb +66 -0
  69. data/lib/rubocop/cop/internal_affairs/single_line_comparison.rb +62 -0
  70. data/lib/rubocop/cop/internal_affairs/useless_message_assertion.rb +2 -0
  71. data/lib/rubocop/cop/internal_affairs/useless_restrict_on_send.rb +7 -1
  72. data/lib/rubocop/cop/internal_affairs.rb +8 -0
  73. data/lib/rubocop/cop/layout/array_alignment.rb +1 -1
  74. data/lib/rubocop/cop/layout/block_alignment.rb +16 -12
  75. data/lib/rubocop/cop/layout/block_end_newline.rb +31 -9
  76. data/lib/rubocop/cop/layout/class_structure.rb +44 -27
  77. data/lib/rubocop/cop/layout/closing_heredoc_indentation.rb +2 -3
  78. data/lib/rubocop/cop/layout/closing_parenthesis_indentation.rb +2 -6
  79. data/lib/rubocop/cop/layout/comment_indentation.rb +3 -1
  80. data/lib/rubocop/cop/layout/dot_position.rb +1 -5
  81. data/lib/rubocop/cop/layout/empty_comment.rb +3 -3
  82. data/lib/rubocop/cop/layout/empty_line_after_guard_clause.rb +42 -9
  83. data/lib/rubocop/cop/layout/empty_line_between_defs.rb +28 -5
  84. data/lib/rubocop/cop/layout/empty_lines.rb +3 -1
  85. data/lib/rubocop/cop/layout/empty_lines_around_access_modifier.rb +7 -2
  86. data/lib/rubocop/cop/layout/empty_lines_around_block_body.rb +2 -0
  87. data/lib/rubocop/cop/layout/empty_lines_around_exception_handling_keywords.rb +2 -0
  88. data/lib/rubocop/cop/layout/end_alignment.rb +9 -1
  89. data/lib/rubocop/cop/layout/end_of_line.rb +4 -4
  90. data/lib/rubocop/cop/layout/extra_spacing.rb +15 -6
  91. data/lib/rubocop/cop/layout/first_argument_indentation.rb +15 -4
  92. data/lib/rubocop/cop/layout/first_array_element_indentation.rb +2 -2
  93. data/lib/rubocop/cop/layout/first_array_element_line_break.rb +35 -8
  94. data/lib/rubocop/cop/layout/first_hash_element_indentation.rb +2 -2
  95. data/lib/rubocop/cop/layout/first_hash_element_line_break.rb +36 -1
  96. data/lib/rubocop/cop/layout/first_method_argument_line_break.rb +57 -8
  97. data/lib/rubocop/cop/layout/first_method_parameter_line_break.rb +52 -19
  98. data/lib/rubocop/cop/layout/heredoc_argument_closing_parenthesis.rb +10 -4
  99. data/lib/rubocop/cop/layout/heredoc_indentation.rb +11 -11
  100. data/lib/rubocop/cop/layout/indentation_style.rb +8 -3
  101. data/lib/rubocop/cop/layout/indentation_width.rb +9 -5
  102. data/lib/rubocop/cop/layout/initial_indentation.rb +1 -1
  103. data/lib/rubocop/cop/layout/leading_comment_space.rb +2 -2
  104. data/lib/rubocop/cop/layout/line_continuation_leading_space.rb +91 -15
  105. data/lib/rubocop/cop/layout/line_continuation_spacing.rb +19 -9
  106. data/lib/rubocop/cop/layout/line_end_string_concatenation_indentation.rb +2 -0
  107. data/lib/rubocop/cop/layout/line_length.rb +8 -1
  108. data/lib/rubocop/cop/layout/multiline_array_line_breaks.rb +31 -1
  109. data/lib/rubocop/cop/layout/multiline_assignment_layout.rb +1 -1
  110. data/lib/rubocop/cop/layout/multiline_block_layout.rb +3 -1
  111. data/lib/rubocop/cop/layout/multiline_hash_key_line_breaks.rb +29 -1
  112. data/lib/rubocop/cop/layout/multiline_method_argument_line_breaks.rb +39 -2
  113. data/lib/rubocop/cop/layout/multiline_method_call_indentation.rb +18 -3
  114. data/lib/rubocop/cop/layout/multiline_method_parameter_line_breaks.rb +77 -0
  115. data/lib/rubocop/cop/layout/redundant_line_break.rb +22 -13
  116. data/lib/rubocop/cop/layout/rescue_ensure_alignment.rb +2 -2
  117. data/lib/rubocop/cop/layout/space_after_comma.rb +9 -1
  118. data/lib/rubocop/cop/layout/space_after_not.rb +1 -1
  119. data/lib/rubocop/cop/layout/space_around_block_parameters.rb +1 -1
  120. data/lib/rubocop/cop/layout/space_around_keyword.rb +3 -3
  121. data/lib/rubocop/cop/layout/space_around_method_call_operator.rb +2 -2
  122. data/lib/rubocop/cop/layout/space_around_operators.rb +4 -2
  123. data/lib/rubocop/cop/layout/space_before_block_braces.rb +2 -0
  124. data/lib/rubocop/cop/layout/space_before_first_arg.rb +1 -1
  125. data/lib/rubocop/cop/layout/space_in_lambda_literal.rb +2 -2
  126. data/lib/rubocop/cop/layout/space_inside_array_literal_brackets.rb +22 -20
  127. data/lib/rubocop/cop/layout/space_inside_array_percent_literal.rb +3 -0
  128. data/lib/rubocop/cop/layout/space_inside_block_braces.rb +27 -9
  129. data/lib/rubocop/cop/layout/space_inside_hash_literal_braces.rb +30 -3
  130. data/lib/rubocop/cop/layout/space_inside_parens.rb +3 -3
  131. data/lib/rubocop/cop/layout/space_inside_percent_literal_delimiters.rb +34 -0
  132. data/lib/rubocop/cop/layout/space_inside_range_literal.rb +1 -1
  133. data/lib/rubocop/cop/layout/space_inside_reference_brackets.rb +10 -6
  134. data/lib/rubocop/cop/layout/space_inside_string_interpolation.rb +5 -4
  135. data/lib/rubocop/cop/layout/trailing_empty_lines.rb +6 -1
  136. data/lib/rubocop/cop/layout/trailing_whitespace.rb +12 -5
  137. data/lib/rubocop/cop/legacy/corrections_proxy.rb +1 -1
  138. data/lib/rubocop/cop/legacy/corrector.rb +1 -1
  139. data/lib/rubocop/cop/lint/ambiguous_block_association.rb +40 -8
  140. data/lib/rubocop/cop/lint/ambiguous_operator.rb +4 -0
  141. data/lib/rubocop/cop/lint/assignment_in_condition.rb +11 -1
  142. data/lib/rubocop/cop/lint/constant_resolution.rb +5 -1
  143. data/lib/rubocop/cop/lint/debugger.rb +41 -32
  144. data/lib/rubocop/cop/lint/deprecated_class_methods.rb +66 -110
  145. data/lib/rubocop/cop/lint/deprecated_constants.rb +8 -1
  146. data/lib/rubocop/cop/lint/deprecated_open_ssl_constant.rb +1 -1
  147. data/lib/rubocop/cop/lint/duplicate_branch.rb +0 -2
  148. data/lib/rubocop/cop/lint/duplicate_hash_key.rb +2 -1
  149. data/lib/rubocop/cop/lint/duplicate_magic_comment.rb +73 -0
  150. data/lib/rubocop/cop/lint/duplicate_match_pattern.rb +122 -0
  151. data/lib/rubocop/cop/lint/duplicate_methods.rb +48 -18
  152. data/lib/rubocop/cop/lint/duplicate_regexp_character_class_element.rb +55 -11
  153. data/lib/rubocop/cop/lint/duplicate_require.rb +1 -1
  154. data/lib/rubocop/cop/lint/else_layout.rb +3 -7
  155. data/lib/rubocop/cop/lint/empty_block.rb +4 -8
  156. data/lib/rubocop/cop/lint/empty_class.rb +3 -1
  157. data/lib/rubocop/cop/lint/empty_conditional_body.rb +110 -2
  158. data/lib/rubocop/cop/lint/empty_interpolation.rb +1 -1
  159. data/lib/rubocop/cop/lint/erb_new_arguments.rb +12 -13
  160. data/lib/rubocop/cop/lint/format_parameter_mismatch.rb +14 -7
  161. data/lib/rubocop/cop/lint/heredoc_method_call_position.rb +16 -18
  162. data/lib/rubocop/cop/lint/identity_comparison.rb +0 -1
  163. data/lib/rubocop/cop/lint/implicit_string_concatenation.rb +1 -1
  164. data/lib/rubocop/cop/lint/incompatible_io_select_with_fiber_scheduler.rb +5 -3
  165. data/lib/rubocop/cop/lint/ineffective_access_modifier.rb +1 -1
  166. data/lib/rubocop/cop/lint/inherit_exception.rb +9 -0
  167. data/lib/rubocop/cop/lint/interpolation_check.rb +4 -3
  168. data/lib/rubocop/cop/lint/lambda_without_literal_block.rb +1 -1
  169. data/lib/rubocop/cop/lint/literal_in_interpolation.rb +49 -3
  170. data/lib/rubocop/cop/lint/missing_cop_enable_directive.rb +18 -3
  171. data/lib/rubocop/cop/lint/missing_super.rb +63 -5
  172. data/lib/rubocop/cop/lint/mixed_case_range.rb +111 -0
  173. data/lib/rubocop/cop/lint/mixed_regexp_capture_types.rb +1 -0
  174. data/lib/rubocop/cop/lint/nested_method_definition.rb +53 -9
  175. data/lib/rubocop/cop/lint/next_without_accumulator.rb +25 -6
  176. data/lib/rubocop/cop/lint/non_atomic_file_operation.rb +68 -29
  177. data/lib/rubocop/cop/lint/non_deterministic_require_order.rb +12 -0
  178. data/lib/rubocop/cop/lint/number_conversion.rb +33 -6
  179. data/lib/rubocop/cop/lint/numbered_parameter_assignment.rb +2 -2
  180. data/lib/rubocop/cop/lint/or_assignment_to_constant.rb +2 -0
  181. data/lib/rubocop/cop/lint/ordered_magic_comments.rb +4 -6
  182. data/lib/rubocop/cop/lint/out_of_range_regexp_ref.rb +17 -2
  183. data/lib/rubocop/cop/lint/parentheses_as_grouped_expression.rb +5 -0
  184. data/lib/rubocop/cop/lint/percent_string_array.rb +1 -1
  185. data/lib/rubocop/cop/lint/percent_symbol_array.rb +1 -1
  186. data/lib/rubocop/cop/lint/redundant_cop_disable_directive.rb +49 -9
  187. data/lib/rubocop/cop/lint/redundant_cop_enable_directive.rb +6 -6
  188. data/lib/rubocop/cop/lint/redundant_dir_glob_sort.rb +7 -0
  189. data/lib/rubocop/cop/lint/redundant_regexp_quantifiers.rb +130 -0
  190. data/lib/rubocop/cop/lint/redundant_require_statement.rb +57 -10
  191. data/lib/rubocop/cop/lint/redundant_safe_navigation.rb +33 -4
  192. data/lib/rubocop/cop/lint/redundant_splat_expansion.rb +1 -1
  193. data/lib/rubocop/cop/lint/redundant_string_coercion.rb +35 -15
  194. data/lib/rubocop/cop/lint/redundant_with_index.rb +14 -11
  195. data/lib/rubocop/cop/lint/redundant_with_object.rb +13 -12
  196. data/lib/rubocop/cop/lint/refinement_import_methods.rb +2 -1
  197. data/lib/rubocop/cop/lint/regexp_as_condition.rb +6 -0
  198. data/lib/rubocop/cop/lint/require_parentheses.rb +3 -1
  199. data/lib/rubocop/cop/lint/require_range_parentheses.rb +57 -0
  200. data/lib/rubocop/cop/lint/rescue_type.rb +3 -3
  201. data/lib/rubocop/cop/lint/safe_navigation_chain.rb +48 -8
  202. data/lib/rubocop/cop/lint/safe_navigation_consistency.rb +1 -1
  203. data/lib/rubocop/cop/lint/script_permission.rb +1 -1
  204. data/lib/rubocop/cop/lint/send_with_mixin_argument.rb +6 -6
  205. data/lib/rubocop/cop/lint/shadowed_exception.rb +21 -22
  206. data/lib/rubocop/cop/lint/shadowing_outer_local_variable.rb +35 -4
  207. data/lib/rubocop/cop/lint/struct_new_override.rb +12 -12
  208. data/lib/rubocop/cop/lint/suppressed_exception.rb +3 -3
  209. data/lib/rubocop/cop/lint/symbol_conversion.rb +1 -1
  210. data/lib/rubocop/cop/lint/syntax.rb +4 -0
  211. data/lib/rubocop/cop/lint/to_enum_arguments.rb +18 -6
  212. data/lib/rubocop/cop/lint/top_level_return_with_argument.rb +23 -9
  213. data/lib/rubocop/cop/lint/unreachable_loop.rb +12 -6
  214. data/lib/rubocop/cop/lint/unused_method_argument.rb +6 -1
  215. data/lib/rubocop/cop/lint/useless_access_modifier.rb +17 -12
  216. data/lib/rubocop/cop/lint/useless_assignment.rb +94 -10
  217. data/lib/rubocop/cop/lint/useless_method_definition.rb +12 -4
  218. data/lib/rubocop/cop/lint/useless_rescue.rb +89 -0
  219. data/lib/rubocop/cop/lint/useless_ruby2_keywords.rb +15 -5
  220. data/lib/rubocop/cop/lint/useless_times.rb +1 -1
  221. data/lib/rubocop/cop/lint/void.rb +86 -21
  222. data/lib/rubocop/cop/metrics/abc_size.rb +4 -2
  223. data/lib/rubocop/cop/metrics/block_length.rb +17 -12
  224. data/lib/rubocop/cop/metrics/block_nesting.rb +2 -2
  225. data/lib/rubocop/cop/metrics/class_length.rb +12 -6
  226. data/lib/rubocop/cop/metrics/collection_literal_length.rb +76 -0
  227. data/lib/rubocop/cop/metrics/cyclomatic_complexity.rb +1 -1
  228. data/lib/rubocop/cop/metrics/method_length.rb +18 -12
  229. data/lib/rubocop/cop/metrics/module_length.rb +10 -5
  230. data/lib/rubocop/cop/metrics/parameter_lists.rb +27 -0
  231. data/lib/rubocop/cop/metrics/perceived_complexity.rb +1 -1
  232. data/lib/rubocop/cop/metrics/utils/abc_size_calculator.rb +4 -8
  233. data/lib/rubocop/cop/metrics/utils/code_length_calculator.rb +39 -8
  234. data/lib/rubocop/cop/migration/department_name.rb +3 -3
  235. data/lib/rubocop/cop/mixin/alignment.rb +2 -2
  236. data/lib/rubocop/cop/mixin/allowed_identifiers.rb +2 -2
  237. data/lib/rubocop/cop/mixin/allowed_methods.rb +23 -2
  238. data/lib/rubocop/cop/mixin/allowed_pattern.rb +17 -1
  239. data/lib/rubocop/cop/mixin/allowed_receivers.rb +34 -0
  240. data/lib/rubocop/cop/mixin/annotation_comment.rb +14 -7
  241. data/lib/rubocop/cop/mixin/check_line_breakable.rb +5 -1
  242. data/lib/rubocop/cop/mixin/code_length.rb +1 -1
  243. data/lib/rubocop/cop/mixin/comments_help.rb +29 -7
  244. data/lib/rubocop/cop/mixin/configurable_enforced_style.rb +21 -9
  245. data/lib/rubocop/cop/mixin/def_node.rb +1 -1
  246. data/lib/rubocop/cop/mixin/documentation_comment.rb +1 -1
  247. data/lib/rubocop/cop/mixin/end_keyword_alignment.rb +1 -1
  248. data/lib/rubocop/cop/mixin/enforce_superclass.rb +2 -1
  249. data/lib/rubocop/cop/mixin/first_element_line_break.rb +11 -7
  250. data/lib/rubocop/cop/mixin/frozen_string_literal.rb +4 -0
  251. data/lib/rubocop/cop/mixin/hash_alignment_styles.rb +1 -1
  252. data/lib/rubocop/cop/mixin/hash_shorthand_syntax.rb +152 -12
  253. data/lib/rubocop/cop/mixin/hash_transform_method.rb +13 -9
  254. data/lib/rubocop/cop/mixin/heredoc.rb +6 -2
  255. data/lib/rubocop/cop/mixin/line_length_help.rb +11 -2
  256. data/lib/rubocop/cop/mixin/method_complexity.rb +13 -16
  257. data/lib/rubocop/cop/mixin/min_branches_count.rb +40 -0
  258. data/lib/rubocop/cop/mixin/multiline_element_indentation.rb +1 -1
  259. data/lib/rubocop/cop/mixin/multiline_element_line_breaks.rb +5 -6
  260. data/lib/rubocop/cop/mixin/multiline_expression_indentation.rb +3 -2
  261. data/lib/rubocop/cop/mixin/ordered_gem_node.rb +1 -1
  262. data/lib/rubocop/cop/mixin/percent_array.rb +58 -1
  263. data/lib/rubocop/cop/mixin/percent_literal.rb +1 -1
  264. data/lib/rubocop/cop/mixin/preceding_following_alignment.rb +6 -8
  265. data/lib/rubocop/cop/mixin/range_help.rb +22 -5
  266. data/lib/rubocop/cop/mixin/require_library.rb +2 -0
  267. data/lib/rubocop/cop/mixin/rescue_node.rb +5 -3
  268. data/lib/rubocop/cop/mixin/space_after_punctuation.rb +1 -1
  269. data/lib/rubocop/cop/mixin/statement_modifier.rb +18 -3
  270. data/lib/rubocop/cop/mixin/string_help.rb +4 -2
  271. data/lib/rubocop/cop/mixin/surrounding_space.rb +13 -11
  272. data/lib/rubocop/cop/mixin/trailing_comma.rb +3 -3
  273. data/lib/rubocop/cop/mixin/visibility_help.rb +40 -5
  274. data/lib/rubocop/cop/naming/ascii_identifiers.rb +1 -1
  275. data/lib/rubocop/cop/naming/block_forwarding.rb +6 -2
  276. data/lib/rubocop/cop/naming/block_parameter_name.rb +1 -1
  277. data/lib/rubocop/cop/naming/class_and_module_camel_case.rb +3 -1
  278. data/lib/rubocop/cop/naming/constant_name.rb +3 -3
  279. data/lib/rubocop/cop/naming/file_name.rb +1 -1
  280. data/lib/rubocop/cop/naming/heredoc_delimiter_case.rb +1 -1
  281. data/lib/rubocop/cop/naming/heredoc_delimiter_naming.rb +3 -1
  282. data/lib/rubocop/cop/naming/inclusive_language.rb +28 -6
  283. data/lib/rubocop/cop/naming/memoized_instance_variable_name.rb +25 -10
  284. data/lib/rubocop/cop/naming/method_name.rb +3 -3
  285. data/lib/rubocop/cop/naming/predicate_name.rb +31 -2
  286. data/lib/rubocop/cop/naming/rescued_exceptions_variable_name.rb +12 -4
  287. data/lib/rubocop/cop/naming/variable_name.rb +6 -1
  288. data/lib/rubocop/cop/registry.rb +73 -45
  289. data/lib/rubocop/cop/security/compound_hash.rb +2 -1
  290. data/lib/rubocop/cop/style/access_modifier_declarations.rb +92 -3
  291. data/lib/rubocop/cop/style/accessor_grouping.rb +50 -20
  292. data/lib/rubocop/cop/style/alias.rb +18 -9
  293. data/lib/rubocop/cop/style/arguments_forwarding.rb +280 -62
  294. data/lib/rubocop/cop/style/array_intersect.rb +119 -0
  295. data/lib/rubocop/cop/style/ascii_comments.rb +1 -1
  296. data/lib/rubocop/cop/style/attr.rb +11 -1
  297. data/lib/rubocop/cop/style/begin_block.rb +1 -2
  298. data/lib/rubocop/cop/style/bisected_attr_accessor.rb +1 -1
  299. data/lib/rubocop/cop/style/block_comments.rb +3 -3
  300. data/lib/rubocop/cop/style/block_delimiters.rb +49 -14
  301. data/lib/rubocop/cop/style/case_equality.rb +40 -10
  302. data/lib/rubocop/cop/style/case_like_if.rb +20 -3
  303. data/lib/rubocop/cop/style/character_literal.rb +1 -1
  304. data/lib/rubocop/cop/style/class_and_module_children.rb +9 -16
  305. data/lib/rubocop/cop/style/class_equality_comparison.rb +79 -12
  306. data/lib/rubocop/cop/style/class_methods_definitions.rb +2 -1
  307. data/lib/rubocop/cop/style/collection_compact.rb +27 -5
  308. data/lib/rubocop/cop/style/collection_methods.rb +4 -0
  309. data/lib/rubocop/cop/style/colon_method_call.rb +2 -2
  310. data/lib/rubocop/cop/style/combinable_loops.rb +32 -8
  311. data/lib/rubocop/cop/style/command_literal.rb +1 -1
  312. data/lib/rubocop/cop/style/comment_annotation.rb +1 -1
  313. data/lib/rubocop/cop/style/commented_keyword.rb +2 -2
  314. data/lib/rubocop/cop/style/comparable_clamp.rb +125 -0
  315. data/lib/rubocop/cop/style/concat_array_literals.rb +94 -0
  316. data/lib/rubocop/cop/style/conditional_assignment.rb +11 -15
  317. data/lib/rubocop/cop/style/copyright.rb +6 -3
  318. data/lib/rubocop/cop/style/data_inheritance.rb +75 -0
  319. data/lib/rubocop/cop/style/dir.rb +1 -1
  320. data/lib/rubocop/cop/style/dir_empty.rb +54 -0
  321. data/lib/rubocop/cop/style/disable_cops_within_source_code_directive.rb +2 -2
  322. data/lib/rubocop/cop/style/document_dynamic_eval_definition.rb +3 -3
  323. data/lib/rubocop/cop/style/documentation.rb +22 -10
  324. data/lib/rubocop/cop/style/documentation_method.rb +10 -4
  325. data/lib/rubocop/cop/style/double_negation.rb +4 -2
  326. data/lib/rubocop/cop/style/each_for_simple_loop.rb +41 -6
  327. data/lib/rubocop/cop/style/each_with_object.rb +40 -9
  328. data/lib/rubocop/cop/style/empty_block_parameter.rb +2 -2
  329. data/lib/rubocop/cop/style/empty_case_condition.rb +6 -1
  330. data/lib/rubocop/cop/style/empty_else.rb +37 -0
  331. data/lib/rubocop/cop/style/empty_heredoc.rb +73 -0
  332. data/lib/rubocop/cop/style/empty_lambda_parameter.rb +2 -2
  333. data/lib/rubocop/cop/style/empty_method.rb +1 -1
  334. data/lib/rubocop/cop/style/endless_method.rb +1 -1
  335. data/lib/rubocop/cop/style/eval_with_location.rb +8 -8
  336. data/lib/rubocop/cop/style/exact_regexp_match.rb +68 -0
  337. data/lib/rubocop/cop/style/explicit_block_argument.rb +5 -1
  338. data/lib/rubocop/cop/style/fetch_env_var.rb +10 -177
  339. data/lib/rubocop/cop/style/file_empty.rb +71 -0
  340. data/lib/rubocop/cop/style/file_read.rb +3 -3
  341. data/lib/rubocop/cop/style/file_write.rb +1 -1
  342. data/lib/rubocop/cop/style/for.rb +3 -1
  343. data/lib/rubocop/cop/style/format_string.rb +24 -3
  344. data/lib/rubocop/cop/style/format_string_token.rb +25 -6
  345. data/lib/rubocop/cop/style/frozen_string_literal_comment.rb +4 -2
  346. data/lib/rubocop/cop/style/guard_clause.rb +152 -37
  347. data/lib/rubocop/cop/style/hash_as_last_array_item.rb +1 -0
  348. data/lib/rubocop/cop/style/hash_conversion.rb +10 -0
  349. data/lib/rubocop/cop/style/hash_each_methods.rb +36 -21
  350. data/lib/rubocop/cop/style/hash_except.rb +27 -16
  351. data/lib/rubocop/cop/style/hash_like_case.rb +3 -9
  352. data/lib/rubocop/cop/style/hash_syntax.rb +26 -2
  353. data/lib/rubocop/cop/style/hash_transform_keys.rb +2 -2
  354. data/lib/rubocop/cop/style/hash_transform_values.rb +2 -2
  355. data/lib/rubocop/cop/style/identical_conditional_branches.rb +36 -3
  356. data/lib/rubocop/cop/style/if_inside_else.rb +6 -0
  357. data/lib/rubocop/cop/style/if_unless_modifier.rb +112 -16
  358. data/lib/rubocop/cop/style/if_with_boolean_literal_branches.rb +29 -2
  359. data/lib/rubocop/cop/style/if_with_semicolon.rb +6 -6
  360. data/lib/rubocop/cop/style/infinite_loop.rb +2 -5
  361. data/lib/rubocop/cop/style/inverse_methods.rb +15 -11
  362. data/lib/rubocop/cop/style/invertible_unless_condition.rb +118 -0
  363. data/lib/rubocop/cop/style/lambda.rb +3 -3
  364. data/lib/rubocop/cop/style/lambda_call.rb +5 -0
  365. data/lib/rubocop/cop/style/line_end_concatenation.rb +4 -1
  366. data/lib/rubocop/cop/style/magic_comment_format.rb +307 -0
  367. data/lib/rubocop/cop/style/map_compact_with_conditional_block.rb +2 -2
  368. data/lib/rubocop/cop/style/map_to_hash.rb +4 -1
  369. data/lib/rubocop/cop/style/map_to_set.rb +64 -0
  370. data/lib/rubocop/cop/style/method_call_with_args_parentheses/omit_parentheses.rb +49 -27
  371. data/lib/rubocop/cop/style/method_call_with_args_parentheses/require_parentheses.rb +5 -1
  372. data/lib/rubocop/cop/style/method_call_with_args_parentheses.rb +48 -41
  373. data/lib/rubocop/cop/style/method_call_without_args_parentheses.rb +21 -2
  374. data/lib/rubocop/cop/style/method_called_on_do_end_block.rb +4 -1
  375. data/lib/rubocop/cop/style/method_def_parentheses.rb +11 -4
  376. data/lib/rubocop/cop/style/min_max.rb +3 -3
  377. data/lib/rubocop/cop/style/min_max_comparison.rb +83 -0
  378. data/lib/rubocop/cop/style/missing_else.rb +13 -1
  379. data/lib/rubocop/cop/style/mixin_grouping.rb +5 -5
  380. data/lib/rubocop/cop/style/module_function.rb +28 -6
  381. data/lib/rubocop/cop/style/multiline_block_chain.rb +4 -2
  382. data/lib/rubocop/cop/style/multiline_if_modifier.rb +0 -4
  383. data/lib/rubocop/cop/style/multiline_in_pattern_then.rb +1 -1
  384. data/lib/rubocop/cop/style/multiline_memoization.rb +2 -2
  385. data/lib/rubocop/cop/style/multiline_method_signature.rb +7 -4
  386. data/lib/rubocop/cop/style/multiline_ternary_operator.rb +19 -4
  387. data/lib/rubocop/cop/style/multiple_comparison.rb +14 -0
  388. data/lib/rubocop/cop/style/negated_if_else_condition.rb +17 -10
  389. data/lib/rubocop/cop/style/nested_parenthesized_calls.rb +9 -0
  390. data/lib/rubocop/cop/style/nested_ternary_operator.rb +3 -11
  391. data/lib/rubocop/cop/style/next.rb +3 -5
  392. data/lib/rubocop/cop/style/nil_lambda.rb +4 -4
  393. data/lib/rubocop/cop/style/numbered_parameters_limit.rb +11 -3
  394. data/lib/rubocop/cop/style/numeric_literals.rb +16 -1
  395. data/lib/rubocop/cop/style/numeric_predicate.rb +43 -9
  396. data/lib/rubocop/cop/style/object_then.rb +5 -0
  397. data/lib/rubocop/cop/style/one_line_conditional.rb +3 -6
  398. data/lib/rubocop/cop/style/open_struct_use.rb +1 -1
  399. data/lib/rubocop/cop/style/operator_method_call.rb +73 -0
  400. data/lib/rubocop/cop/style/parallel_assignment.rb +29 -19
  401. data/lib/rubocop/cop/style/percent_literal_delimiters.rb +2 -3
  402. data/lib/rubocop/cop/style/percent_q_literals.rb +1 -1
  403. data/lib/rubocop/cop/style/perl_backrefs.rb +22 -1
  404. data/lib/rubocop/cop/style/preferred_hash_methods.rb +1 -1
  405. data/lib/rubocop/cop/style/proc.rb +4 -1
  406. data/lib/rubocop/cop/style/quoted_symbols.rb +1 -1
  407. data/lib/rubocop/cop/style/redundant_argument.rb +9 -1
  408. data/lib/rubocop/cop/style/redundant_array_constructor.rb +77 -0
  409. data/lib/rubocop/cop/style/redundant_begin.rb +13 -2
  410. data/lib/rubocop/cop/style/redundant_condition.rb +41 -8
  411. data/lib/rubocop/cop/style/redundant_conditional.rb +2 -14
  412. data/lib/rubocop/cop/style/redundant_constant_base.rb +85 -0
  413. data/lib/rubocop/cop/style/redundant_current_directory_in_path.rb +38 -0
  414. data/lib/rubocop/cop/style/redundant_double_splat_hash_braces.rb +126 -0
  415. data/lib/rubocop/cop/style/redundant_each.rb +116 -0
  416. data/lib/rubocop/cop/style/redundant_exception.rb +32 -12
  417. data/lib/rubocop/cop/style/redundant_fetch_block.rb +7 -5
  418. data/lib/rubocop/cop/style/redundant_filter_chain.rb +117 -0
  419. data/lib/rubocop/cop/style/redundant_heredoc_delimiter_quotes.rb +58 -0
  420. data/lib/rubocop/cop/style/redundant_initialize.rb +3 -1
  421. data/lib/rubocop/cop/style/redundant_interpolation.rb +2 -2
  422. data/lib/rubocop/cop/style/redundant_line_continuation.rb +183 -0
  423. data/lib/rubocop/cop/style/redundant_parentheses.rb +44 -29
  424. data/lib/rubocop/cop/style/redundant_percent_q.rb +1 -1
  425. data/lib/rubocop/cop/style/redundant_regexp_argument.rb +100 -0
  426. data/lib/rubocop/cop/style/redundant_regexp_character_class.rb +9 -3
  427. data/lib/rubocop/cop/style/redundant_regexp_constructor.rb +46 -0
  428. data/lib/rubocop/cop/style/redundant_regexp_escape.rb +22 -4
  429. data/lib/rubocop/cop/style/redundant_return.rb +14 -2
  430. data/lib/rubocop/cop/style/redundant_self.rb +2 -0
  431. data/lib/rubocop/cop/style/redundant_self_assignment_branch.rb +8 -1
  432. data/lib/rubocop/cop/style/redundant_sort.rb +24 -9
  433. data/lib/rubocop/cop/style/redundant_sort_by.rb +24 -8
  434. data/lib/rubocop/cop/style/redundant_string_escape.rb +185 -0
  435. data/lib/rubocop/cop/style/regexp_literal.rb +11 -2
  436. data/lib/rubocop/cop/style/require_order.rb +139 -0
  437. data/lib/rubocop/cop/style/rescue_modifier.rb +2 -4
  438. data/lib/rubocop/cop/style/rescue_standard_error.rb +2 -2
  439. data/lib/rubocop/cop/style/return_nil.rb +6 -2
  440. data/lib/rubocop/cop/style/return_nil_in_predicate_method_definition.rb +95 -0
  441. data/lib/rubocop/cop/style/safe_navigation.rb +41 -10
  442. data/lib/rubocop/cop/style/select_by_regexp.rb +23 -5
  443. data/lib/rubocop/cop/style/self_assignment.rb +2 -2
  444. data/lib/rubocop/cop/style/semicolon.rb +63 -8
  445. data/lib/rubocop/cop/style/signal_exception.rb +9 -7
  446. data/lib/rubocop/cop/style/single_line_block_params.rb +1 -1
  447. data/lib/rubocop/cop/style/single_line_do_end_block.rb +65 -0
  448. data/lib/rubocop/cop/style/single_line_methods.rb +1 -1
  449. data/lib/rubocop/cop/style/slicing_with_range.rb +1 -1
  450. data/lib/rubocop/cop/style/sole_nested_conditional.rb +23 -10
  451. data/lib/rubocop/cop/style/special_global_vars.rb +3 -4
  452. data/lib/rubocop/cop/style/static_class.rb +32 -1
  453. data/lib/rubocop/cop/style/stderr_puts.rb +1 -1
  454. data/lib/rubocop/cop/style/string_hash_keys.rb +4 -1
  455. data/lib/rubocop/cop/style/string_literals.rb +1 -5
  456. data/lib/rubocop/cop/style/string_literals_in_interpolation.rb +30 -5
  457. data/lib/rubocop/cop/style/struct_inheritance.rb +1 -1
  458. data/lib/rubocop/cop/style/symbol_array.rb +40 -19
  459. data/lib/rubocop/cop/style/symbol_proc.rb +42 -10
  460. data/lib/rubocop/cop/style/ternary_parentheses.rb +1 -13
  461. data/lib/rubocop/cop/style/top_level_method_definition.rb +5 -1
  462. data/lib/rubocop/cop/style/trailing_body_on_class.rb +1 -0
  463. data/lib/rubocop/cop/style/trailing_comma_in_arguments.rb +4 -4
  464. data/lib/rubocop/cop/style/trailing_comma_in_block_args.rb +1 -1
  465. data/lib/rubocop/cop/style/trailing_underscore_variable.rb +1 -1
  466. data/lib/rubocop/cop/style/trivial_accessors.rb +4 -1
  467. data/lib/rubocop/cop/style/unless_logical_operators.rb +1 -0
  468. data/lib/rubocop/cop/style/unpack_first.rb +3 -3
  469. data/lib/rubocop/cop/style/word_array.rb +59 -5
  470. data/lib/rubocop/cop/style/yaml_file_read.rb +66 -0
  471. data/lib/rubocop/cop/style/yoda_condition.rb +17 -8
  472. data/lib/rubocop/cop/style/yoda_expression.rb +91 -0
  473. data/lib/rubocop/cop/style/zero_length_predicate.rb +40 -19
  474. data/lib/rubocop/cop/team.rb +63 -56
  475. data/lib/rubocop/cop/util.rb +45 -9
  476. data/lib/rubocop/cop/utils/regexp_ranges.rb +113 -0
  477. data/lib/rubocop/cop/variable_force/assignment.rb +45 -4
  478. data/lib/rubocop/cop/variable_force/scope.rb +3 -3
  479. data/lib/rubocop/cop/variable_force/variable.rb +5 -3
  480. data/lib/rubocop/cop/variable_force/variable_table.rb +6 -4
  481. data/lib/rubocop/cop/variable_force.rb +19 -30
  482. data/lib/rubocop/cops_documentation_generator.rb +45 -15
  483. data/lib/rubocop/directive_comment.rb +4 -4
  484. data/lib/rubocop/ext/comment.rb +18 -0
  485. data/lib/rubocop/ext/processed_source.rb +2 -0
  486. data/lib/rubocop/ext/range.rb +15 -0
  487. data/lib/rubocop/ext/regexp_node.rb +1 -1
  488. data/lib/rubocop/ext/regexp_parser.rb +5 -2
  489. data/lib/rubocop/feature_loader.rb +94 -0
  490. data/lib/rubocop/file_finder.rb +4 -7
  491. data/lib/rubocop/file_patterns.rb +43 -0
  492. data/lib/rubocop/formatter/clang_style_formatter.rb +1 -1
  493. data/lib/rubocop/formatter/disabled_config_formatter.rb +26 -9
  494. data/lib/rubocop/formatter/html_formatter.rb +4 -4
  495. data/lib/rubocop/formatter/junit_formatter.rb +4 -1
  496. data/lib/rubocop/formatter/markdown_formatter.rb +1 -1
  497. data/lib/rubocop/formatter/offense_count_formatter.rb +8 -5
  498. data/lib/rubocop/formatter/simple_text_formatter.rb +1 -1
  499. data/lib/rubocop/formatter/tap_formatter.rb +1 -1
  500. data/lib/rubocop/formatter/worst_offenders_formatter.rb +6 -3
  501. data/lib/rubocop/formatter.rb +4 -1
  502. data/lib/rubocop/lsp/logger.rb +22 -0
  503. data/lib/rubocop/lsp/routes.rb +246 -0
  504. data/lib/rubocop/lsp/runtime.rb +99 -0
  505. data/lib/rubocop/lsp/server.rb +68 -0
  506. data/lib/rubocop/lsp/severity.rb +27 -0
  507. data/lib/rubocop/magic_comment.rb +12 -10
  508. data/lib/rubocop/options.rb +66 -23
  509. data/lib/rubocop/path_util.rb +50 -22
  510. data/lib/rubocop/result_cache.rb +30 -24
  511. data/lib/rubocop/rspec/cop_helper.rb +26 -3
  512. data/lib/rubocop/rspec/expect_offense.rb +6 -4
  513. data/lib/rubocop/rspec/shared_contexts.rb +33 -17
  514. data/lib/rubocop/rspec/support.rb +17 -2
  515. data/lib/rubocop/runner.rb +78 -21
  516. data/lib/rubocop/server/cache.rb +49 -2
  517. data/lib/rubocop/server/cli.rb +62 -19
  518. data/lib/rubocop/server/client_command/base.rb +1 -1
  519. data/lib/rubocop/server/client_command/exec.rb +9 -3
  520. data/lib/rubocop/server/client_command/start.rb +6 -1
  521. data/lib/rubocop/server/core.rb +42 -10
  522. data/lib/rubocop/server/helper.rb +1 -1
  523. data/lib/rubocop/server/server_command/exec.rb +1 -1
  524. data/lib/rubocop/server/socket_reader.rb +5 -1
  525. data/lib/rubocop/server.rb +1 -1
  526. data/lib/rubocop/string_interpreter.rb +3 -3
  527. data/lib/rubocop/target_finder.rb +8 -4
  528. data/lib/rubocop/target_ruby.rb +14 -10
  529. data/lib/rubocop/version.rb +17 -7
  530. data/lib/rubocop.rb +58 -8
  531. metadata +110 -39
  532. data/lib/rubocop/cop/mixin/ignored_methods.rb +0 -52
@@ -14,8 +14,14 @@ module RuboCop
14
14
  #
15
15
  # # good
16
16
  # def foo(x, y = 1)
17
+ # # Alternatives to `__callee__` are `__method__` and `:foo`.
17
18
  # return to_enum(__callee__, x, y)
18
- # # alternatives to `__callee__` are `__method__` and `:foo`
19
+ # end
20
+ #
21
+ # # good
22
+ # def foo(x, y = 1)
23
+ # # It is also allowed if it is wrapped in some method like Sorbet.
24
+ # return to_enum(T.must(__callee__), x, y)
19
25
  # end
20
26
  #
21
27
  class ToEnumArguments < Base
@@ -43,8 +49,12 @@ module RuboCop
43
49
  return unless def_node
44
50
 
45
51
  enum_conversion_call?(node) do |method_node, arguments|
46
- add_offense(node) unless method_name?(method_node, def_node.method_name) &&
47
- arguments_match?(arguments, def_node)
52
+ next if method_node.call_type? &&
53
+ !method_node.method?(:__method__) && !method_node.method?(:__callee__)
54
+ next if method_name?(method_node, def_node.method_name) &&
55
+ arguments_match?(arguments, def_node)
56
+
57
+ add_offense(node)
48
58
  end
49
59
  end
50
60
 
@@ -64,7 +74,7 @@ module RuboCop
64
74
  end
65
75
  end
66
76
 
67
- # rubocop:disable Metrics/AbcSize, Metrics/CyclomaticComplexity
77
+ # rubocop:disable Metrics/AbcSize, Metrics/CyclomaticComplexity, Metrics/MethodLength
68
78
  def argument_match?(send_arg, def_arg)
69
79
  def_arg_name = def_arg.children[0]
70
80
 
@@ -77,12 +87,14 @@ module RuboCop
77
87
  send_arg.hash_type? &&
78
88
  send_arg.pairs.any? { |pair| passing_keyword_arg?(pair, def_arg_name) }
79
89
  when :kwrestarg
80
- send_arg.each_child_node(:kwsplat).any? { |child| child.source == def_arg.source }
90
+ send_arg.each_child_node(:kwsplat, :forwarded_kwrestarg).any? do |child|
91
+ child.source == def_arg.source
92
+ end
81
93
  when :forward_arg
82
94
  send_arg.forwarded_args_type?
83
95
  end
84
96
  end
85
- # rubocop:enable Metrics/AbcSize, Metrics/CyclomaticComplexity
97
+ # rubocop:enable Metrics/AbcSize, Metrics/CyclomaticComplexity, Metrics/MethodLength
86
98
  end
87
99
  end
88
100
  end
@@ -8,25 +8,39 @@ module RuboCop
8
8
  # always ignored. This is detected automatically since Ruby 2.7.
9
9
  #
10
10
  # @example
11
+ # # bad
12
+ # return 1
11
13
  #
12
- # # Detected since Ruby 2.7
13
- # return 1 # 1 is always ignored.
14
+ # # good
15
+ # return
14
16
  class TopLevelReturnWithArgument < Base
15
- # This cop works by validating the ancestors of the return node. A
16
- # top-level return node's ancestors should not be of block, def, or
17
- # defs type.
17
+ extend AutoCorrector
18
18
 
19
19
  MSG = 'Top level return with argument detected.'
20
20
 
21
21
  def on_return(return_node)
22
- add_offense(return_node) if return_node.arguments? && ancestors_valid?(return_node)
22
+ return unless top_level_return_with_any_argument?(return_node)
23
+
24
+ add_offense(return_node) do |corrector|
25
+ remove_arguments(corrector, return_node)
26
+ end
23
27
  end
24
28
 
25
29
  private
26
30
 
27
- def ancestors_valid?(return_node)
28
- prohibited_ancestors = return_node.each_ancestor(:block, :def, :defs)
29
- prohibited_ancestors.none?
31
+ def top_level_return_with_any_argument?(return_node)
32
+ top_level_return?(return_node) && return_node.arguments?
33
+ end
34
+
35
+ def remove_arguments(corrector, return_node)
36
+ corrector.replace(return_node, 'return')
37
+ end
38
+
39
+ # This cop works by validating the ancestors of the return node. A
40
+ # top-level return node's ancestors should not be of block, def, or
41
+ # defs type.
42
+ def top_level_return?(return_node)
43
+ return_node.each_ancestor(:block, :def, :defs).none?
30
44
  end
31
45
  end
32
46
  end
@@ -9,7 +9,7 @@ module RuboCop
9
9
  # In rare cases where only one iteration (or at most one iteration) is intended behavior,
10
10
  # the code should be refactored to use `if` conditionals.
11
11
  #
12
- # NOTE: Block methods that are used with `Enumerable`s are considered to be loops.
12
+ # NOTE: Block methods that are used with ``Enumerable``s are considered to be loops.
13
13
  #
14
14
  # `AllowedPatterns` can be used to match against the block receiver in order to allow
15
15
  # code that would otherwise be registered as an offense (eg. `times` used not in an
@@ -79,7 +79,7 @@ module RuboCop
79
79
  # # bad
80
80
  # 2.times { raise ArgumentError }
81
81
  #
82
- # @example AllowedPatterns: [/(exactly|at_least|at_most)\(\d+\)\.times/] (default)
82
+ # @example AllowedPatterns: ['(exactly|at_least|at_most)\(\d+\)\.times'] (default)
83
83
  #
84
84
  # # good
85
85
  # exactly(2).times { raise StandardError }
@@ -101,15 +101,19 @@ module RuboCop
101
101
  check(node) if loop_method?(node)
102
102
  end
103
103
 
104
+ def on_numblock(node)
105
+ check(node) if loop_method?(node)
106
+ end
107
+
104
108
  private
105
109
 
106
110
  def loop_method?(node)
107
- return false unless node.block_type?
111
+ return false unless node.block_type? || node.numblock_type?
108
112
 
109
113
  send_node = node.send_node
110
- return false if matches_allowed_pattern?(send_node.source)
111
-
112
- send_node.enumerable_method? || send_node.enumerator_method? || send_node.method?(:loop)
114
+ loopable = send_node.enumerable_method? || send_node.enumerator_method? ||
115
+ send_node.method?(:loop)
116
+ loopable && !matches_allowed_pattern?(send_node.source)
113
117
  end
114
118
 
115
119
  def check(node)
@@ -179,6 +183,8 @@ module RuboCop
179
183
 
180
184
  def preceded_by_continue_statement?(break_statement)
181
185
  break_statement.left_siblings.any? do |sibling|
186
+ # Numblocks have the arguments count as a number in the AST.
187
+ next if sibling.is_a?(Integer)
182
188
  next if sibling.loop_keyword? || loop_method?(sibling)
183
189
 
184
190
  sibling.each_descendant(*CONTINUE_KEYWORDS).any?
@@ -68,6 +68,10 @@ module RuboCop
68
68
  (send nil? :fail ...)}
69
69
  PATTERN
70
70
 
71
+ def self.autocorrect_incompatible_with
72
+ [Style::ExplicitBlockArgument]
73
+ end
74
+
71
75
  def self.joining_forces
72
76
  VariableForce
73
77
  end
@@ -96,7 +100,8 @@ module RuboCop
96
100
 
97
101
  unless variable.keyword_argument?
98
102
  message << " If it's necessary, use `_` or `_#{variable.name}` " \
99
- "as an argument name to indicate that it won't be used."
103
+ "as an argument name to indicate that it won't be used. " \
104
+ "If it's unnecessary, remove it."
100
105
  end
101
106
 
102
107
  scope = variable.scope
@@ -31,8 +31,8 @@ module RuboCop
31
31
  # # bad
32
32
  # class Foo
33
33
  # # The following is redundant (methods defined on the class'
34
- # # singleton class are not affected by the public modifier)
35
- # public
34
+ # # singleton class are not affected by the private modifier)
35
+ # private
36
36
  #
37
37
  # def self.method3
38
38
  # end
@@ -137,11 +137,13 @@ module RuboCop
137
137
  alias on_sclass on_class
138
138
 
139
139
  def on_block(node)
140
- return unless eval_call?(node)
140
+ return unless eval_call?(node) || included_block?(node)
141
141
 
142
142
  check_node(node.body)
143
143
  end
144
144
 
145
+ alias on_numblock on_block
146
+
145
147
  private
146
148
 
147
149
  def autocorrect(corrector, node)
@@ -157,17 +159,12 @@ module RuboCop
157
159
 
158
160
  # @!method dynamic_method_definition?(node)
159
161
  def_node_matcher :dynamic_method_definition?, <<~PATTERN
160
- {(send nil? :define_method ...) (block (send nil? :define_method ...) ...)}
162
+ {(send nil? :define_method ...) ({block numblock} (send nil? :define_method ...) ...)}
161
163
  PATTERN
162
164
 
163
165
  # @!method class_or_instance_eval?(node)
164
166
  def_node_matcher :class_or_instance_eval?, <<~PATTERN
165
- (block (send _ {:class_eval :instance_eval}) ...)
166
- PATTERN
167
-
168
- # @!method class_or_module_or_struct_new_call?(node)
169
- def_node_matcher :class_or_module_or_struct_new_call?, <<~PATTERN
170
- (block (send (const {nil? cbase} {:Class :Module :Struct}) :new ...) ...)
167
+ ({block numblock} (send _ {:class_eval :instance_eval}) ...)
171
168
  PATTERN
172
169
 
173
170
  def check_node(node)
@@ -195,10 +192,13 @@ module RuboCop
195
192
  end
196
193
  end
197
194
 
195
+ # rubocop:disable Metrics/CyclomaticComplexity, Metrics/PerceivedComplexity
198
196
  def check_child_nodes(node, unused, cur_vis)
199
197
  node.child_nodes.each do |child|
200
198
  if child.send_type? && access_modifier?(child)
201
199
  cur_vis, unused = check_send_node(child, cur_vis, unused)
200
+ elsif child.block_type? && included_block?(child)
201
+ next
202
202
  elsif method_definition?(child)
203
203
  unused = nil
204
204
  elsif start_of_new_scope?(child)
@@ -210,6 +210,7 @@ module RuboCop
210
210
 
211
211
  [cur_vis, unused]
212
212
  end
213
+ # rubocop:enable Metrics/CyclomaticComplexity, Metrics/PerceivedComplexity
213
214
 
214
215
  def check_send_node(node, cur_vis, unused)
215
216
  if node.bare_access_modifier?
@@ -243,6 +244,10 @@ module RuboCop
243
244
  [new_vis, unused]
244
245
  end
245
246
 
247
+ def included_block?(block_node)
248
+ active_support_extensions_enabled? && block_node.method?(:included)
249
+ end
250
+
246
251
  def method_definition?(child)
247
252
  static_method_definition?(child) ||
248
253
  dynamic_method_definition?(child) ||
@@ -268,7 +273,7 @@ module RuboCop
268
273
 
269
274
  def eval_call?(child)
270
275
  class_or_instance_eval?(child) ||
271
- class_or_module_or_struct_new_call?(child) ||
276
+ child.class_constructor? ||
272
277
  any_context_creating_methods?(child)
273
278
  end
274
279
 
@@ -277,7 +282,7 @@ module RuboCop
277
282
  matcher_name = "#{m}_block?".to_sym
278
283
  unless respond_to?(matcher_name)
279
284
  self.class.def_node_matcher matcher_name, <<~PATTERN
280
- (block (send {nil? const} {:#{m}} ...) ...)
285
+ ({block numblock} (send {nil? const} {:#{m}} ...) ...)
281
286
  PATTERN
282
287
  end
283
288
 
@@ -7,12 +7,24 @@ module RuboCop
7
7
  # scope.
8
8
  # The basic idea for this cop was from the warning of `ruby -cw`:
9
9
  #
10
- # assigned but unused variable - foo
10
+ # [source,console]
11
+ # ----
12
+ # assigned but unused variable - foo
13
+ # ----
11
14
  #
12
15
  # Currently this cop has advanced logic that detects unreferenced
13
16
  # reassignments and properly handles varied cases such as branch, loop,
14
17
  # rescue, ensure, etc.
15
18
  #
19
+ # NOTE: Given the assignment `foo = 1, bar = 2`, removing unused variables
20
+ # can lead to a syntax error, so this case is not autocorrected.
21
+ #
22
+ # @safety
23
+ # This cop's autocorrection is unsafe because removing assignment from
24
+ # operator assignment can cause NameError if this assignment has been used to declare
25
+ # local variable. For example, replacing `a ||= 1` to `a || 1` may cause
26
+ # "undefined local variable or method `a' for main:Object (NameError)".
27
+ #
16
28
  # @example
17
29
  #
18
30
  # # bad
@@ -31,6 +43,10 @@ module RuboCop
31
43
  # do_something(some_var)
32
44
  # end
33
45
  class UselessAssignment < Base
46
+ extend AutoCorrector
47
+
48
+ include RangeHelp
49
+
34
50
  MSG = 'Useless assignment to variable - `%<variable>s`.'
35
51
 
36
52
  def self.joining_forces
@@ -41,23 +57,24 @@ module RuboCop
41
57
  scope.variables.each_value { |variable| check_for_unused_assignments(variable) }
42
58
  end
43
59
 
60
+ # rubocop:disable Metrics/AbcSize
44
61
  def check_for_unused_assignments(variable)
45
62
  return if variable.should_be_unused?
46
63
 
47
64
  variable.assignments.each do |assignment|
48
- next if assignment.used?
65
+ next if assignment.used? || part_of_ignored_node?(assignment.node)
49
66
 
50
67
  message = message_for_useless_assignment(assignment)
68
+ range = offense_range(assignment)
51
69
 
52
- location = if assignment.regexp_named_capture?
53
- assignment.node.children.first.source_range
54
- else
55
- assignment.node.loc.name
56
- end
70
+ add_offense(range, message: message) do |corrector|
71
+ autocorrect(corrector, assignment) unless sequential_assignment?(assignment.node)
72
+ end
57
73
 
58
- add_offense(location, message: message)
74
+ ignore_node(assignment.node) if chained_assignment?(assignment.node)
59
75
  end
60
76
  end
77
+ # rubocop:enable Metrics/AbcSize
61
78
 
62
79
  def message_for_useless_assignment(assignment)
63
80
  variable = assignment.variable
@@ -65,6 +82,28 @@ module RuboCop
65
82
  format(MSG, variable: variable.name) + message_specification(assignment, variable).to_s
66
83
  end
67
84
 
85
+ def offense_range(assignment)
86
+ if assignment.regexp_named_capture?
87
+ assignment.node.children.first.source_range
88
+ else
89
+ assignment.node.loc.name
90
+ end
91
+ end
92
+
93
+ def sequential_assignment?(node)
94
+ if node.lvasgn_type? && node.expression&.array_type? &&
95
+ node.each_descendant.any?(&:assignment?)
96
+ return true
97
+ end
98
+ return false unless node.parent
99
+
100
+ sequential_assignment?(node.parent)
101
+ end
102
+
103
+ def chained_assignment?(node)
104
+ node.respond_to?(:expression) && node.expression&.lvasgn_type?
105
+ end
106
+
68
107
  def message_specification(assignment, variable)
69
108
  if assignment.multiple_assignment?
70
109
  multiple_assignment_message(variable.name)
@@ -84,8 +123,7 @@ module RuboCop
84
123
  return_value_node = return_value_node_of_scope(scope)
85
124
  return unless assignment.meta_assignment_node.equal?(return_value_node)
86
125
 
87
- " Use `#{assignment.operator.sub(/=$/, '')}` " \
88
- "instead of `#{assignment.operator}`."
126
+ " Use `#{assignment.operator.delete_suffix('=')}` instead of `#{assignment.operator}`."
89
127
  end
90
128
 
91
129
  def similar_name_message(variable)
@@ -119,6 +157,52 @@ module RuboCop
119
157
 
120
158
  node.receiver.nil? && !node.arguments?
121
159
  end
160
+
161
+ # rubocop:disable Metrics/AbcSize
162
+ def autocorrect(corrector, assignment)
163
+ if assignment.exception_assignment?
164
+ remove_exception_assignment_part(corrector, assignment.node)
165
+ elsif assignment.multiple_assignment? || assignment.rest_assignment? ||
166
+ assignment.for_assignment?
167
+ rename_variable_with_underscore(corrector, assignment.node)
168
+ elsif assignment.operator_assignment?
169
+ remove_trailing_character_from_operator(corrector, assignment.node)
170
+ elsif assignment.regexp_named_capture?
171
+ replace_named_capture_group_with_non_capturing_group(corrector, assignment.node,
172
+ assignment.variable.name)
173
+ else
174
+ remove_local_variable_assignment_part(corrector, assignment.node)
175
+ end
176
+ end
177
+ # rubocop:enable Metrics/AbcSize
178
+
179
+ def remove_exception_assignment_part(corrector, node)
180
+ corrector.remove(
181
+ range_between(
182
+ (node.parent.children.first&.source_range || node.parent.location.keyword).end_pos,
183
+ node.source_range.end_pos
184
+ )
185
+ )
186
+ end
187
+
188
+ def rename_variable_with_underscore(corrector, node)
189
+ corrector.replace(node, '_')
190
+ end
191
+
192
+ def remove_trailing_character_from_operator(corrector, node)
193
+ corrector.remove(node.parent.location.operator.end.adjust(begin_pos: -1))
194
+ end
195
+
196
+ def replace_named_capture_group_with_non_capturing_group(corrector, node, variable_name)
197
+ corrector.replace(
198
+ node.children.first,
199
+ node.children.first.source.sub(/\(\?<#{variable_name}>/, '(?:')
200
+ )
201
+ end
202
+
203
+ def remove_local_variable_assignment_part(corrector, node)
204
+ corrector.replace(node, node.expression.source)
205
+ end
122
206
  end
123
207
  end
124
208
  end
@@ -41,17 +41,25 @@ module RuboCop
41
41
  MSG = 'Useless method definition detected.'
42
42
 
43
43
  def on_def(node)
44
- return if optional_args?(node)
44
+ return if method_definition_with_modifier?(node) || use_rest_or_optional_args?(node)
45
45
  return unless delegating?(node.body, node)
46
46
 
47
- add_offense(node) { |corrector| corrector.remove(node) }
47
+ add_offense(node) do |corrector|
48
+ range = node.parent&.send_type? ? node.parent : node
49
+
50
+ corrector.remove(range)
51
+ end
48
52
  end
49
53
  alias on_defs on_def
50
54
 
51
55
  private
52
56
 
53
- def optional_args?(node)
54
- node.arguments.any? { |arg| arg.optarg_type? || arg.kwoptarg_type? }
57
+ def method_definition_with_modifier?(node)
58
+ node.parent&.send_type? && !node.parent&.non_bare_access_modifier?
59
+ end
60
+
61
+ def use_rest_or_optional_args?(node)
62
+ node.arguments.any? { |arg| arg.restarg_type? || arg.optarg_type? || arg.kwoptarg_type? }
55
63
  end
56
64
 
57
65
  def delegating?(node, def_node)
@@ -0,0 +1,89 @@
1
+ # frozen_string_literal: true
2
+
3
+ module RuboCop
4
+ module Cop
5
+ module Lint
6
+ # Checks for useless `rescue`s, which only reraise rescued exceptions.
7
+ #
8
+ # @example
9
+ # # bad
10
+ # def foo
11
+ # do_something
12
+ # rescue
13
+ # raise
14
+ # end
15
+ #
16
+ # # bad
17
+ # def foo
18
+ # do_something
19
+ # rescue => e
20
+ # raise # or 'raise e', or 'raise $!', or 'raise $ERROR_INFO'
21
+ # end
22
+ #
23
+ # # good
24
+ # def foo
25
+ # do_something
26
+ # rescue
27
+ # do_cleanup
28
+ # raise
29
+ # end
30
+ #
31
+ # # bad (latest rescue)
32
+ # def foo
33
+ # do_something
34
+ # rescue ArgumentError
35
+ # # noop
36
+ # rescue
37
+ # raise
38
+ # end
39
+ #
40
+ # # good (not the latest rescue)
41
+ # def foo
42
+ # do_something
43
+ # rescue ArgumentError
44
+ # raise
45
+ # rescue
46
+ # # noop
47
+ # end
48
+ #
49
+ class UselessRescue < Base
50
+ MSG = 'Useless `rescue` detected.'
51
+
52
+ def on_rescue(node)
53
+ resbody_node = node.resbody_branches.last
54
+ add_offense(resbody_node) if only_reraising?(resbody_node)
55
+ end
56
+
57
+ private
58
+
59
+ # rubocop:disable Metrics/AbcSize, Metrics/CyclomaticComplexity
60
+ def only_reraising?(resbody_node)
61
+ return false if use_exception_variable_in_ensure?(resbody_node)
62
+
63
+ body = resbody_node.body
64
+
65
+ return false if body.nil? || !body.send_type? || !body.method?(:raise) || body.receiver
66
+ return true unless body.arguments?
67
+ return false if body.arguments.size > 1
68
+
69
+ exception_name = body.first_argument.source
70
+
71
+ exception_objects(resbody_node).include?(exception_name)
72
+ end
73
+ # rubocop:enable Metrics/AbcSize, Metrics/CyclomaticComplexity
74
+
75
+ def use_exception_variable_in_ensure?(resbody_node)
76
+ return false unless (exception_variable = resbody_node.exception_variable)
77
+ return false unless (ensure_node = resbody_node.each_ancestor(:ensure).first)
78
+ return false unless (ensure_body = ensure_node.body)
79
+
80
+ ensure_body.each_descendant(:lvar).map(&:source).include?(exception_variable.source)
81
+ end
82
+
83
+ def exception_objects(resbody_node)
84
+ [resbody_node.exception_variable&.source, '$!', '$ERROR_INFO']
85
+ end
86
+ end
87
+ end
88
+ end
89
+ end
@@ -6,7 +6,7 @@ module RuboCop
6
6
  # Looks for `ruby2_keywords` calls for methods that do not need it.
7
7
  #
8
8
  # `ruby2_keywords` should only be called on methods that accept an argument splat
9
- # (`*args`) but do not explicit keyword arguments (`k:` or `k: true`) or
9
+ # (`\*args`) but do not explicit keyword arguments (`k:` or `k: true`) or
10
10
  # a keyword splat (`**kwargs`).
11
11
  #
12
12
  # @example
@@ -77,10 +77,12 @@ module RuboCop
77
77
  PATTERN
78
78
 
79
79
  def on_send(node)
80
- if node.first_argument.def_type?
81
- inspect_def(node, node.first_argument)
80
+ return unless (first_argument = node.first_argument)
81
+
82
+ if first_argument.def_type?
83
+ inspect_def(node, first_argument)
82
84
  elsif node.first_argument.sym_type?
83
- inspect_sym(node, node.first_argument)
85
+ inspect_sym(node, first_argument)
84
86
  end
85
87
  end
86
88
 
@@ -96,7 +98,7 @@ module RuboCop
96
98
  return unless node.parent
97
99
 
98
100
  method_name = sym_node.value
99
- definition = node.parent.each_child_node.detect { |n| method_definition(n, method_name) }
101
+ definition = find_method_definition(node, method_name)
100
102
 
101
103
  return unless definition
102
104
  return if allowed_arguments(definition.arguments)
@@ -104,6 +106,14 @@ module RuboCop
104
106
  add_offense(node, message: format(MSG, method_name: method_name))
105
107
  end
106
108
 
109
+ def find_method_definition(node, method_name)
110
+ node.each_ancestor.lazy.map do |ancestor|
111
+ ancestor.each_child_node(:def, :block, :numblock).find do |child|
112
+ method_definition(child, method_name)
113
+ end
114
+ end.find(&:itself)
115
+ end
116
+
107
117
  # `ruby2_keywords` is only allowed if there's a `restarg` and no keyword arguments
108
118
  def allowed_arguments(arguments)
109
119
  return false if arguments.empty?
@@ -74,7 +74,7 @@ module RuboCop
74
74
  end
75
75
 
76
76
  def remove_node(corrector, node)
77
- corrector.remove(range_by_whole_lines(node.loc.expression, include_final_newline: true))
77
+ corrector.remove(range_by_whole_lines(node.source_range, include_final_newline: true))
78
78
  end
79
79
 
80
80
  def autocorrect_block_pass(corrector, node, proc_name)