rubocop 1.26.0 → 1.36.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (588) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +7 -5
  3. data/config/default.yml +254 -47
  4. data/config/obsoletion.yml +35 -2
  5. data/exe/rubocop +15 -7
  6. data/lib/rubocop/cache_config.rb +29 -0
  7. data/lib/rubocop/cli/command/{auto_genenerate_config.rb → auto_generate_config.rb} +20 -5
  8. data/lib/rubocop/cli/command/execute_runner.rb +1 -1
  9. data/lib/rubocop/cli/command/init_dotfile.rb +1 -1
  10. data/lib/rubocop/cli/command/show_cops.rb +1 -1
  11. data/lib/rubocop/cli/command/suggest_extensions.rb +54 -16
  12. data/lib/rubocop/cli.rb +2 -0
  13. data/lib/rubocop/config.rb +6 -2
  14. data/lib/rubocop/config_finder.rb +68 -0
  15. data/lib/rubocop/config_loader.rb +15 -41
  16. data/lib/rubocop/config_loader_resolver.rb +2 -6
  17. data/lib/rubocop/config_obsoletion/changed_parameter.rb +5 -0
  18. data/lib/rubocop/config_obsoletion/extracted_cop.rb +3 -1
  19. data/lib/rubocop/config_obsoletion/parameter_rule.rb +4 -0
  20. data/lib/rubocop/config_obsoletion.rb +7 -2
  21. data/lib/rubocop/config_validator.rb +21 -4
  22. data/lib/rubocop/cop/autocorrect_logic.rb +8 -2
  23. data/lib/rubocop/cop/badge.rb +1 -1
  24. data/lib/rubocop/cop/base.rb +6 -2
  25. data/lib/rubocop/cop/bundler/duplicated_gem.rb +3 -7
  26. data/lib/rubocop/cop/bundler/gem_comment.rb +1 -1
  27. data/lib/rubocop/cop/bundler/gem_filename.rb +5 -5
  28. data/lib/rubocop/cop/bundler/ordered_gems.rb +2 -2
  29. data/lib/rubocop/cop/cop.rb +1 -1
  30. data/lib/rubocop/cop/corrector.rb +2 -2
  31. data/lib/rubocop/cop/correctors/alignment_corrector.rb +1 -1
  32. data/lib/rubocop/cop/correctors/condition_corrector.rb +1 -1
  33. data/lib/rubocop/cop/correctors/each_to_for_corrector.rb +1 -1
  34. data/lib/rubocop/cop/correctors/empty_line_corrector.rb +1 -1
  35. data/lib/rubocop/cop/correctors/for_to_each_corrector.rb +4 -2
  36. data/lib/rubocop/cop/correctors/if_then_corrector.rb +1 -1
  37. data/lib/rubocop/cop/correctors/lambda_literal_to_method_corrector.rb +1 -1
  38. data/lib/rubocop/cop/correctors/line_break_corrector.rb +7 -1
  39. data/lib/rubocop/cop/correctors/multiline_literal_brace_corrector.rb +3 -3
  40. data/lib/rubocop/cop/correctors/ordered_gem_corrector.rb +1 -1
  41. data/lib/rubocop/cop/correctors/parentheses_corrector.rb +59 -1
  42. data/lib/rubocop/cop/correctors/percent_literal_corrector.rb +1 -1
  43. data/lib/rubocop/cop/correctors/punctuation_corrector.rb +1 -1
  44. data/lib/rubocop/cop/correctors/space_corrector.rb +1 -1
  45. data/lib/rubocop/cop/correctors/string_literal_corrector.rb +1 -1
  46. data/lib/rubocop/cop/correctors/unused_arg_corrector.rb +2 -2
  47. data/lib/rubocop/cop/gemspec/dependency_version.rb +156 -0
  48. data/lib/rubocop/cop/gemspec/deprecated_attribute_assignment.rb +92 -0
  49. data/lib/rubocop/cop/gemspec/duplicated_assignment.rb +5 -12
  50. data/lib/rubocop/cop/gemspec/ordered_dependencies.rb +1 -1
  51. data/lib/rubocop/cop/gemspec/require_mfa.rb +21 -21
  52. data/lib/rubocop/cop/gemspec/ruby_version_globals_usage.rb +1 -1
  53. data/lib/rubocop/cop/generator/require_file_injector.rb +2 -2
  54. data/lib/rubocop/cop/generator.rb +5 -1
  55. data/lib/rubocop/cop/internal_affairs/cop_description.rb +96 -0
  56. data/lib/rubocop/cop/internal_affairs/empty_line_between_expect_offense_and_correction.rb +1 -1
  57. data/lib/rubocop/cop/internal_affairs/location_line_equality_comparison.rb +1 -1
  58. data/lib/rubocop/cop/internal_affairs/method_name_end_with.rb +80 -0
  59. data/lib/rubocop/cop/internal_affairs/node_matcher_directive.rb +1 -5
  60. data/lib/rubocop/cop/internal_affairs/numblock_handler.rb +69 -0
  61. data/lib/rubocop/cop/internal_affairs/redundant_described_class_as_subject.rb +1 -1
  62. data/lib/rubocop/cop/internal_affairs/redundant_let_rubocop_config_new.rb +1 -1
  63. data/lib/rubocop/cop/internal_affairs/redundant_location_argument.rb +1 -1
  64. data/lib/rubocop/cop/internal_affairs/redundant_message_argument.rb +1 -1
  65. data/lib/rubocop/cop/internal_affairs/single_line_comparison.rb +62 -0
  66. data/lib/rubocop/cop/internal_affairs/useless_restrict_on_send.rb +60 -0
  67. data/lib/rubocop/cop/internal_affairs.rb +5 -0
  68. data/lib/rubocop/cop/layout/argument_alignment.rb +22 -1
  69. data/lib/rubocop/cop/layout/assignment_indentation.rb +1 -1
  70. data/lib/rubocop/cop/layout/begin_end_alignment.rb +1 -1
  71. data/lib/rubocop/cop/layout/block_alignment.rb +17 -13
  72. data/lib/rubocop/cop/layout/block_end_newline.rb +36 -6
  73. data/lib/rubocop/cop/layout/case_indentation.rb +17 -1
  74. data/lib/rubocop/cop/layout/closing_parenthesis_indentation.rb +1 -1
  75. data/lib/rubocop/cop/layout/comment_indentation.rb +2 -2
  76. data/lib/rubocop/cop/layout/condition_position.rb +1 -1
  77. data/lib/rubocop/cop/layout/def_end_alignment.rb +1 -1
  78. data/lib/rubocop/cop/layout/dot_position.rb +1 -1
  79. data/lib/rubocop/cop/layout/else_alignment.rb +1 -1
  80. data/lib/rubocop/cop/layout/empty_comment.rb +2 -2
  81. data/lib/rubocop/cop/layout/empty_line_after_guard_clause.rb +1 -1
  82. data/lib/rubocop/cop/layout/empty_line_after_multiline_condition.rb +1 -1
  83. data/lib/rubocop/cop/layout/empty_line_between_defs.rb +1 -1
  84. data/lib/rubocop/cop/layout/empty_lines.rb +1 -1
  85. data/lib/rubocop/cop/layout/empty_lines_around_access_modifier.rb +5 -2
  86. data/lib/rubocop/cop/layout/empty_lines_around_arguments.rb +1 -1
  87. data/lib/rubocop/cop/layout/empty_lines_around_attribute_accessor.rb +25 -4
  88. data/lib/rubocop/cop/layout/empty_lines_around_begin_body.rb +1 -1
  89. data/lib/rubocop/cop/layout/empty_lines_around_block_body.rb +7 -5
  90. data/lib/rubocop/cop/layout/empty_lines_around_class_body.rb +10 -10
  91. data/lib/rubocop/cop/layout/empty_lines_around_exception_handling_keywords.rb +1 -1
  92. data/lib/rubocop/cop/layout/empty_lines_around_method_body.rb +1 -1
  93. data/lib/rubocop/cop/layout/empty_lines_around_module_body.rb +10 -10
  94. data/lib/rubocop/cop/layout/end_alignment.rb +1 -1
  95. data/lib/rubocop/cop/layout/end_of_line.rb +5 -5
  96. data/lib/rubocop/cop/layout/extra_spacing.rb +1 -1
  97. data/lib/rubocop/cop/layout/first_argument_indentation.rb +34 -29
  98. data/lib/rubocop/cop/layout/first_array_element_indentation.rb +21 -14
  99. data/lib/rubocop/cop/layout/first_array_element_line_break.rb +1 -1
  100. data/lib/rubocop/cop/layout/first_hash_element_indentation.rb +52 -13
  101. data/lib/rubocop/cop/layout/first_hash_element_line_break.rb +1 -1
  102. data/lib/rubocop/cop/layout/first_method_argument_line_break.rb +1 -1
  103. data/lib/rubocop/cop/layout/first_method_parameter_line_break.rb +1 -1
  104. data/lib/rubocop/cop/layout/first_parameter_indentation.rb +1 -1
  105. data/lib/rubocop/cop/layout/hash_alignment.rb +2 -0
  106. data/lib/rubocop/cop/layout/heredoc_argument_closing_parenthesis.rb +1 -1
  107. data/lib/rubocop/cop/layout/heredoc_indentation.rb +1 -1
  108. data/lib/rubocop/cop/layout/indentation_consistency.rb +1 -1
  109. data/lib/rubocop/cop/layout/indentation_style.rb +1 -1
  110. data/lib/rubocop/cop/layout/indentation_width.rb +16 -10
  111. data/lib/rubocop/cop/layout/initial_indentation.rb +2 -2
  112. data/lib/rubocop/cop/layout/leading_comment_space.rb +1 -1
  113. data/lib/rubocop/cop/layout/leading_empty_lines.rb +1 -1
  114. data/lib/rubocop/cop/layout/line_continuation_leading_space.rb +112 -0
  115. data/lib/rubocop/cop/layout/line_continuation_spacing.rb +130 -0
  116. data/lib/rubocop/cop/layout/line_end_string_concatenation_indentation.rb +2 -2
  117. data/lib/rubocop/cop/layout/line_length.rb +11 -6
  118. data/lib/rubocop/cop/layout/multiline_array_brace_layout.rb +1 -1
  119. data/lib/rubocop/cop/layout/multiline_array_line_breaks.rb +1 -1
  120. data/lib/rubocop/cop/layout/multiline_assignment_layout.rb +2 -2
  121. data/lib/rubocop/cop/layout/multiline_block_layout.rb +4 -2
  122. data/lib/rubocop/cop/layout/multiline_hash_brace_layout.rb +1 -1
  123. data/lib/rubocop/cop/layout/multiline_hash_key_line_breaks.rb +1 -1
  124. data/lib/rubocop/cop/layout/multiline_method_argument_line_breaks.rb +5 -2
  125. data/lib/rubocop/cop/layout/multiline_method_call_brace_layout.rb +1 -1
  126. data/lib/rubocop/cop/layout/multiline_method_call_indentation.rb +22 -5
  127. data/lib/rubocop/cop/layout/multiline_method_definition_brace_layout.rb +1 -1
  128. data/lib/rubocop/cop/layout/multiline_method_parameter_line_breaks.rb +45 -0
  129. data/lib/rubocop/cop/layout/multiline_operation_indentation.rb +3 -3
  130. data/lib/rubocop/cop/layout/redundant_line_break.rb +5 -6
  131. data/lib/rubocop/cop/layout/rescue_ensure_alignment.rb +1 -1
  132. data/lib/rubocop/cop/layout/single_line_block_chain.rb +1 -1
  133. data/lib/rubocop/cop/layout/space_after_not.rb +1 -1
  134. data/lib/rubocop/cop/layout/space_around_block_parameters.rb +3 -3
  135. data/lib/rubocop/cop/layout/space_around_keyword.rb +1 -1
  136. data/lib/rubocop/cop/layout/space_around_operators.rb +1 -1
  137. data/lib/rubocop/cop/layout/space_before_block_braces.rb +5 -3
  138. data/lib/rubocop/cop/layout/space_before_brackets.rb +7 -0
  139. data/lib/rubocop/cop/layout/space_before_comment.rb +1 -1
  140. data/lib/rubocop/cop/layout/space_before_first_arg.rb +1 -1
  141. data/lib/rubocop/cop/layout/space_in_lambda_literal.rb +1 -1
  142. data/lib/rubocop/cop/layout/space_inside_array_literal_brackets.rb +10 -10
  143. data/lib/rubocop/cop/layout/space_inside_block_braces.rb +33 -15
  144. data/lib/rubocop/cop/layout/space_inside_reference_brackets.rb +1 -1
  145. data/lib/rubocop/cop/layout/space_inside_string_interpolation.rb +1 -1
  146. data/lib/rubocop/cop/layout/trailing_empty_lines.rb +9 -9
  147. data/lib/rubocop/cop/layout/trailing_whitespace.rb +3 -3
  148. data/lib/rubocop/cop/legacy/corrections_proxy.rb +1 -1
  149. data/lib/rubocop/cop/legacy/corrector.rb +1 -1
  150. data/lib/rubocop/cop/lint/ambiguous_assignment.rb +1 -1
  151. data/lib/rubocop/cop/lint/ambiguous_block_association.rb +28 -7
  152. data/lib/rubocop/cop/lint/ambiguous_operator.rb +7 -7
  153. data/lib/rubocop/cop/lint/ambiguous_operator_precedence.rb +1 -1
  154. data/lib/rubocop/cop/lint/ambiguous_range.rb +5 -5
  155. data/lib/rubocop/cop/lint/ambiguous_regexp_literal.rb +1 -1
  156. data/lib/rubocop/cop/lint/assignment_in_condition.rb +1 -1
  157. data/lib/rubocop/cop/lint/binary_operator_with_identical_operands.rb +1 -1
  158. data/lib/rubocop/cop/lint/boolean_symbol.rb +1 -1
  159. data/lib/rubocop/cop/lint/circular_argument_reference.rb +1 -1
  160. data/lib/rubocop/cop/lint/constant_overwritten_in_rescue.rb +51 -0
  161. data/lib/rubocop/cop/lint/debugger.rb +27 -17
  162. data/lib/rubocop/cop/lint/deprecated_class_methods.rb +15 -9
  163. data/lib/rubocop/cop/lint/deprecated_constants.rb +1 -1
  164. data/lib/rubocop/cop/lint/disjunctive_assignment_in_constructor.rb +1 -1
  165. data/lib/rubocop/cop/lint/duplicate_branch.rb +1 -1
  166. data/lib/rubocop/cop/lint/duplicate_case_condition.rb +1 -1
  167. data/lib/rubocop/cop/lint/duplicate_elsif_condition.rb +1 -1
  168. data/lib/rubocop/cop/lint/duplicate_hash_key.rb +1 -1
  169. data/lib/rubocop/cop/lint/duplicate_methods.rb +1 -1
  170. data/lib/rubocop/cop/lint/duplicate_regexp_character_class_element.rb +1 -1
  171. data/lib/rubocop/cop/lint/duplicate_require.rb +11 -2
  172. data/lib/rubocop/cop/lint/duplicate_rescue_exception.rb +1 -1
  173. data/lib/rubocop/cop/lint/each_with_object_argument.rb +1 -1
  174. data/lib/rubocop/cop/lint/else_layout.rb +3 -3
  175. data/lib/rubocop/cop/lint/empty_block.rb +2 -2
  176. data/lib/rubocop/cop/lint/empty_class.rb +1 -1
  177. data/lib/rubocop/cop/lint/empty_conditional_body.rb +99 -3
  178. data/lib/rubocop/cop/lint/empty_ensure.rb +1 -1
  179. data/lib/rubocop/cop/lint/empty_expression.rb +1 -1
  180. data/lib/rubocop/cop/lint/empty_file.rb +1 -1
  181. data/lib/rubocop/cop/lint/empty_in_pattern.rb +4 -2
  182. data/lib/rubocop/cop/lint/empty_interpolation.rb +1 -1
  183. data/lib/rubocop/cop/lint/empty_when.rb +4 -2
  184. data/lib/rubocop/cop/lint/ensure_return.rb +1 -1
  185. data/lib/rubocop/cop/lint/erb_new_arguments.rb +10 -10
  186. data/lib/rubocop/cop/lint/flip_flop.rb +1 -1
  187. data/lib/rubocop/cop/lint/float_comparison.rb +1 -1
  188. data/lib/rubocop/cop/lint/float_out_of_range.rb +1 -1
  189. data/lib/rubocop/cop/lint/heredoc_method_call_position.rb +1 -1
  190. data/lib/rubocop/cop/lint/implicit_string_concatenation.rb +1 -1
  191. data/lib/rubocop/cop/lint/incompatible_io_select_with_fiber_scheduler.rb +11 -4
  192. data/lib/rubocop/cop/lint/ineffective_access_modifier.rb +1 -1
  193. data/lib/rubocop/cop/lint/inherit_exception.rb +1 -1
  194. data/lib/rubocop/cop/lint/interpolation_check.rb +2 -2
  195. data/lib/rubocop/cop/lint/lambda_without_literal_block.rb +10 -3
  196. data/lib/rubocop/cop/lint/literal_as_condition.rb +6 -1
  197. data/lib/rubocop/cop/lint/literal_in_interpolation.rb +5 -1
  198. data/lib/rubocop/cop/lint/loop.rb +2 -2
  199. data/lib/rubocop/cop/lint/missing_cop_enable_directive.rb +1 -1
  200. data/lib/rubocop/cop/lint/missing_super.rb +1 -1
  201. data/lib/rubocop/cop/lint/nested_method_definition.rb +1 -1
  202. data/lib/rubocop/cop/lint/nested_percent_literal.rb +1 -1
  203. data/lib/rubocop/cop/lint/next_without_accumulator.rb +25 -6
  204. data/lib/rubocop/cop/lint/non_atomic_file_operation.rb +157 -0
  205. data/lib/rubocop/cop/lint/non_deterministic_require_order.rb +17 -5
  206. data/lib/rubocop/cop/lint/non_local_exit_from_iterator.rb +1 -1
  207. data/lib/rubocop/cop/lint/number_conversion.rb +32 -10
  208. data/lib/rubocop/cop/lint/numbered_parameter_assignment.rb +1 -1
  209. data/lib/rubocop/cop/lint/or_assignment_to_constant.rb +2 -3
  210. data/lib/rubocop/cop/lint/parentheses_as_grouped_expression.rb +2 -2
  211. data/lib/rubocop/cop/lint/percent_string_array.rb +1 -1
  212. data/lib/rubocop/cop/lint/percent_symbol_array.rb +1 -1
  213. data/lib/rubocop/cop/lint/raise_exception.rb +2 -2
  214. data/lib/rubocop/cop/lint/rand_one.rb +1 -1
  215. data/lib/rubocop/cop/lint/redundant_cop_disable_directive.rb +6 -6
  216. data/lib/rubocop/cop/lint/redundant_cop_enable_directive.rb +2 -2
  217. data/lib/rubocop/cop/lint/redundant_dir_glob_sort.rb +3 -3
  218. data/lib/rubocop/cop/lint/redundant_require_statement.rb +4 -1
  219. data/lib/rubocop/cop/lint/redundant_safe_navigation.rb +16 -3
  220. data/lib/rubocop/cop/lint/redundant_splat_expansion.rb +1 -1
  221. data/lib/rubocop/cop/lint/redundant_string_coercion.rb +1 -1
  222. data/lib/rubocop/cop/lint/redundant_with_index.rb +14 -11
  223. data/lib/rubocop/cop/lint/redundant_with_object.rb +13 -12
  224. data/lib/rubocop/cop/lint/refinement_import_methods.rb +51 -0
  225. data/lib/rubocop/cop/lint/regexp_as_condition.rb +3 -3
  226. data/lib/rubocop/cop/lint/require_parentheses.rb +1 -1
  227. data/lib/rubocop/cop/lint/require_range_parentheses.rb +57 -0
  228. data/lib/rubocop/cop/lint/rescue_exception.rb +1 -1
  229. data/lib/rubocop/cop/lint/return_in_void_context.rb +6 -18
  230. data/lib/rubocop/cop/lint/safe_navigation_chain.rb +38 -1
  231. data/lib/rubocop/cop/lint/safe_navigation_consistency.rb +1 -1
  232. data/lib/rubocop/cop/lint/safe_navigation_with_empty.rb +1 -1
  233. data/lib/rubocop/cop/lint/script_permission.rb +1 -1
  234. data/lib/rubocop/cop/lint/self_assignment.rb +1 -1
  235. data/lib/rubocop/cop/lint/shadowed_argument.rb +1 -1
  236. data/lib/rubocop/cop/lint/shadowed_exception.rb +16 -1
  237. data/lib/rubocop/cop/lint/shadowing_outer_local_variable.rb +32 -1
  238. data/lib/rubocop/cop/lint/struct_new_override.rb +3 -3
  239. data/lib/rubocop/cop/lint/suppressed_exception.rb +1 -1
  240. data/lib/rubocop/cop/lint/symbol_conversion.rb +4 -3
  241. data/lib/rubocop/cop/lint/syntax.rb +2 -3
  242. data/lib/rubocop/cop/lint/to_enum_arguments.rb +1 -1
  243. data/lib/rubocop/cop/lint/to_json.rb +1 -1
  244. data/lib/rubocop/cop/lint/top_level_return_with_argument.rb +1 -1
  245. data/lib/rubocop/cop/lint/trailing_comma_in_attribute_declaration.rb +2 -2
  246. data/lib/rubocop/cop/lint/triple_quotes.rb +1 -1
  247. data/lib/rubocop/cop/lint/underscore_prefixed_variable_name.rb +1 -1
  248. data/lib/rubocop/cop/lint/unexpected_block_arity.rb +1 -1
  249. data/lib/rubocop/cop/lint/unified_integer.rb +3 -1
  250. data/lib/rubocop/cop/lint/unreachable_code.rb +1 -1
  251. data/lib/rubocop/cop/lint/unreachable_loop.rb +13 -7
  252. data/lib/rubocop/cop/lint/unused_block_argument.rb +1 -1
  253. data/lib/rubocop/cop/lint/unused_method_argument.rb +2 -2
  254. data/lib/rubocop/cop/lint/uri_escape_unescape.rb +1 -1
  255. data/lib/rubocop/cop/lint/uri_regexp.rb +1 -1
  256. data/lib/rubocop/cop/lint/useless_access_modifier.rb +9 -7
  257. data/lib/rubocop/cop/lint/useless_assignment.rb +1 -1
  258. data/lib/rubocop/cop/lint/useless_else_without_rescue.rb +2 -3
  259. data/lib/rubocop/cop/lint/useless_method_definition.rb +1 -1
  260. data/lib/rubocop/cop/lint/useless_ruby2_keywords.rb +2 -2
  261. data/lib/rubocop/cop/lint/useless_setter_call.rb +2 -2
  262. data/lib/rubocop/cop/lint/useless_times.rb +2 -2
  263. data/lib/rubocop/cop/lint/void.rb +3 -1
  264. data/lib/rubocop/cop/metrics/abc_size.rb +4 -2
  265. data/lib/rubocop/cop/metrics/block_length.rb +7 -7
  266. data/lib/rubocop/cop/metrics/block_nesting.rb +1 -1
  267. data/lib/rubocop/cop/metrics/class_length.rb +1 -1
  268. data/lib/rubocop/cop/metrics/cyclomatic_complexity.rb +1 -1
  269. data/lib/rubocop/cop/metrics/method_length.rb +9 -8
  270. data/lib/rubocop/cop/metrics/module_length.rb +1 -1
  271. data/lib/rubocop/cop/metrics/parameter_lists.rb +1 -1
  272. data/lib/rubocop/cop/metrics/perceived_complexity.rb +1 -1
  273. data/lib/rubocop/cop/metrics/utils/abc_size_calculator.rb +2 -3
  274. data/lib/rubocop/cop/metrics/utils/code_length_calculator.rb +22 -3
  275. data/lib/rubocop/cop/mixin/allowed_methods.rb +20 -1
  276. data/lib/rubocop/cop/mixin/allowed_pattern.rb +56 -0
  277. data/lib/rubocop/cop/mixin/check_line_breakable.rb +5 -1
  278. data/lib/rubocop/cop/mixin/comments_help.rb +28 -2
  279. data/lib/rubocop/cop/mixin/def_node.rb +2 -7
  280. data/lib/rubocop/cop/mixin/duplication.rb +1 -1
  281. data/lib/rubocop/cop/mixin/enforce_superclass.rb +2 -1
  282. data/lib/rubocop/cop/mixin/hash_shorthand_syntax.rb +83 -4
  283. data/lib/rubocop/cop/mixin/hash_transform_method.rb +10 -6
  284. data/lib/rubocop/cop/mixin/line_length_help.rb +17 -6
  285. data/lib/rubocop/cop/mixin/method_complexity.rb +8 -13
  286. data/lib/rubocop/cop/mixin/multiline_element_indentation.rb +34 -12
  287. data/lib/rubocop/cop/mixin/multiline_expression_indentation.rb +4 -3
  288. data/lib/rubocop/cop/mixin/percent_array.rb +60 -1
  289. data/lib/rubocop/cop/mixin/preferred_delimiters.rb +2 -2
  290. data/lib/rubocop/cop/mixin/range_help.rb +10 -7
  291. data/lib/rubocop/cop/mixin/statement_modifier.rb +1 -1
  292. data/lib/rubocop/cop/mixin/string_help.rb +1 -1
  293. data/lib/rubocop/cop/mixin/surrounding_space.rb +4 -2
  294. data/lib/rubocop/cop/mixin/trailing_comma.rb +1 -1
  295. data/lib/rubocop/cop/naming/accessor_method_name.rb +4 -2
  296. data/lib/rubocop/cop/naming/ascii_identifiers.rb +1 -1
  297. data/lib/rubocop/cop/naming/binary_operator_parameter_name.rb +1 -1
  298. data/lib/rubocop/cop/naming/block_forwarding.rb +4 -4
  299. data/lib/rubocop/cop/naming/block_parameter_name.rb +2 -2
  300. data/lib/rubocop/cop/naming/class_and_module_camel_case.rb +1 -1
  301. data/lib/rubocop/cop/naming/constant_name.rb +3 -3
  302. data/lib/rubocop/cop/naming/file_name.rb +2 -2
  303. data/lib/rubocop/cop/naming/heredoc_delimiter_case.rb +1 -1
  304. data/lib/rubocop/cop/naming/heredoc_delimiter_naming.rb +1 -1
  305. data/lib/rubocop/cop/naming/inclusive_language.rb +3 -2
  306. data/lib/rubocop/cop/naming/memoized_instance_variable_name.rb +1 -1
  307. data/lib/rubocop/cop/naming/method_name.rb +6 -6
  308. data/lib/rubocop/cop/naming/method_parameter_name.rb +1 -1
  309. data/lib/rubocop/cop/naming/predicate_name.rb +32 -3
  310. data/lib/rubocop/cop/naming/rescued_exceptions_variable_name.rb +1 -1
  311. data/lib/rubocop/cop/naming/variable_name.rb +10 -1
  312. data/lib/rubocop/cop/naming/variable_number.rb +28 -18
  313. data/lib/rubocop/cop/offense.rb +1 -1
  314. data/lib/rubocop/cop/security/compound_hash.rb +105 -0
  315. data/lib/rubocop/cop/security/eval.rb +1 -1
  316. data/lib/rubocop/cop/security/json_load.rb +1 -1
  317. data/lib/rubocop/cop/security/marshal_load.rb +1 -1
  318. data/lib/rubocop/cop/security/open.rb +1 -1
  319. data/lib/rubocop/cop/security/yaml_load.rb +2 -2
  320. data/lib/rubocop/cop/style/access_modifier_declarations.rb +77 -1
  321. data/lib/rubocop/cop/style/accessor_grouping.rb +4 -4
  322. data/lib/rubocop/cop/style/alias.rb +4 -4
  323. data/lib/rubocop/cop/style/and_or.rb +12 -12
  324. data/lib/rubocop/cop/style/arguments_forwarding.rb +3 -3
  325. data/lib/rubocop/cop/style/array_coercion.rb +1 -1
  326. data/lib/rubocop/cop/style/array_join.rb +1 -1
  327. data/lib/rubocop/cop/style/ascii_comments.rb +1 -1
  328. data/lib/rubocop/cop/style/attr.rb +1 -1
  329. data/lib/rubocop/cop/style/auto_resource_cleanup.rb +1 -1
  330. data/lib/rubocop/cop/style/bare_percent_literals.rb +1 -1
  331. data/lib/rubocop/cop/style/bisected_attr_accessor/macro.rb +1 -1
  332. data/lib/rubocop/cop/style/bisected_attr_accessor.rb +1 -1
  333. data/lib/rubocop/cop/style/block_comments.rb +1 -1
  334. data/lib/rubocop/cop/style/block_delimiters.rb +35 -9
  335. data/lib/rubocop/cop/style/case_equality.rb +41 -11
  336. data/lib/rubocop/cop/style/case_like_if.rb +2 -2
  337. data/lib/rubocop/cop/style/character_literal.rb +1 -1
  338. data/lib/rubocop/cop/style/class_and_module_children.rb +5 -5
  339. data/lib/rubocop/cop/style/class_check.rb +1 -1
  340. data/lib/rubocop/cop/style/class_equality_comparison.rb +51 -4
  341. data/lib/rubocop/cop/style/class_methods.rb +1 -1
  342. data/lib/rubocop/cop/style/class_methods_definitions.rb +3 -2
  343. data/lib/rubocop/cop/style/class_vars.rb +1 -1
  344. data/lib/rubocop/cop/style/collection_compact.rb +4 -4
  345. data/lib/rubocop/cop/style/collection_methods.rb +3 -1
  346. data/lib/rubocop/cop/style/colon_method_call.rb +1 -1
  347. data/lib/rubocop/cop/style/colon_method_definition.rb +1 -1
  348. data/lib/rubocop/cop/style/combinable_loops.rb +4 -2
  349. data/lib/rubocop/cop/style/command_literal.rb +1 -1
  350. data/lib/rubocop/cop/style/comment_annotation.rb +1 -1
  351. data/lib/rubocop/cop/style/commented_keyword.rb +4 -4
  352. data/lib/rubocop/cop/style/conditional_assignment.rb +2 -1
  353. data/lib/rubocop/cop/style/constant_visibility.rb +1 -1
  354. data/lib/rubocop/cop/style/date_time.rb +2 -2
  355. data/lib/rubocop/cop/style/def_with_parentheses.rb +1 -1
  356. data/lib/rubocop/cop/style/dir.rb +4 -1
  357. data/lib/rubocop/cop/style/documentation.rb +1 -1
  358. data/lib/rubocop/cop/style/documentation_method.rb +1 -1
  359. data/lib/rubocop/cop/style/double_negation.rb +62 -3
  360. data/lib/rubocop/cop/style/each_for_simple_loop.rb +42 -7
  361. data/lib/rubocop/cop/style/each_with_object.rb +40 -9
  362. data/lib/rubocop/cop/style/empty_block_parameter.rb +2 -2
  363. data/lib/rubocop/cop/style/empty_case_condition.rb +3 -4
  364. data/lib/rubocop/cop/style/empty_else.rb +40 -3
  365. data/lib/rubocop/cop/style/empty_heredoc.rb +73 -0
  366. data/lib/rubocop/cop/style/empty_lambda_parameter.rb +2 -2
  367. data/lib/rubocop/cop/style/empty_literal.rb +2 -2
  368. data/lib/rubocop/cop/style/empty_method.rb +17 -2
  369. data/lib/rubocop/cop/style/encoding.rb +2 -2
  370. data/lib/rubocop/cop/style/end_block.rb +1 -1
  371. data/lib/rubocop/cop/style/endless_method.rb +1 -1
  372. data/lib/rubocop/cop/style/env_home.rb +56 -0
  373. data/lib/rubocop/cop/style/eval_with_location.rb +1 -1
  374. data/lib/rubocop/cop/style/even_odd.rb +1 -1
  375. data/lib/rubocop/cop/style/expand_path_arguments.rb +1 -1
  376. data/lib/rubocop/cop/style/explicit_block_argument.rb +2 -2
  377. data/lib/rubocop/cop/style/exponential_notation.rb +1 -1
  378. data/lib/rubocop/cop/style/fetch_env_var.rb +132 -0
  379. data/lib/rubocop/cop/style/file_write.rb +12 -0
  380. data/lib/rubocop/cop/style/float_division.rb +1 -1
  381. data/lib/rubocop/cop/style/for.rb +3 -1
  382. data/lib/rubocop/cop/style/format_string.rb +1 -1
  383. data/lib/rubocop/cop/style/format_string_token.rb +73 -23
  384. data/lib/rubocop/cop/style/frozen_string_literal_comment.rb +6 -3
  385. data/lib/rubocop/cop/style/global_std_stream.rb +1 -1
  386. data/lib/rubocop/cop/style/global_vars.rb +1 -1
  387. data/lib/rubocop/cop/style/guard_clause.rb +62 -4
  388. data/lib/rubocop/cop/style/hash_as_last_array_item.rb +1 -1
  389. data/lib/rubocop/cop/style/hash_conversion.rb +1 -1
  390. data/lib/rubocop/cop/style/hash_each_methods.rb +4 -2
  391. data/lib/rubocop/cop/style/hash_except.rb +85 -9
  392. data/lib/rubocop/cop/style/hash_like_case.rb +1 -1
  393. data/lib/rubocop/cop/style/hash_syntax.rb +20 -3
  394. data/lib/rubocop/cop/style/hash_transform_keys.rb +6 -1
  395. data/lib/rubocop/cop/style/hash_transform_values.rb +4 -1
  396. data/lib/rubocop/cop/style/identical_conditional_branches.rb +4 -4
  397. data/lib/rubocop/cop/style/if_unless_modifier.rb +6 -5
  398. data/lib/rubocop/cop/style/if_with_boolean_literal_branches.rb +4 -2
  399. data/lib/rubocop/cop/style/implicit_runtime_error.rb +3 -3
  400. data/lib/rubocop/cop/style/in_pattern_then.rb +1 -1
  401. data/lib/rubocop/cop/style/inline_comment.rb +1 -1
  402. data/lib/rubocop/cop/style/inverse_methods.rb +10 -8
  403. data/lib/rubocop/cop/style/ip_addresses.rb +1 -1
  404. data/lib/rubocop/cop/style/keyword_parameters_order.rb +2 -2
  405. data/lib/rubocop/cop/style/lambda.rb +1 -1
  406. data/lib/rubocop/cop/style/lambda_call.rb +1 -1
  407. data/lib/rubocop/cop/style/line_end_concatenation.rb +2 -2
  408. data/lib/rubocop/cop/style/magic_comment_format.rb +307 -0
  409. data/lib/rubocop/cop/style/map_compact_with_conditional_block.rb +136 -0
  410. data/lib/rubocop/cop/style/map_to_hash.rb +3 -3
  411. data/lib/rubocop/cop/style/method_call_with_args_parentheses/omit_parentheses.rb +4 -4
  412. data/lib/rubocop/cop/style/method_call_with_args_parentheses/require_parentheses.rb +6 -2
  413. data/lib/rubocop/cop/style/method_call_with_args_parentheses.rb +12 -12
  414. data/lib/rubocop/cop/style/method_call_without_args_parentheses.rb +20 -3
  415. data/lib/rubocop/cop/style/method_called_on_do_end_block.rb +5 -2
  416. data/lib/rubocop/cop/style/method_def_parentheses.rb +1 -1
  417. data/lib/rubocop/cop/style/min_max.rb +1 -1
  418. data/lib/rubocop/cop/style/missing_else.rb +24 -24
  419. data/lib/rubocop/cop/style/missing_respond_to_missing.rb +1 -1
  420. data/lib/rubocop/cop/style/mixin_grouping.rb +2 -2
  421. data/lib/rubocop/cop/style/mixin_usage.rb +1 -1
  422. data/lib/rubocop/cop/style/module_function.rb +3 -3
  423. data/lib/rubocop/cop/style/multiline_block_chain.rb +4 -2
  424. data/lib/rubocop/cop/style/multiline_if_modifier.rb +2 -2
  425. data/lib/rubocop/cop/style/multiline_if_then.rb +1 -1
  426. data/lib/rubocop/cop/style/multiline_in_pattern_then.rb +3 -5
  427. data/lib/rubocop/cop/style/multiline_memoization.rb +1 -1
  428. data/lib/rubocop/cop/style/multiline_method_signature.rb +2 -2
  429. data/lib/rubocop/cop/style/multiline_ternary_operator.rb +37 -11
  430. data/lib/rubocop/cop/style/multiline_when_then.rb +2 -4
  431. data/lib/rubocop/cop/style/multiple_comparison.rb +1 -1
  432. data/lib/rubocop/cop/style/mutable_constant.rb +1 -1
  433. data/lib/rubocop/cop/style/negated_if_else_condition.rb +1 -1
  434. data/lib/rubocop/cop/style/nested_file_dirname.rb +1 -1
  435. data/lib/rubocop/cop/style/nested_modifier.rb +1 -1
  436. data/lib/rubocop/cop/style/nested_parenthesized_calls.rb +11 -2
  437. data/lib/rubocop/cop/style/nested_ternary_operator.rb +20 -8
  438. data/lib/rubocop/cop/style/next.rb +4 -6
  439. data/lib/rubocop/cop/style/nil_comparison.rb +1 -1
  440. data/lib/rubocop/cop/style/nil_lambda.rb +3 -3
  441. data/lib/rubocop/cop/style/non_nil_check.rb +1 -1
  442. data/lib/rubocop/cop/style/not.rb +2 -2
  443. data/lib/rubocop/cop/style/numbered_parameters.rb +1 -1
  444. data/lib/rubocop/cop/style/numbered_parameters_limit.rb +1 -1
  445. data/lib/rubocop/cop/style/numeric_literal_prefix.rb +1 -1
  446. data/lib/rubocop/cop/style/numeric_literals.rb +16 -1
  447. data/lib/rubocop/cop/style/numeric_predicate.rb +53 -11
  448. data/lib/rubocop/cop/style/object_then.rb +71 -0
  449. data/lib/rubocop/cop/style/one_line_conditional.rb +1 -1
  450. data/lib/rubocop/cop/style/open_struct_use.rb +1 -1
  451. data/lib/rubocop/cop/style/option_hash.rb +1 -1
  452. data/lib/rubocop/cop/style/optional_arguments.rb +2 -2
  453. data/lib/rubocop/cop/style/optional_boolean_parameter.rb +2 -2
  454. data/lib/rubocop/cop/style/or_assignment.rb +1 -1
  455. data/lib/rubocop/cop/style/parentheses_around_condition.rb +1 -1
  456. data/lib/rubocop/cop/style/percent_literal_delimiters.rb +1 -1
  457. data/lib/rubocop/cop/style/percent_q_literals.rb +1 -1
  458. data/lib/rubocop/cop/style/perl_backrefs.rb +23 -2
  459. data/lib/rubocop/cop/style/preferred_hash_methods.rb +1 -1
  460. data/lib/rubocop/cop/style/proc.rb +5 -2
  461. data/lib/rubocop/cop/style/quoted_symbols.rb +1 -1
  462. data/lib/rubocop/cop/style/raise_args.rb +10 -4
  463. data/lib/rubocop/cop/style/random_with_offset.rb +1 -1
  464. data/lib/rubocop/cop/style/redundant_argument.rb +2 -2
  465. data/lib/rubocop/cop/style/redundant_assignment.rb +1 -1
  466. data/lib/rubocop/cop/style/redundant_begin.rb +19 -6
  467. data/lib/rubocop/cop/style/redundant_capital_w.rb +2 -3
  468. data/lib/rubocop/cop/style/redundant_condition.rb +129 -13
  469. data/lib/rubocop/cop/style/redundant_conditional.rb +1 -1
  470. data/lib/rubocop/cop/style/redundant_exception.rb +1 -1
  471. data/lib/rubocop/cop/style/redundant_fetch_block.rb +2 -2
  472. data/lib/rubocop/cop/style/redundant_file_extension_in_require.rb +1 -1
  473. data/lib/rubocop/cop/style/redundant_freeze.rb +1 -1
  474. data/lib/rubocop/cop/style/redundant_initialize.rb +154 -0
  475. data/lib/rubocop/cop/style/redundant_interpolation.rb +22 -1
  476. data/lib/rubocop/cop/style/redundant_parentheses.rb +22 -24
  477. data/lib/rubocop/cop/style/redundant_percent_q.rb +1 -1
  478. data/lib/rubocop/cop/style/redundant_regexp_character_class.rb +8 -3
  479. data/lib/rubocop/cop/style/redundant_regexp_escape.rb +2 -2
  480. data/lib/rubocop/cop/style/redundant_return.rb +2 -2
  481. data/lib/rubocop/cop/style/redundant_self.rb +3 -1
  482. data/lib/rubocop/cop/style/redundant_self_assignment.rb +3 -4
  483. data/lib/rubocop/cop/style/redundant_self_assignment_branch.rb +1 -1
  484. data/lib/rubocop/cop/style/redundant_sort.rb +22 -7
  485. data/lib/rubocop/cop/style/redundant_sort_by.rb +25 -9
  486. data/lib/rubocop/cop/style/regexp_literal.rb +1 -1
  487. data/lib/rubocop/cop/style/rescue_modifier.rb +1 -1
  488. data/lib/rubocop/cop/style/rescue_standard_error.rb +13 -13
  489. data/lib/rubocop/cop/style/return_nil.rb +1 -1
  490. data/lib/rubocop/cop/style/safe_navigation.rb +21 -11
  491. data/lib/rubocop/cop/style/sample.rb +1 -1
  492. data/lib/rubocop/cop/style/select_by_regexp.rb +7 -2
  493. data/lib/rubocop/cop/style/self_assignment.rb +1 -1
  494. data/lib/rubocop/cop/style/semicolon.rb +28 -4
  495. data/lib/rubocop/cop/style/send.rb +1 -1
  496. data/lib/rubocop/cop/style/signal_exception.rb +1 -1
  497. data/lib/rubocop/cop/style/single_argument_dig.rb +5 -0
  498. data/lib/rubocop/cop/style/single_line_block_params.rb +2 -2
  499. data/lib/rubocop/cop/style/single_line_methods.rb +2 -2
  500. data/lib/rubocop/cop/style/slicing_with_range.rb +1 -1
  501. data/lib/rubocop/cop/style/sole_nested_conditional.rb +96 -30
  502. data/lib/rubocop/cop/style/special_global_vars.rb +66 -8
  503. data/lib/rubocop/cop/style/static_class.rb +1 -1
  504. data/lib/rubocop/cop/style/stderr_puts.rb +1 -1
  505. data/lib/rubocop/cop/style/string_chars.rb +1 -1
  506. data/lib/rubocop/cop/style/string_concatenation.rb +6 -7
  507. data/lib/rubocop/cop/style/string_hash_keys.rb +1 -1
  508. data/lib/rubocop/cop/style/string_literals_in_interpolation.rb +1 -1
  509. data/lib/rubocop/cop/style/string_methods.rb +1 -1
  510. data/lib/rubocop/cop/style/strip.rb +1 -1
  511. data/lib/rubocop/cop/style/struct_inheritance.rb +4 -4
  512. data/lib/rubocop/cop/style/swap_values.rb +2 -2
  513. data/lib/rubocop/cop/style/symbol_array.rb +9 -6
  514. data/lib/rubocop/cop/style/symbol_literal.rb +1 -1
  515. data/lib/rubocop/cop/style/symbol_proc.rb +70 -12
  516. data/lib/rubocop/cop/style/ternary_parentheses.rb +3 -16
  517. data/lib/rubocop/cop/style/top_level_method_definition.rb +3 -1
  518. data/lib/rubocop/cop/style/trailing_body_on_class.rb +1 -1
  519. data/lib/rubocop/cop/style/trailing_body_on_method_definition.rb +1 -1
  520. data/lib/rubocop/cop/style/trailing_body_on_module.rb +1 -1
  521. data/lib/rubocop/cop/style/trailing_comma_in_arguments.rb +1 -1
  522. data/lib/rubocop/cop/style/trailing_comma_in_array_literal.rb +1 -1
  523. data/lib/rubocop/cop/style/trailing_comma_in_block_args.rb +2 -2
  524. data/lib/rubocop/cop/style/trailing_comma_in_hash_literal.rb +1 -1
  525. data/lib/rubocop/cop/style/trailing_method_end_statement.rb +2 -5
  526. data/lib/rubocop/cop/style/trailing_underscore_variable.rb +1 -1
  527. data/lib/rubocop/cop/style/trivial_accessors.rb +11 -9
  528. data/lib/rubocop/cop/style/unless_else.rb +5 -1
  529. data/lib/rubocop/cop/style/unless_logical_operators.rb +1 -1
  530. data/lib/rubocop/cop/style/unpack_first.rb +5 -2
  531. data/lib/rubocop/cop/style/variable_interpolation.rb +1 -1
  532. data/lib/rubocop/cop/style/when_then.rb +1 -1
  533. data/lib/rubocop/cop/style/word_array.rb +4 -5
  534. data/lib/rubocop/cop/style/yoda_condition.rb +1 -1
  535. data/lib/rubocop/cop/style/zero_length_predicate.rb +1 -1
  536. data/lib/rubocop/cop/team.rb +2 -2
  537. data/lib/rubocop/cop/util.rb +3 -3
  538. data/lib/rubocop/cop/variable_force/branch.rb +1 -1
  539. data/lib/rubocop/cops_documentation_generator.rb +19 -2
  540. data/lib/rubocop/ext/range.rb +15 -0
  541. data/lib/rubocop/feature_loader.rb +94 -0
  542. data/lib/rubocop/formatter/clang_style_formatter.rb +1 -1
  543. data/lib/rubocop/formatter/disabled_config_formatter.rb +11 -8
  544. data/lib/rubocop/formatter/formatter_set.rb +20 -18
  545. data/lib/rubocop/formatter/git_hub_actions_formatter.rb +15 -2
  546. data/lib/rubocop/formatter/html_formatter.rb +5 -13
  547. data/lib/rubocop/formatter/markdown_formatter.rb +78 -0
  548. data/lib/rubocop/formatter/offense_count_formatter.rb +8 -2
  549. data/lib/rubocop/formatter/simple_text_formatter.rb +9 -8
  550. data/lib/rubocop/formatter/tap_formatter.rb +1 -1
  551. data/lib/rubocop/formatter/worst_offenders_formatter.rb +1 -2
  552. data/lib/rubocop/formatter.rb +31 -0
  553. data/lib/rubocop/magic_comment.rb +31 -5
  554. data/lib/rubocop/options.rb +103 -34
  555. data/lib/rubocop/rake_task.rb +34 -9
  556. data/lib/rubocop/result_cache.rb +24 -13
  557. data/lib/rubocop/rspec/cop_helper.rb +2 -2
  558. data/lib/rubocop/rspec/expect_offense.rb +3 -3
  559. data/lib/rubocop/rspec/parallel_formatter.rb +1 -1
  560. data/lib/rubocop/rspec/shared_contexts.rb +31 -11
  561. data/lib/rubocop/rspec/support.rb +14 -0
  562. data/lib/rubocop/runner.rb +41 -7
  563. data/lib/rubocop/server/cache.rb +144 -0
  564. data/lib/rubocop/server/cli.rb +121 -0
  565. data/lib/rubocop/server/client_command/base.rb +44 -0
  566. data/lib/rubocop/server/client_command/exec.rb +59 -0
  567. data/lib/rubocop/server/client_command/restart.rb +25 -0
  568. data/lib/rubocop/server/client_command/start.rb +43 -0
  569. data/lib/rubocop/server/client_command/status.rb +28 -0
  570. data/lib/rubocop/server/client_command/stop.rb +31 -0
  571. data/lib/rubocop/server/client_command.rb +26 -0
  572. data/lib/rubocop/server/core.rb +79 -0
  573. data/lib/rubocop/server/errors.rb +23 -0
  574. data/lib/rubocop/server/helper.rb +34 -0
  575. data/lib/rubocop/server/server_command/base.rb +50 -0
  576. data/lib/rubocop/server/server_command/exec.rb +34 -0
  577. data/lib/rubocop/server/server_command/stop.rb +24 -0
  578. data/lib/rubocop/server/server_command.rb +21 -0
  579. data/lib/rubocop/server/socket_reader.rb +65 -0
  580. data/lib/rubocop/server.rb +53 -0
  581. data/lib/rubocop/string_interpreter.rb +4 -4
  582. data/lib/rubocop/target_ruby.rb +14 -6
  583. data/lib/rubocop/version.rb +17 -9
  584. data/lib/rubocop.rb +25 -30
  585. metadata +78 -14
  586. data/lib/rubocop/cop/gemspec/date_assignment.rb +0 -49
  587. data/lib/rubocop/cop/mixin/ignored_methods.rb +0 -52
  588. data/lib/rubocop/cop/mixin/ignored_pattern.rb +0 -29
@@ -3,7 +3,7 @@
3
3
  module RuboCop
4
4
  module Cop
5
5
  module Lint
6
- # This cop checks for `raise` or `fail` statements which are
6
+ # Checks for `raise` or `fail` statements which are
7
7
  # raising `Exception` class.
8
8
  #
9
9
  # You can specify a module name that will be an implicit namespace
@@ -15,7 +15,7 @@ module RuboCop
15
15
  #
16
16
  # @safety
17
17
  # This cop is unsafe because it will change the exception class being
18
- # raised, which is a change in behaviour.
18
+ # raised, which is a change in behavior.
19
19
  #
20
20
  # @example
21
21
  # # bad
@@ -3,7 +3,7 @@
3
3
  module RuboCop
4
4
  module Cop
5
5
  module Lint
6
- # This cop checks for `rand(1)` calls.
6
+ # Checks for `rand(1)` calls.
7
7
  # Such calls always return `0`.
8
8
  #
9
9
  # @example
@@ -6,7 +6,7 @@
6
6
  module RuboCop
7
7
  module Cop
8
8
  module Lint
9
- # This cop detects instances of rubocop:disable comments that can be
9
+ # Detects instances of rubocop:disable comments that can be
10
10
  # removed without causing any offenses to be reported. It's implemented
11
11
  # as a cop in that it inherits from the Cop base class and calls
12
12
  # add_offense. The unusual part of its implementation is that it doesn't
@@ -71,16 +71,16 @@ module RuboCop
71
71
  processed_source.comment_config.comment_only_line?(directive_comment_range.line) &&
72
72
  directive_comment_range.begin_pos == line_comment_range.begin_pos
73
73
  # When the previous line is blank, it should be retained
74
- range_with_surrounding_space(range: directive_comment_range, side: :right)
74
+ range_with_surrounding_space(directive_comment_range, side: :right)
75
75
  else
76
76
  # Eat the entire comment, the preceding space, and the preceding
77
77
  # newline if there is one.
78
78
  original_begin = directive_comment_range.begin_pos
79
79
  range = range_with_surrounding_space(
80
- range: directive_comment_range, side: :left, newlines: true
80
+ directive_comment_range, side: :left, newlines: true
81
81
  )
82
82
 
83
- range_with_surrounding_space(range: range,
83
+ range_with_surrounding_space(range,
84
84
  side: :right,
85
85
  # Special for a comment that
86
86
  # begins the file: remove
@@ -94,13 +94,13 @@ module RuboCop
94
94
  # is NOT being removed?
95
95
  if ends_its_line?(ranges.last) && trailing_range?(ranges, range)
96
96
  # Eat the comma on the left.
97
- range = range_with_surrounding_space(range: range, side: :left)
97
+ range = range_with_surrounding_space(range, side: :left)
98
98
  range = range_with_surrounding_comma(range, :left)
99
99
  end
100
100
 
101
101
  range = range_with_surrounding_comma(range, :right)
102
102
  # Eat following spaces up to EOL, but not the newline itself.
103
- range_with_surrounding_space(range: range, side: :right, newlines: false)
103
+ range_with_surrounding_space(range, side: :right, newlines: false)
104
104
  end
105
105
 
106
106
  def each_redundant_disable(&block)
@@ -9,7 +9,7 @@
9
9
  module RuboCop
10
10
  module Cop
11
11
  module Lint
12
- # This cop detects instances of rubocop:enable comments that can be
12
+ # Detects instances of rubocop:enable comments that can be
13
13
  # removed.
14
14
  #
15
15
  # When comment enables all cops at once `rubocop:enable all`
@@ -60,7 +60,7 @@ module RuboCop
60
60
  message: format(MSG, cop: all_or_name(name))
61
61
  ) do |corrector|
62
62
  if directive.match?(cop_names)
63
- corrector.remove(range_with_surrounding_space(range: directive.range, side: :right))
63
+ corrector.remove(range_with_surrounding_space(directive.range, side: :right))
64
64
  else
65
65
  corrector.remove(range_with_comma(comment, name))
66
66
  end
@@ -7,9 +7,9 @@ module RuboCop
7
7
  # This cop checks for redundant `sort` method to `Dir.glob` and `Dir[]`.
8
8
  #
9
9
  # @safety
10
- # This cop is unsafe, in case of having a file and a directory with
11
- # identical names, since directory will be loaded before the file, which
12
- # will break `exe/files.rb` that rely on `exe.rb` file.
10
+ # This cop is unsafe, in case of having a file and a directory with
11
+ # identical names, since directory will be loaded before the file, which
12
+ # will break `exe/files.rb` that rely on `exe.rb` file.
13
13
  #
14
14
  # @example
15
15
  #
@@ -24,6 +24,9 @@ module RuboCop
24
24
  class RedundantRequireStatement < Base
25
25
  include RangeHelp
26
26
  extend AutoCorrector
27
+ extend TargetRubyVersion
28
+
29
+ minimum_target_ruby_version 2.2
27
30
 
28
31
  MSG = 'Remove unnecessary `require` statement.'
29
32
  RESTRICT_ON_SEND = %i[require].freeze
@@ -38,7 +41,7 @@ module RuboCop
38
41
  return unless unnecessary_require_statement?(node)
39
42
 
40
43
  add_offense(node) do |corrector|
41
- range = range_with_surrounding_space(range: node.loc.expression, side: :right)
44
+ range = range_with_surrounding_space(node.loc.expression, side: :right)
42
45
 
43
46
  corrector.remove(range)
44
47
  end
@@ -3,17 +3,22 @@
3
3
  module RuboCop
4
4
  module Cop
5
5
  module Lint
6
- # This cop checks for redundant safe navigation calls.
6
+ # Checks for redundant safe navigation calls.
7
7
  # `instance_of?`, `kind_of?`, `is_a?`, `eql?`, `respond_to?`, and `equal?` methods
8
8
  # are checked by default. These are customizable with `AllowedMethods` option.
9
9
  #
10
+ # The `AllowedMethods` option specifies nil-safe methods,
11
+ # in other words, it is a method that is allowed to skip safe navigation.
12
+ # Note that the `AllowedMethod` option is not an option that specifies methods
13
+ # for which to suppress (allow) this cop's check.
14
+ #
10
15
  # In the example below, the safe navigation operator (`&.`) is unnecessary
11
16
  # because `NilClass` has methods like `respond_to?` and `is_a?`.
12
17
  #
13
18
  # @safety
14
- # This cop is unsafe, because auto-correction can change the return type of
19
+ # This cop is unsafe, because autocorrection can change the return type of
15
20
  # the expression. An offending expression that previously could return `nil`
16
- # will be auto-corrected to never return `nil`.
21
+ # will be autocorrected to never return `nil`.
17
22
  #
18
23
  # @example
19
24
  # # bad
@@ -35,6 +40,14 @@ module RuboCop
35
40
  # # good - without `&.` this will always return `true`
36
41
  # foo&.respond_to?(:to_a)
37
42
  #
43
+ # @example AllowedMethods: [nil_safe_method]
44
+ # # bad
45
+ # do_something if attrs&.nil_safe_method(:[])
46
+ #
47
+ # # good
48
+ # do_something if attrs.nil_safe_method(:[])
49
+ # do_something if attrs&.not_nil_safe_method(:[])
50
+ #
38
51
  class RedundantSafeNavigation < Base
39
52
  include AllowedMethods
40
53
  include RangeHelp
@@ -3,7 +3,7 @@
3
3
  module RuboCop
4
4
  module Cop
5
5
  module Lint
6
- # This cop checks for unneeded usages of splat expansion
6
+ # Checks for unneeded usages of splat expansion
7
7
  #
8
8
  # @example
9
9
  #
@@ -3,7 +3,7 @@
3
3
  module RuboCop
4
4
  module Cop
5
5
  module Lint
6
- # This cop checks for string conversion in string interpolation,
6
+ # Checks for string conversion in string interpolation,
7
7
  # which is redundant.
8
8
  #
9
9
  # @example
@@ -3,7 +3,7 @@
3
3
  module RuboCop
4
4
  module Cop
5
5
  module Lint
6
- # This cop checks for redundant `with_index`.
6
+ # Checks for redundant `with_index`.
7
7
  #
8
8
  # @example
9
9
  # # bad
@@ -33,16 +33,6 @@ module RuboCop
33
33
  MSG_EACH_WITH_INDEX = 'Use `each` instead of `each_with_index`.'
34
34
  MSG_WITH_INDEX = 'Remove redundant `with_index`.'
35
35
 
36
- # @!method redundant_with_index?(node)
37
- def_node_matcher :redundant_with_index?, <<~PATTERN
38
- (block
39
- $(send
40
- _ {:each_with_index :with_index} ...)
41
- (args
42
- (arg _))
43
- ...)
44
- PATTERN
45
-
46
36
  def on_block(node)
47
37
  return unless (send = redundant_with_index?(node))
48
38
 
@@ -58,8 +48,21 @@ module RuboCop
58
48
  end
59
49
  end
60
50
 
51
+ alias on_numblock on_block
52
+
61
53
  private
62
54
 
55
+ # @!method redundant_with_index?(node)
56
+ def_node_matcher :redundant_with_index?, <<~PATTERN
57
+ {
58
+ (block
59
+ $(send _ {:each_with_index :with_index} ...)
60
+ (args (arg _)) ...)
61
+ (numblock
62
+ $(send _ {:each_with_index :with_index} ...) 1 ...)
63
+ }
64
+ PATTERN
65
+
63
66
  def message(node)
64
67
  if node.method?(:each_with_index)
65
68
  MSG_EACH_WITH_INDEX
@@ -3,7 +3,7 @@
3
3
  module RuboCop
4
4
  module Cop
5
5
  module Lint
6
- # This cop checks for redundant `with_object`.
6
+ # Checks for redundant `with_object`.
7
7
  #
8
8
  # @example
9
9
  # # bad
@@ -31,19 +31,8 @@ module RuboCop
31
31
  extend AutoCorrector
32
32
 
33
33
  MSG_EACH_WITH_OBJECT = 'Use `each` instead of `each_with_object`.'
34
-
35
34
  MSG_WITH_OBJECT = 'Remove redundant `with_object`.'
36
35
 
37
- # @!method redundant_with_object?(node)
38
- def_node_matcher :redundant_with_object?, <<~PATTERN
39
- (block
40
- $(send _ {:each_with_object :with_object}
41
- _)
42
- (args
43
- (arg _))
44
- ...)
45
- PATTERN
46
-
47
36
  def on_block(node)
48
37
  return unless (send = redundant_with_object?(node))
49
38
 
@@ -59,8 +48,20 @@ module RuboCop
59
48
  end
60
49
  end
61
50
 
51
+ alias on_numblock on_block
52
+
62
53
  private
63
54
 
55
+ # @!method redundant_with_object?(node)
56
+ def_node_matcher :redundant_with_object?, <<~PATTERN
57
+ {
58
+ (block
59
+ $(send _ {:each_with_object :with_object} _) (args (arg _)) ...)
60
+ (numblock
61
+ $(send _ {:each_with_object :with_object} _) 1 ...)
62
+ }
63
+ PATTERN
64
+
64
65
  def message(node)
65
66
  if node.method?(:each_with_object)
66
67
  MSG_EACH_WITH_OBJECT
@@ -0,0 +1,51 @@
1
+ # frozen_string_literal: true
2
+
3
+ module RuboCop
4
+ module Cop
5
+ module Lint
6
+ # Checks if `include` or `prepend` is called in `refine` block.
7
+ # These methods are deprecated and should be replaced with `Refinement#import_methods`.
8
+ #
9
+ # It emulates deprecation warnings in Ruby 3.1.
10
+ #
11
+ # @safety
12
+ # This cop's autocorrection is unsafe because `include M` will affect the included class
13
+ # if any changes are made to module `M`.
14
+ # On the other hand, `import_methods M` uses a snapshot of method definitions,
15
+ # thus it will not be affected if module `M` changes.
16
+ #
17
+ # @example
18
+ #
19
+ # # bad
20
+ # refine Foo do
21
+ # include Bar
22
+ # end
23
+ #
24
+ # # bad
25
+ # refine Foo do
26
+ # prepend Bar
27
+ # end
28
+ #
29
+ # # good
30
+ # refine Foo do
31
+ # import_methods Bar
32
+ # end
33
+ #
34
+ class RefinementImportMethods < Base
35
+ extend TargetRubyVersion
36
+
37
+ MSG = 'Use `import_methods` instead of `%<current>s` because it is deprecated in Ruby 3.1.'
38
+ RESTRICT_ON_SEND = %i[include prepend].freeze
39
+
40
+ minimum_target_ruby_version 3.1
41
+
42
+ def on_send(node)
43
+ return if node.receiver
44
+ return unless node.parent.block_type? && node.parent.method?(:refine)
45
+
46
+ add_offense(node.loc.selector, message: format(MSG, current: node.method_name))
47
+ end
48
+ end
49
+ end
50
+ end
51
+ end
@@ -3,7 +3,7 @@
3
3
  module RuboCop
4
4
  module Cop
5
5
  module Lint
6
- # This cop checks for regexp literals used as `match-current-line`.
6
+ # Checks for regexp literals used as `match-current-line`.
7
7
  # If a regexp literal is in condition, the regexp matches `$_` implicitly.
8
8
  #
9
9
  # @example
@@ -19,8 +19,8 @@ module RuboCop
19
19
  class RegexpAsCondition < Base
20
20
  extend AutoCorrector
21
21
 
22
- MSG = 'Do not use regexp literal as a condition.' \
23
- ' The regexp literal matches `$_` implicitly.'
22
+ MSG = 'Do not use regexp literal as a condition. ' \
23
+ 'The regexp literal matches `$_` implicitly.'
24
24
 
25
25
  def on_match_current_line(node)
26
26
  add_offense(node) { |corrector| corrector.replace(node, "#{node.source} =~ $_") }
@@ -3,7 +3,7 @@
3
3
  module RuboCop
4
4
  module Cop
5
5
  module Lint
6
- # This cop checks for expressions where there is a call to a predicate
6
+ # Checks for expressions where there is a call to a predicate
7
7
  # method with at least one argument, where no parentheses are used around
8
8
  # the parameter list, and a boolean operator, && or ||, is used in the
9
9
  # last argument.
@@ -0,0 +1,57 @@
1
+ # frozen_string_literal: true
2
+
3
+ module RuboCop
4
+ module Cop
5
+ module Lint
6
+ # Checks that a range literal is enclosed in parentheses when the end of the range is
7
+ # at a line break.
8
+ #
9
+ # NOTE: The following is maybe intended for `(42..)`. But, compatible is `42..do_something`.
10
+ # So, this cop does not provide autocorrection because it is left to user.
11
+ #
12
+ # [source,ruby]
13
+ # ----
14
+ # case condition
15
+ # when 42..
16
+ # do_something
17
+ # end
18
+ # ----
19
+ #
20
+ # @example
21
+ #
22
+ # # bad - Represents `(1..42)`, not endless range.
23
+ # 1..
24
+ # 42
25
+ #
26
+ # # good - It's incompatible, but your intentions when using endless range may be:
27
+ # (1..)
28
+ # 42
29
+ #
30
+ # # good
31
+ # 1..42
32
+ #
33
+ # # good
34
+ # (1..42)
35
+ #
36
+ # # good
37
+ # (1..
38
+ # 42)
39
+ #
40
+ class RequireRangeParentheses < Base
41
+ MSG = 'Wrap the endless range literal `%<range>s` to avoid precedence ambiguity.'
42
+
43
+ def on_irange(node)
44
+ return if node.parent&.begin_type?
45
+ return unless node.begin && node.end
46
+ return if same_line?(node.begin, node.end)
47
+
48
+ message = format(MSG, range: "#{node.begin.source}#{node.loc.operator.source}")
49
+
50
+ add_offense(node, message: message)
51
+ end
52
+
53
+ alias on_erange on_irange
54
+ end
55
+ end
56
+ end
57
+ end
@@ -3,7 +3,7 @@
3
3
  module RuboCop
4
4
  module Cop
5
5
  module Lint
6
- # This cop checks for `rescue` blocks targeting the Exception class.
6
+ # Checks for `rescue` blocks targeting the Exception class.
7
7
  #
8
8
  # @example
9
9
  #
@@ -3,7 +3,7 @@
3
3
  module RuboCop
4
4
  module Cop
5
5
  module Lint
6
- # This cop checks for the use of a return with a value in a context
6
+ # Checks for the use of a return with a value in a context
7
7
  # where the value will be ignored. (initialize and setter methods)
8
8
  #
9
9
  # @example
@@ -40,12 +40,12 @@ module RuboCop
40
40
  context_node = non_void_context(return_node)
41
41
 
42
42
  return unless context_node&.def_type?
43
+ return unless context_node&.void_context?
43
44
 
44
- method_name = method_name(context_node)
45
-
46
- return unless method_name && void_context_method?(method_name)
47
-
48
- add_offense(return_node.loc.keyword, message: format(message, method: method_name))
45
+ add_offense(
46
+ return_node.loc.keyword,
47
+ message: format(message, method: context_node.method_name)
48
+ )
49
49
  end
50
50
 
51
51
  private
@@ -53,18 +53,6 @@ module RuboCop
53
53
  def non_void_context(return_node)
54
54
  return_node.each_ancestor(:block, :def, :defs).first
55
55
  end
56
-
57
- def method_name(context_node)
58
- context_node.children.first
59
- end
60
-
61
- def void_context_method?(method_name)
62
- method_name == :initialize || setter_method?(method_name)
63
- end
64
-
65
- def setter_method?(method_name)
66
- method_name.to_s.end_with?('=') && !AST::Node::COMPARISON_OPERATORS.include?(method_name)
67
- end
68
56
  end
69
57
  end
70
58
  end
@@ -25,6 +25,10 @@ module RuboCop
25
25
  # x&.foo || bar
26
26
  class SafeNavigationChain < Base
27
27
  include NilMethods
28
+ extend AutoCorrector
29
+ extend TargetRubyVersion
30
+
31
+ minimum_target_ruby_version 2.3
28
32
 
29
33
  MSG = 'Do not chain ordinary method call after safe navigation operator.'
30
34
 
@@ -45,12 +49,45 @@ module RuboCop
45
49
  Parser::Source::Range.new(node.source_range.source_buffer,
46
50
  safe_nav.source_range.end_pos,
47
51
  method_chain.source_range.end_pos)
48
- add_offense(location)
52
+ add_offense(location) do |corrector|
53
+ autocorrect(corrector, offense_range: location, send_node: method_chain)
54
+ end
49
55
  end
50
56
  end
51
57
 
52
58
  private
53
59
 
60
+ # @param [Parser::Source::Range] offense_range
61
+ # @param [RuboCop::AST::SendNode] send_node
62
+ # @return [String]
63
+ def add_safe_navigation_operator(offense_range:, send_node:)
64
+ source = \
65
+ if send_node.method?(:[]) || send_node.method?(:[]=)
66
+ format(
67
+ '%<method_name>s(%<arguments>s)',
68
+ arguments: send_node.arguments.map(&:source).join(', '),
69
+ method_name: send_node.method_name
70
+ )
71
+ else
72
+ offense_range.source.dup
73
+ end
74
+ source.prepend('.') unless send_node.dot?
75
+ source.prepend('&')
76
+ end
77
+
78
+ # @param [RuboCop::Cop::Corrector] corrector
79
+ # @param [Parser::Source::Range] offense_range
80
+ # @param [RuboCop::AST::SendNode] send_node
81
+ def autocorrect(corrector, offense_range:, send_node:)
82
+ corrector.replace(
83
+ offense_range,
84
+ add_safe_navigation_operator(
85
+ offense_range: offense_range,
86
+ send_node: send_node
87
+ )
88
+ )
89
+ end
90
+
54
91
  def method_chain(node)
55
92
  chain = node
56
93
  chain = chain.parent if chain.send_type? && chain.parent&.call_type?
@@ -3,7 +3,7 @@
3
3
  module RuboCop
4
4
  module Cop
5
5
  module Lint
6
- # This cop check to make sure that if safe navigation is used for a method
6
+ # Check to make sure that if safe navigation is used for a method
7
7
  # call in an `&&` or `||` condition that safe navigation is used for all
8
8
  # method calls on that same object.
9
9
  #
@@ -3,7 +3,7 @@
3
3
  module RuboCop
4
4
  module Cop
5
5
  module Lint
6
- # This cop checks to make sure safe navigation isn't used with `empty?` in
6
+ # Checks to make sure safe navigation isn't used with `empty?` in
7
7
  # a conditional.
8
8
  #
9
9
  # While the safe navigation operator is generally a good idea, when
@@ -3,7 +3,7 @@
3
3
  module RuboCop
4
4
  module Cop
5
5
  module Lint
6
- # This cop checks if a file which has a shebang line as
6
+ # Checks if a file which has a shebang line as
7
7
  # its first line is granted execute permission.
8
8
  #
9
9
  # @example
@@ -3,7 +3,7 @@
3
3
  module RuboCop
4
4
  module Cop
5
5
  module Lint
6
- # This cop checks for self-assignments.
6
+ # Checks for self-assignments.
7
7
  #
8
8
  # @example
9
9
  # # bad
@@ -3,7 +3,7 @@
3
3
  module RuboCop
4
4
  module Cop
5
5
  module Lint
6
- # This cop checks for shadowed arguments.
6
+ # Checks for shadowed arguments.
7
7
  #
8
8
  # This cop has `IgnoreImplicitReferences` configuration option.
9
9
  # It means argument shadowing is used in order to pass parameters
@@ -3,10 +3,18 @@
3
3
  module RuboCop
4
4
  module Cop
5
5
  module Lint
6
- # This cop checks for a rescued exception that get shadowed by a
6
+ # Checks for a rescued exception that get shadowed by a
7
7
  # less specific exception being rescued before a more specific
8
8
  # exception is rescued.
9
9
  #
10
+ # An exception is considered shadowed if it is rescued after its
11
+ # ancestor is, or if it and its ancestor are both rescued in the
12
+ # same `rescue` statement. In both cases, the more specific rescue is
13
+ # unnecessary because it is covered by rescuing the less specific
14
+ # exception. (ie. `rescue Exception, StandardError` has the same behavior
15
+ # whether `StandardError` is included or not, because all ``StandardError``s
16
+ # are rescued by `rescue Exception`).
17
+ #
10
18
  # @example
11
19
  #
12
20
  # # bad
@@ -19,6 +27,13 @@ module RuboCop
19
27
  # handle_standard_error
20
28
  # end
21
29
  #
30
+ # # bad
31
+ # begin
32
+ # something
33
+ # rescue Exception, StandardError
34
+ # handle_error
35
+ # end
36
+ #
22
37
  # # good
23
38
  #
24
39
  # begin
@@ -3,7 +3,7 @@
3
3
  module RuboCop
4
4
  module Cop
5
5
  module Lint
6
- # This cop checks for the use of local variable names from an outer scope
6
+ # Checks for the use of local variable names from an outer scope
7
7
  # in block arguments or block-local variables. This mirrors the warning
8
8
  # given by `ruby -cw` prior to Ruby 2.6:
9
9
  # "shadowing outer local variable - foo".
@@ -57,10 +57,41 @@ module RuboCop
57
57
 
58
58
  outer_local_variable = variable_table.find_variable(variable.name)
59
59
  return unless outer_local_variable
60
+ return if same_conditions_node_different_branch?(variable, outer_local_variable)
60
61
 
61
62
  message = format(MSG, variable: variable.name)
62
63
  add_offense(variable.declaration_node, message: message)
63
64
  end
65
+
66
+ def same_conditions_node_different_branch?(variable, outer_local_variable)
67
+ variable_node = variable_node(variable)
68
+ return false unless variable_node.conditional?
69
+
70
+ outer_local_variable_node =
71
+ find_conditional_node_from_ascendant(outer_local_variable.declaration_node)
72
+ return true unless outer_local_variable_node
73
+
74
+ outer_local_variable_node.conditional? &&
75
+ (variable_node == outer_local_variable_node ||
76
+ variable_node == outer_local_variable_node.else_branch)
77
+ end
78
+
79
+ def variable_node(variable)
80
+ parent_node = variable.scope.node.parent
81
+
82
+ if parent_node.when_type?
83
+ parent_node.parent
84
+ else
85
+ parent_node
86
+ end
87
+ end
88
+
89
+ def find_conditional_node_from_ascendant(node)
90
+ return unless (parent = node.parent)
91
+ return parent if parent.conditional?
92
+
93
+ find_conditional_node_from_ascendant(parent)
94
+ end
64
95
  end
65
96
  end
66
97
  end