rubocop 1.9.1 → 1.22.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (560) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +17 -14
  3. data/assets/output.html.erb +1 -1
  4. data/config/default.yml +326 -73
  5. data/config/obsoletion.yml +4 -0
  6. data/exe/rubocop +1 -3
  7. data/lib/rubocop/cached_data.rb +1 -3
  8. data/lib/rubocop/cli/command/auto_genenerate_config.rb +9 -19
  9. data/lib/rubocop/cli/command/execute_runner.rb +1 -1
  10. data/lib/rubocop/cli/command/init_dotfile.rb +1 -3
  11. data/lib/rubocop/cli/command/show_cops.rb +1 -4
  12. data/lib/rubocop/cli/command/suggest_extensions.rb +6 -5
  13. data/lib/rubocop/cli.rb +21 -5
  14. data/lib/rubocop/comment_config.rb +45 -101
  15. data/lib/rubocop/config.rb +16 -26
  16. data/lib/rubocop/config_loader.rb +11 -15
  17. data/lib/rubocop/config_loader_resolver.rb +44 -21
  18. data/lib/rubocop/config_obsoletion/cop_rule.rb +1 -2
  19. data/lib/rubocop/config_store.rb +1 -2
  20. data/lib/rubocop/config_validator.rb +37 -21
  21. data/lib/rubocop/cop/autocorrect_logic.rb +3 -8
  22. data/lib/rubocop/cop/badge.rb +1 -2
  23. data/lib/rubocop/cop/base.rb +13 -11
  24. data/lib/rubocop/cop/bundler/duplicated_gem.rb +4 -4
  25. data/lib/rubocop/cop/bundler/gem_comment.rb +43 -10
  26. data/lib/rubocop/cop/bundler/gem_filename.rb +103 -0
  27. data/lib/rubocop/cop/bundler/gem_version.rb +133 -0
  28. data/lib/rubocop/cop/bundler/insecure_protocol_source.rb +46 -21
  29. data/lib/rubocop/cop/bundler/ordered_gems.rb +5 -16
  30. data/lib/rubocop/cop/commissioner.rb +2 -8
  31. data/lib/rubocop/cop/cop.rb +4 -18
  32. data/lib/rubocop/cop/corrector.rb +5 -8
  33. data/lib/rubocop/cop/correctors/alignment_corrector.rb +6 -12
  34. data/lib/rubocop/cop/correctors/each_to_for_corrector.rb +2 -4
  35. data/lib/rubocop/cop/correctors/for_to_each_corrector.rb +1 -2
  36. data/lib/rubocop/cop/correctors/lambda_literal_to_method_corrector.rb +2 -2
  37. data/lib/rubocop/cop/correctors/line_break_corrector.rb +3 -6
  38. data/lib/rubocop/cop/correctors/multiline_literal_brace_corrector.rb +1 -3
  39. data/lib/rubocop/cop/correctors/ordered_gem_corrector.rb +11 -12
  40. data/lib/rubocop/cop/correctors/percent_literal_corrector.rb +2 -8
  41. data/lib/rubocop/cop/correctors/require_library_corrector.rb +23 -0
  42. data/lib/rubocop/cop/documentation.rb +1 -1
  43. data/lib/rubocop/cop/gemspec/date_assignment.rb +57 -0
  44. data/lib/rubocop/cop/gemspec/duplicated_assignment.rb +3 -2
  45. data/lib/rubocop/cop/gemspec/ordered_dependencies.rb +5 -16
  46. data/lib/rubocop/cop/gemspec/required_ruby_version.rb +32 -23
  47. data/lib/rubocop/cop/gemspec/ruby_version_globals_usage.rb +2 -0
  48. data/lib/rubocop/cop/generator/configuration_injector.rb +1 -2
  49. data/lib/rubocop/cop/generator/require_file_injector.rb +2 -5
  50. data/lib/rubocop/cop/generator.rb +18 -15
  51. data/lib/rubocop/cop/internal_affairs/example_description.rb +8 -5
  52. data/lib/rubocop/cop/internal_affairs/inherit_deprecated_cop_class.rb +34 -0
  53. data/lib/rubocop/cop/internal_affairs/location_line_equality_comparison.rb +60 -0
  54. data/lib/rubocop/cop/internal_affairs/method_name_equal.rb +3 -5
  55. data/lib/rubocop/cop/internal_affairs/node_destructuring.rb +3 -3
  56. data/lib/rubocop/cop/internal_affairs/node_matcher_directive.rb +151 -0
  57. data/lib/rubocop/cop/internal_affairs/node_type_predicate.rb +2 -3
  58. data/lib/rubocop/cop/internal_affairs/offense_location_keyword.rb +3 -2
  59. data/lib/rubocop/cop/internal_affairs/redundant_described_class_as_subject.rb +1 -0
  60. data/lib/rubocop/cop/internal_affairs/redundant_let_rubocop_config_new.rb +1 -0
  61. data/lib/rubocop/cop/internal_affairs/redundant_location_argument.rb +1 -0
  62. data/lib/rubocop/cop/internal_affairs/redundant_message_argument.rb +3 -0
  63. data/lib/rubocop/cop/internal_affairs/style_detected_api_use.rb +5 -2
  64. data/lib/rubocop/cop/internal_affairs/undefined_config.rb +71 -0
  65. data/lib/rubocop/cop/internal_affairs/useless_message_assertion.rb +3 -3
  66. data/lib/rubocop/cop/internal_affairs.rb +4 -0
  67. data/lib/rubocop/cop/layout/access_modifier_indentation.rb +12 -10
  68. data/lib/rubocop/cop/layout/argument_alignment.rb +36 -19
  69. data/lib/rubocop/cop/layout/array_alignment.rb +9 -8
  70. data/lib/rubocop/cop/layout/assignment_indentation.rb +9 -8
  71. data/lib/rubocop/cop/layout/begin_end_alignment.rb +1 -4
  72. data/lib/rubocop/cop/layout/block_alignment.rb +12 -23
  73. data/lib/rubocop/cop/layout/block_end_newline.rb +4 -8
  74. data/lib/rubocop/cop/layout/case_indentation.rb +57 -11
  75. data/lib/rubocop/cop/layout/class_structure.rb +12 -12
  76. data/lib/rubocop/cop/layout/closing_parenthesis_indentation.rb +24 -30
  77. data/lib/rubocop/cop/layout/comment_indentation.rb +18 -22
  78. data/lib/rubocop/cop/layout/def_end_alignment.rb +2 -6
  79. data/lib/rubocop/cop/layout/dot_position.rb +42 -9
  80. data/lib/rubocop/cop/layout/else_alignment.rb +10 -9
  81. data/lib/rubocop/cop/layout/empty_comment.rb +6 -13
  82. data/lib/rubocop/cop/layout/empty_line_after_guard_clause.rb +44 -23
  83. data/lib/rubocop/cop/layout/empty_line_between_defs.rb +2 -6
  84. data/lib/rubocop/cop/layout/empty_lines.rb +1 -3
  85. data/lib/rubocop/cop/layout/empty_lines_around_access_modifier.rb +8 -18
  86. data/lib/rubocop/cop/layout/empty_lines_around_exception_handling_keywords.rb +9 -12
  87. data/lib/rubocop/cop/layout/end_alignment.rb +10 -4
  88. data/lib/rubocop/cop/layout/end_of_line.rb +1 -1
  89. data/lib/rubocop/cop/layout/extra_spacing.rb +5 -9
  90. data/lib/rubocop/cop/layout/first_argument_indentation.rb +12 -6
  91. data/lib/rubocop/cop/layout/first_array_element_indentation.rb +13 -11
  92. data/lib/rubocop/cop/layout/first_array_element_line_break.rb +1 -2
  93. data/lib/rubocop/cop/layout/first_hash_element_indentation.rb +37 -21
  94. data/lib/rubocop/cop/layout/first_hash_element_line_break.rb +1 -2
  95. data/lib/rubocop/cop/layout/first_method_argument_line_break.rb +1 -2
  96. data/lib/rubocop/cop/layout/first_method_parameter_line_break.rb +1 -2
  97. data/lib/rubocop/cop/layout/first_parameter_indentation.rb +8 -7
  98. data/lib/rubocop/cop/layout/hash_alignment.rb +58 -31
  99. data/lib/rubocop/cop/layout/heredoc_argument_closing_parenthesis.rb +4 -11
  100. data/lib/rubocop/cop/layout/heredoc_indentation.rb +2 -13
  101. data/lib/rubocop/cop/layout/indentation_consistency.rb +9 -6
  102. data/lib/rubocop/cop/layout/indentation_style.rb +25 -30
  103. data/lib/rubocop/cop/layout/indentation_width.rb +34 -13
  104. data/lib/rubocop/cop/layout/initial_indentation.rb +1 -4
  105. data/lib/rubocop/cop/layout/leading_comment_space.rb +2 -2
  106. data/lib/rubocop/cop/layout/line_end_string_concatenation_indentation.rb +141 -0
  107. data/lib/rubocop/cop/layout/line_length.rb +13 -22
  108. data/lib/rubocop/cop/layout/multiline_array_brace_layout.rb +6 -6
  109. data/lib/rubocop/cop/layout/multiline_array_line_breaks.rb +1 -2
  110. data/lib/rubocop/cop/layout/multiline_assignment_layout.rb +29 -3
  111. data/lib/rubocop/cop/layout/multiline_block_layout.rb +10 -18
  112. data/lib/rubocop/cop/layout/multiline_hash_brace_layout.rb +6 -6
  113. data/lib/rubocop/cop/layout/multiline_hash_key_line_breaks.rb +1 -2
  114. data/lib/rubocop/cop/layout/multiline_method_argument_line_breaks.rb +4 -2
  115. data/lib/rubocop/cop/layout/multiline_method_call_brace_layout.rb +6 -6
  116. data/lib/rubocop/cop/layout/multiline_method_call_indentation.rb +22 -15
  117. data/lib/rubocop/cop/layout/multiline_method_definition_brace_layout.rb +6 -6
  118. data/lib/rubocop/cop/layout/multiline_operation_indentation.rb +13 -8
  119. data/lib/rubocop/cop/layout/parameter_alignment.rb +8 -7
  120. data/lib/rubocop/cop/layout/redundant_line_break.rb +140 -0
  121. data/lib/rubocop/cop/layout/rescue_ensure_alignment.rb +26 -16
  122. data/lib/rubocop/cop/layout/single_line_block_chain.rb +64 -0
  123. data/lib/rubocop/cop/layout/space_after_colon.rb +1 -3
  124. data/lib/rubocop/cop/layout/space_after_method_name.rb +2 -4
  125. data/lib/rubocop/cop/layout/space_after_not.rb +1 -0
  126. data/lib/rubocop/cop/layout/space_around_block_parameters.rb +6 -14
  127. data/lib/rubocop/cop/layout/space_around_equals_in_parameter_default.rb +2 -2
  128. data/lib/rubocop/cop/layout/space_around_keyword.rb +33 -8
  129. data/lib/rubocop/cop/layout/space_around_operators.rb +23 -11
  130. data/lib/rubocop/cop/layout/space_before_block_braces.rb +2 -3
  131. data/lib/rubocop/cop/layout/space_before_brackets.rb +3 -4
  132. data/lib/rubocop/cop/layout/space_before_comment.rb +3 -5
  133. data/lib/rubocop/cop/layout/space_before_first_arg.rb +5 -11
  134. data/lib/rubocop/cop/layout/space_in_lambda_literal.rb +2 -4
  135. data/lib/rubocop/cop/layout/space_inside_array_literal_brackets.rb +5 -10
  136. data/lib/rubocop/cop/layout/space_inside_array_percent_literal.rb +2 -7
  137. data/lib/rubocop/cop/layout/space_inside_block_braces.rb +6 -11
  138. data/lib/rubocop/cop/layout/space_inside_hash_literal_braces.rb +1 -2
  139. data/lib/rubocop/cop/layout/space_inside_parens.rb +78 -32
  140. data/lib/rubocop/cop/layout/space_inside_reference_brackets.rb +1 -2
  141. data/lib/rubocop/cop/layout/trailing_whitespace.rb +24 -1
  142. data/lib/rubocop/cop/legacy/corrections_proxy.rb +2 -8
  143. data/lib/rubocop/cop/legacy/corrector.rb +1 -3
  144. data/lib/rubocop/cop/lint/ambiguous_assignment.rb +1 -6
  145. data/lib/rubocop/cop/lint/ambiguous_block_association.rb +14 -7
  146. data/lib/rubocop/cop/lint/ambiguous_operator_precedence.rb +111 -0
  147. data/lib/rubocop/cop/lint/ambiguous_range.rb +105 -0
  148. data/lib/rubocop/cop/lint/ambiguous_regexp_literal.rb +5 -2
  149. data/lib/rubocop/cop/lint/assignment_in_condition.rb +7 -5
  150. data/lib/rubocop/cop/lint/big_decimal_new.rb +1 -0
  151. data/lib/rubocop/cop/lint/binary_operator_with_identical_operands.rb +18 -5
  152. data/lib/rubocop/cop/lint/boolean_symbol.rb +7 -2
  153. data/lib/rubocop/cop/lint/constant_definition_in_block.rb +2 -0
  154. data/lib/rubocop/cop/lint/constant_resolution.rb +2 -2
  155. data/lib/rubocop/cop/lint/debugger.rb +59 -15
  156. data/lib/rubocop/cop/lint/deprecated_class_methods.rb +83 -41
  157. data/lib/rubocop/cop/lint/deprecated_constants.rb +5 -4
  158. data/lib/rubocop/cop/lint/deprecated_open_ssl_constant.rb +16 -9
  159. data/lib/rubocop/cop/lint/disjunctive_assignment_in_constructor.rb +24 -1
  160. data/lib/rubocop/cop/lint/duplicate_branch.rb +4 -4
  161. data/lib/rubocop/cop/lint/duplicate_hash_key.rb +1 -3
  162. data/lib/rubocop/cop/lint/duplicate_methods.rb +14 -12
  163. data/lib/rubocop/cop/lint/duplicate_require.rb +3 -2
  164. data/lib/rubocop/cop/lint/each_with_object_argument.rb +1 -0
  165. data/lib/rubocop/cop/lint/else_layout.rb +12 -10
  166. data/lib/rubocop/cop/lint/empty_block.rb +18 -2
  167. data/lib/rubocop/cop/lint/empty_ensure.rb +1 -3
  168. data/lib/rubocop/cop/lint/empty_file.rb +1 -3
  169. data/lib/rubocop/cop/lint/empty_in_pattern.rb +62 -0
  170. data/lib/rubocop/cop/lint/empty_interpolation.rb +1 -3
  171. data/lib/rubocop/cop/lint/ensure_return.rb +1 -3
  172. data/lib/rubocop/cop/lint/erb_new_arguments.rb +4 -7
  173. data/lib/rubocop/cop/lint/float_out_of_range.rb +1 -2
  174. data/lib/rubocop/cop/lint/format_parameter_mismatch.rb +4 -6
  175. data/lib/rubocop/cop/lint/hash_compare_by_identity.rb +13 -3
  176. data/lib/rubocop/cop/lint/heredoc_method_call_position.rb +1 -2
  177. data/lib/rubocop/cop/lint/implicit_string_concatenation.rb +1 -2
  178. data/lib/rubocop/cop/lint/incompatible_io_select_with_fiber_scheduler.rb +67 -0
  179. data/lib/rubocop/cop/lint/ineffective_access_modifier.rb +4 -7
  180. data/lib/rubocop/cop/lint/inherit_exception.rb +2 -2
  181. data/lib/rubocop/cop/lint/interpolation_check.rb +8 -11
  182. data/lib/rubocop/cop/lint/literal_as_condition.rb +13 -1
  183. data/lib/rubocop/cop/lint/literal_in_interpolation.rb +3 -6
  184. data/lib/rubocop/cop/lint/loop.rb +5 -5
  185. data/lib/rubocop/cop/lint/missing_cop_enable_directive.rb +32 -21
  186. data/lib/rubocop/cop/lint/missing_super.rb +1 -2
  187. data/lib/rubocop/cop/lint/mixed_regexp_capture_types.rb +1 -2
  188. data/lib/rubocop/cop/lint/multiple_comparison.rb +5 -4
  189. data/lib/rubocop/cop/lint/nested_method_definition.rb +4 -2
  190. data/lib/rubocop/cop/lint/nested_percent_literal.rb +2 -4
  191. data/lib/rubocop/cop/lint/next_without_accumulator.rb +1 -0
  192. data/lib/rubocop/cop/lint/non_deterministic_require_order.rb +13 -4
  193. data/lib/rubocop/cop/lint/non_local_exit_from_iterator.rb +3 -0
  194. data/lib/rubocop/cop/lint/number_conversion.rb +25 -6
  195. data/lib/rubocop/cop/lint/numbered_parameter_assignment.rb +1 -1
  196. data/lib/rubocop/cop/lint/or_assignment_to_constant.rb +4 -2
  197. data/lib/rubocop/cop/lint/ordered_magic_comments.rb +1 -2
  198. data/lib/rubocop/cop/lint/out_of_range_regexp_ref.rb +18 -3
  199. data/lib/rubocop/cop/lint/parentheses_as_grouped_expression.rb +1 -3
  200. data/lib/rubocop/cop/lint/percent_string_array.rb +11 -1
  201. data/lib/rubocop/cop/lint/percent_symbol_array.rb +2 -4
  202. data/lib/rubocop/cop/lint/raise_exception.rb +7 -2
  203. data/lib/rubocop/cop/lint/rand_one.rb +2 -2
  204. data/lib/rubocop/cop/lint/redundant_cop_disable_directive.rb +108 -90
  205. data/lib/rubocop/cop/lint/redundant_cop_enable_directive.rb +5 -0
  206. data/lib/rubocop/cop/lint/redundant_require_statement.rb +1 -0
  207. data/lib/rubocop/cop/lint/redundant_safe_navigation.rb +7 -7
  208. data/lib/rubocop/cop/lint/redundant_splat_expansion.rb +10 -10
  209. data/lib/rubocop/cop/lint/redundant_string_coercion.rb +2 -2
  210. data/lib/rubocop/cop/lint/redundant_with_index.rb +2 -4
  211. data/lib/rubocop/cop/lint/redundant_with_object.rb +2 -4
  212. data/lib/rubocop/cop/lint/regexp_as_condition.rb +1 -3
  213. data/lib/rubocop/cop/lint/require_parentheses.rb +2 -4
  214. data/lib/rubocop/cop/lint/require_relative_self_path.rb +50 -0
  215. data/lib/rubocop/cop/lint/rescue_exception.rb +1 -2
  216. data/lib/rubocop/cop/lint/rescue_type.rb +2 -7
  217. data/lib/rubocop/cop/lint/return_in_void_context.rb +1 -2
  218. data/lib/rubocop/cop/lint/safe_navigation_chain.rb +2 -2
  219. data/lib/rubocop/cop/lint/safe_navigation_consistency.rb +4 -10
  220. data/lib/rubocop/cop/lint/safe_navigation_with_empty.rb +2 -2
  221. data/lib/rubocop/cop/lint/send_with_mixin_argument.rb +3 -7
  222. data/lib/rubocop/cop/lint/shadowed_argument.rb +6 -12
  223. data/lib/rubocop/cop/lint/shadowed_exception.rb +7 -8
  224. data/lib/rubocop/cop/lint/shadowing_outer_local_variable.rb +2 -1
  225. data/lib/rubocop/cop/lint/struct_new_override.rb +2 -2
  226. data/lib/rubocop/cop/lint/suppressed_exception.rb +44 -1
  227. data/lib/rubocop/cop/lint/symbol_conversion.rb +86 -11
  228. data/lib/rubocop/cop/lint/syntax.rb +1 -3
  229. data/lib/rubocop/cop/lint/to_enum_arguments.rb +3 -0
  230. data/lib/rubocop/cop/lint/to_json.rb +1 -2
  231. data/lib/rubocop/cop/lint/trailing_comma_in_attribute_declaration.rb +1 -3
  232. data/lib/rubocop/cop/lint/triple_quotes.rb +1 -1
  233. data/lib/rubocop/cop/lint/underscore_prefixed_variable_name.rb +1 -3
  234. data/lib/rubocop/cop/lint/unexpected_block_arity.rb +8 -3
  235. data/lib/rubocop/cop/lint/unified_integer.rb +1 -0
  236. data/lib/rubocop/cop/lint/unmodified_reduce_accumulator.rb +5 -0
  237. data/lib/rubocop/cop/lint/unreachable_code.rb +3 -5
  238. data/lib/rubocop/cop/lint/unreachable_loop.rb +15 -7
  239. data/lib/rubocop/cop/lint/unused_block_argument.rb +10 -8
  240. data/lib/rubocop/cop/lint/unused_method_argument.rb +4 -5
  241. data/lib/rubocop/cop/lint/uri_escape_unescape.rb +1 -0
  242. data/lib/rubocop/cop/lint/useless_access_modifier.rb +6 -4
  243. data/lib/rubocop/cop/lint/useless_assignment.rb +5 -10
  244. data/lib/rubocop/cop/lint/useless_method_definition.rb +3 -2
  245. data/lib/rubocop/cop/lint/useless_setter_call.rb +9 -7
  246. data/lib/rubocop/cop/lint/useless_times.rb +8 -4
  247. data/lib/rubocop/cop/lint/void.rb +5 -12
  248. data/lib/rubocop/cop/message_annotator.rb +1 -3
  249. data/lib/rubocop/cop/metrics/abc_size.rb +6 -0
  250. data/lib/rubocop/cop/metrics/block_nesting.rb +2 -7
  251. data/lib/rubocop/cop/metrics/class_length.rb +1 -3
  252. data/lib/rubocop/cop/metrics/cyclomatic_complexity.rb +1 -2
  253. data/lib/rubocop/cop/metrics/module_length.rb +3 -6
  254. data/lib/rubocop/cop/metrics/parameter_lists.rb +8 -7
  255. data/lib/rubocop/cop/metrics/perceived_complexity.rb +2 -3
  256. data/lib/rubocop/cop/metrics/utils/abc_size_calculator.rb +5 -8
  257. data/lib/rubocop/cop/metrics/utils/code_length_calculator.rb +8 -6
  258. data/lib/rubocop/cop/metrics/utils/repeated_attribute_discount.rb +4 -7
  259. data/lib/rubocop/cop/migration/department_name.rb +4 -6
  260. data/lib/rubocop/cop/mixin/alignment.rb +12 -7
  261. data/lib/rubocop/cop/mixin/annotation_comment.rb +57 -34
  262. data/lib/rubocop/cop/mixin/check_line_breakable.rb +29 -4
  263. data/lib/rubocop/cop/mixin/code_length.rb +2 -4
  264. data/lib/rubocop/cop/mixin/comments_help.rb +5 -1
  265. data/lib/rubocop/cop/mixin/configurable_enforced_style.rb +2 -2
  266. data/lib/rubocop/cop/mixin/configurable_formatting.rb +3 -8
  267. data/lib/rubocop/cop/mixin/def_node.rb +3 -5
  268. data/lib/rubocop/cop/mixin/documentation_comment.rb +8 -8
  269. data/lib/rubocop/cop/mixin/empty_lines_around_body.rb +6 -7
  270. data/lib/rubocop/cop/mixin/empty_parameter.rb +2 -3
  271. data/lib/rubocop/cop/mixin/end_keyword_alignment.rb +2 -5
  272. data/lib/rubocop/cop/mixin/enforce_superclass.rb +4 -6
  273. data/lib/rubocop/cop/mixin/first_element_line_break.rb +1 -3
  274. data/lib/rubocop/cop/mixin/frozen_string_literal.rb +30 -8
  275. data/lib/rubocop/cop/mixin/gem_declaration.rb +13 -0
  276. data/lib/rubocop/cop/mixin/hash_alignment_styles.rb +17 -9
  277. data/lib/rubocop/cop/mixin/hash_transform_method.rb +16 -25
  278. data/lib/rubocop/cop/mixin/heredoc.rb +5 -0
  279. data/lib/rubocop/cop/mixin/interpolation.rb +1 -3
  280. data/lib/rubocop/cop/mixin/line_length_help.rb +13 -10
  281. data/lib/rubocop/cop/mixin/match_range.rb +2 -5
  282. data/lib/rubocop/cop/mixin/method_complexity.rb +2 -3
  283. data/lib/rubocop/cop/mixin/method_preference.rb +1 -2
  284. data/lib/rubocop/cop/mixin/multiline_element_indentation.rb +5 -4
  285. data/lib/rubocop/cop/mixin/multiline_element_line_breaks.rb +1 -3
  286. data/lib/rubocop/cop/mixin/multiline_expression_indentation.rb +13 -42
  287. data/lib/rubocop/cop/mixin/multiline_literal_brace_layout.rb +2 -3
  288. data/lib/rubocop/cop/mixin/negative_conditional.rb +4 -2
  289. data/lib/rubocop/cop/mixin/ordered_gem_node.rb +10 -5
  290. data/lib/rubocop/cop/mixin/percent_array.rb +17 -8
  291. data/lib/rubocop/cop/mixin/percent_literal.rb +0 -6
  292. data/lib/rubocop/cop/mixin/preceding_following_alignment.rb +14 -12
  293. data/lib/rubocop/cop/mixin/preferred_delimiters.rb +6 -9
  294. data/lib/rubocop/cop/mixin/range_help.rb +10 -13
  295. data/lib/rubocop/cop/mixin/rational_literal.rb +1 -0
  296. data/lib/rubocop/cop/mixin/require_library.rb +59 -0
  297. data/lib/rubocop/cop/mixin/rescue_node.rb +2 -6
  298. data/lib/rubocop/cop/mixin/safe_assignment.rb +6 -2
  299. data/lib/rubocop/cop/mixin/space_after_punctuation.rb +2 -4
  300. data/lib/rubocop/cop/mixin/space_before_punctuation.rb +3 -4
  301. data/lib/rubocop/cop/mixin/statement_modifier.rb +2 -4
  302. data/lib/rubocop/cop/mixin/string_literals_help.rb +7 -5
  303. data/lib/rubocop/cop/mixin/symbol_help.rb +13 -0
  304. data/lib/rubocop/cop/mixin/trailing_body.rb +2 -3
  305. data/lib/rubocop/cop/mixin/trailing_comma.rb +1 -2
  306. data/lib/rubocop/cop/mixin/uncommunicative_name.rb +7 -13
  307. data/lib/rubocop/cop/mixin/unused_argument.rb +1 -3
  308. data/lib/rubocop/cop/mixin/visibility_help.rb +1 -0
  309. data/lib/rubocop/cop/naming/ascii_identifiers.rb +2 -7
  310. data/lib/rubocop/cop/naming/binary_operator_parameter_name.rb +2 -2
  311. data/lib/rubocop/cop/naming/block_parameter_name.rb +1 -1
  312. data/lib/rubocop/cop/naming/constant_name.rb +3 -1
  313. data/lib/rubocop/cop/naming/file_name.rb +7 -16
  314. data/lib/rubocop/cop/naming/inclusive_language.rb +266 -0
  315. data/lib/rubocop/cop/naming/memoized_instance_variable_name.rb +11 -5
  316. data/lib/rubocop/cop/naming/method_name.rb +4 -2
  317. data/lib/rubocop/cop/naming/predicate_name.rb +2 -2
  318. data/lib/rubocop/cop/naming/rescued_exceptions_variable_name.rb +17 -0
  319. data/lib/rubocop/cop/offense.rb +3 -8
  320. data/lib/rubocop/cop/registry.rb +13 -12
  321. data/lib/rubocop/cop/security/eval.rb +1 -0
  322. data/lib/rubocop/cop/security/io_methods.rb +49 -0
  323. data/lib/rubocop/cop/security/json_load.rb +9 -7
  324. data/lib/rubocop/cop/security/marshal_load.rb +1 -0
  325. data/lib/rubocop/cop/security/open.rb +5 -0
  326. data/lib/rubocop/cop/security/yaml_load.rb +5 -0
  327. data/lib/rubocop/cop/style/access_modifier_declarations.rb +4 -5
  328. data/lib/rubocop/cop/style/accessor_grouping.rb +3 -5
  329. data/lib/rubocop/cop/style/alias.rb +6 -12
  330. data/lib/rubocop/cop/style/and_or.rb +8 -1
  331. data/lib/rubocop/cop/style/arguments_forwarding.rb +17 -5
  332. data/lib/rubocop/cop/style/array_coercion.rb +23 -3
  333. data/lib/rubocop/cop/style/array_join.rb +1 -0
  334. data/lib/rubocop/cop/style/ascii_comments.rb +1 -5
  335. data/lib/rubocop/cop/style/attr.rb +2 -3
  336. data/lib/rubocop/cop/style/auto_resource_cleanup.rb +2 -5
  337. data/lib/rubocop/cop/style/bisected_attr_accessor/macro.rb +60 -0
  338. data/lib/rubocop/cop/style/bisected_attr_accessor.rb +59 -71
  339. data/lib/rubocop/cop/style/block_delimiters.rb +50 -2
  340. data/lib/rubocop/cop/style/case_equality.rb +8 -10
  341. data/lib/rubocop/cop/style/case_like_if.rb +21 -6
  342. data/lib/rubocop/cop/style/character_literal.rb +2 -4
  343. data/lib/rubocop/cop/style/class_and_module_children.rb +42 -10
  344. data/lib/rubocop/cop/style/class_equality_comparison.rb +3 -0
  345. data/lib/rubocop/cop/style/class_methods.rb +1 -3
  346. data/lib/rubocop/cop/style/collection_compact.rb +10 -8
  347. data/lib/rubocop/cop/style/collection_methods.rb +8 -6
  348. data/lib/rubocop/cop/style/colon_method_call.rb +2 -3
  349. data/lib/rubocop/cop/style/combinable_loops.rb +6 -4
  350. data/lib/rubocop/cop/style/command_literal.rb +4 -9
  351. data/lib/rubocop/cop/style/comment_annotation.rb +57 -30
  352. data/lib/rubocop/cop/style/commented_keyword.rb +16 -16
  353. data/lib/rubocop/cop/style/conditional_assignment.rb +31 -29
  354. data/lib/rubocop/cop/style/constant_visibility.rb +28 -0
  355. data/lib/rubocop/cop/style/copyright.rb +3 -6
  356. data/lib/rubocop/cop/style/date_time.rb +10 -5
  357. data/lib/rubocop/cop/style/def_with_parentheses.rb +1 -2
  358. data/lib/rubocop/cop/style/dir.rb +1 -0
  359. data/lib/rubocop/cop/style/disable_cops_within_source_code_directive.rb +2 -2
  360. data/lib/rubocop/cop/style/document_dynamic_eval_definition.rb +1 -1
  361. data/lib/rubocop/cop/style/documentation.rb +52 -10
  362. data/lib/rubocop/cop/style/documentation_method.rb +1 -0
  363. data/lib/rubocop/cop/style/double_cop_disable_directive.rb +1 -7
  364. data/lib/rubocop/cop/style/double_negation.rb +30 -8
  365. data/lib/rubocop/cop/style/each_for_simple_loop.rb +2 -2
  366. data/lib/rubocop/cop/style/each_with_object.rb +1 -0
  367. data/lib/rubocop/cop/style/empty_case_condition.rb +2 -7
  368. data/lib/rubocop/cop/style/empty_else.rb +3 -9
  369. data/lib/rubocop/cop/style/empty_literal.rb +21 -9
  370. data/lib/rubocop/cop/style/empty_method.rb +3 -7
  371. data/lib/rubocop/cop/style/encoding.rb +26 -15
  372. data/lib/rubocop/cop/style/end_block.rb +1 -2
  373. data/lib/rubocop/cop/style/endless_method.rb +2 -3
  374. data/lib/rubocop/cop/style/eval_with_location.rb +91 -31
  375. data/lib/rubocop/cop/style/even_odd.rb +1 -0
  376. data/lib/rubocop/cop/style/expand_path_arguments.rb +4 -3
  377. data/lib/rubocop/cop/style/explicit_block_argument.rb +48 -15
  378. data/lib/rubocop/cop/style/exponential_notation.rb +6 -7
  379. data/lib/rubocop/cop/style/float_division.rb +14 -2
  380. data/lib/rubocop/cop/style/format_string.rb +2 -0
  381. data/lib/rubocop/cop/style/format_string_token.rb +2 -4
  382. data/lib/rubocop/cop/style/frozen_string_literal_comment.rb +15 -12
  383. data/lib/rubocop/cop/style/global_std_stream.rb +5 -0
  384. data/lib/rubocop/cop/style/guard_clause.rb +3 -7
  385. data/lib/rubocop/cop/style/hash_as_last_array_item.rb +11 -0
  386. data/lib/rubocop/cop/style/hash_conversion.rb +133 -0
  387. data/lib/rubocop/cop/style/hash_each_methods.rb +25 -3
  388. data/lib/rubocop/cop/style/hash_except.rb +5 -3
  389. data/lib/rubocop/cop/style/hash_like_case.rb +2 -2
  390. data/lib/rubocop/cop/style/hash_syntax.rb +21 -25
  391. data/lib/rubocop/cop/style/hash_transform_keys.rb +8 -9
  392. data/lib/rubocop/cop/style/hash_transform_values.rb +8 -6
  393. data/lib/rubocop/cop/style/identical_conditional_branches.rb +83 -8
  394. data/lib/rubocop/cop/style/if_unless_modifier.rb +40 -13
  395. data/lib/rubocop/cop/style/if_with_boolean_literal_branches.rb +20 -4
  396. data/lib/rubocop/cop/style/implicit_runtime_error.rb +1 -0
  397. data/lib/rubocop/cop/style/in_pattern_then.rb +56 -0
  398. data/lib/rubocop/cop/style/infinite_loop.rb +6 -8
  399. data/lib/rubocop/cop/style/inverse_methods.rb +14 -9
  400. data/lib/rubocop/cop/style/ip_addresses.rb +1 -2
  401. data/lib/rubocop/cop/style/lambda.rb +2 -4
  402. data/lib/rubocop/cop/style/lambda_call.rb +1 -2
  403. data/lib/rubocop/cop/style/line_end_concatenation.rb +19 -13
  404. data/lib/rubocop/cop/style/method_call_with_args_parentheses/omit_parentheses.rb +32 -21
  405. data/lib/rubocop/cop/style/method_call_with_args_parentheses.rb +47 -3
  406. data/lib/rubocop/cop/style/method_call_without_args_parentheses.rb +1 -2
  407. data/lib/rubocop/cop/style/method_called_on_do_end_block.rb +2 -4
  408. data/lib/rubocop/cop/style/method_def_parentheses.rb +14 -9
  409. data/lib/rubocop/cop/style/min_max.rb +2 -2
  410. data/lib/rubocop/cop/style/missing_else.rb +9 -4
  411. data/lib/rubocop/cop/style/missing_respond_to_missing.rb +1 -2
  412. data/lib/rubocop/cop/style/mixin_grouping.rb +4 -10
  413. data/lib/rubocop/cop/style/mixin_usage.rb +3 -2
  414. data/lib/rubocop/cop/style/module_function.rb +16 -15
  415. data/lib/rubocop/cop/style/multiline_block_chain.rb +1 -2
  416. data/lib/rubocop/cop/style/multiline_in_pattern_then.rb +62 -0
  417. data/lib/rubocop/cop/style/multiline_method_signature.rb +11 -6
  418. data/lib/rubocop/cop/style/multiline_ternary_operator.rb +1 -2
  419. data/lib/rubocop/cop/style/multiline_when_then.rb +3 -12
  420. data/lib/rubocop/cop/style/multiple_comparison.rb +23 -6
  421. data/lib/rubocop/cop/style/mutable_constant.rb +85 -23
  422. data/lib/rubocop/cop/style/negated_if.rb +1 -2
  423. data/lib/rubocop/cop/style/negated_if_else_condition.rb +24 -2
  424. data/lib/rubocop/cop/style/negated_unless.rb +1 -2
  425. data/lib/rubocop/cop/style/nested_modifier.rb +3 -7
  426. data/lib/rubocop/cop/style/nested_ternary_operator.rb +2 -3
  427. data/lib/rubocop/cop/style/next.rb +4 -9
  428. data/lib/rubocop/cop/style/nil_comparison.rb +3 -0
  429. data/lib/rubocop/cop/style/nil_lambda.rb +30 -12
  430. data/lib/rubocop/cop/style/non_nil_check.rb +11 -7
  431. data/lib/rubocop/cop/style/not.rb +2 -2
  432. data/lib/rubocop/cop/style/numbered_parameters.rb +46 -0
  433. data/lib/rubocop/cop/style/numbered_parameters_limit.rb +50 -0
  434. data/lib/rubocop/cop/style/numeric_literals.rb +6 -15
  435. data/lib/rubocop/cop/style/numeric_predicate.rb +10 -7
  436. data/lib/rubocop/cop/style/one_line_conditional.rb +1 -2
  437. data/lib/rubocop/cop/style/option_hash.rb +2 -3
  438. data/lib/rubocop/cop/style/optional_arguments.rb +6 -5
  439. data/lib/rubocop/cop/style/optional_boolean_parameter.rb +14 -4
  440. data/lib/rubocop/cop/style/or_assignment.rb +4 -6
  441. data/lib/rubocop/cop/style/parallel_assignment.rb +13 -10
  442. data/lib/rubocop/cop/style/parentheses_around_condition.rb +1 -0
  443. data/lib/rubocop/cop/style/percent_literal_delimiters.rb +2 -4
  444. data/lib/rubocop/cop/style/percent_q_literals.rb +3 -4
  445. data/lib/rubocop/cop/style/perl_backrefs.rb +2 -9
  446. data/lib/rubocop/cop/style/preferred_hash_methods.rb +10 -8
  447. data/lib/rubocop/cop/style/proc.rb +2 -2
  448. data/lib/rubocop/cop/style/quoted_symbols.rb +114 -0
  449. data/lib/rubocop/cop/style/raise_args.rb +6 -8
  450. data/lib/rubocop/cop/style/random_with_offset.rb +8 -8
  451. data/lib/rubocop/cop/style/redundant_argument.rb +21 -20
  452. data/lib/rubocop/cop/style/redundant_assignment.rb +2 -3
  453. data/lib/rubocop/cop/style/redundant_begin.rb +72 -7
  454. data/lib/rubocop/cop/style/redundant_capital_w.rb +1 -2
  455. data/lib/rubocop/cop/style/redundant_condition.rb +4 -8
  456. data/lib/rubocop/cop/style/redundant_conditional.rb +5 -6
  457. data/lib/rubocop/cop/style/redundant_exception.rb +5 -6
  458. data/lib/rubocop/cop/style/redundant_fetch_block.rb +6 -0
  459. data/lib/rubocop/cop/style/redundant_file_extension_in_require.rb +13 -3
  460. data/lib/rubocop/cop/style/redundant_freeze.rb +6 -6
  461. data/lib/rubocop/cop/style/redundant_interpolation.rb +2 -3
  462. data/lib/rubocop/cop/style/redundant_parentheses.rb +21 -20
  463. data/lib/rubocop/cop/style/redundant_percent_q.rb +3 -5
  464. data/lib/rubocop/cop/style/redundant_regexp_character_class.rb +1 -1
  465. data/lib/rubocop/cop/style/redundant_regexp_escape.rb +1 -4
  466. data/lib/rubocop/cop/style/redundant_return.rb +6 -4
  467. data/lib/rubocop/cop/style/redundant_self.rb +42 -10
  468. data/lib/rubocop/cop/style/redundant_self_assignment.rb +8 -5
  469. data/lib/rubocop/cop/style/redundant_self_assignment_branch.rb +83 -0
  470. data/lib/rubocop/cop/style/redundant_sort.rb +56 -25
  471. data/lib/rubocop/cop/style/redundant_sort_by.rb +1 -0
  472. data/lib/rubocop/cop/style/regexp_literal.rb +15 -10
  473. data/lib/rubocop/cop/style/rescue_modifier.rb +21 -14
  474. data/lib/rubocop/cop/style/rescue_standard_error.rb +5 -7
  475. data/lib/rubocop/cop/style/return_nil.rb +8 -2
  476. data/lib/rubocop/cop/style/safe_navigation.rb +25 -23
  477. data/lib/rubocop/cop/style/sample.rb +1 -0
  478. data/lib/rubocop/cop/style/select_by_regexp.rb +139 -0
  479. data/lib/rubocop/cop/style/semicolon.rb +32 -24
  480. data/lib/rubocop/cop/style/send.rb +1 -2
  481. data/lib/rubocop/cop/style/signal_exception.rb +6 -7
  482. data/lib/rubocop/cop/style/single_argument_dig.rb +7 -2
  483. data/lib/rubocop/cop/style/single_line_block_params.rb +5 -6
  484. data/lib/rubocop/cop/style/single_line_methods.rb +45 -18
  485. data/lib/rubocop/cop/style/slicing_with_range.rb +14 -0
  486. data/lib/rubocop/cop/style/sole_nested_conditional.rb +35 -7
  487. data/lib/rubocop/cop/style/special_global_vars.rb +33 -20
  488. data/lib/rubocop/cop/style/stabby_lambda_parentheses.rb +1 -2
  489. data/lib/rubocop/cop/style/static_class.rb +5 -5
  490. data/lib/rubocop/cop/style/stderr_puts.rb +3 -6
  491. data/lib/rubocop/cop/style/string_chars.rb +41 -0
  492. data/lib/rubocop/cop/style/string_concatenation.rb +45 -15
  493. data/lib/rubocop/cop/style/string_hash_keys.rb +6 -0
  494. data/lib/rubocop/cop/style/string_literals.rb +5 -7
  495. data/lib/rubocop/cop/style/string_literals_in_interpolation.rb +1 -0
  496. data/lib/rubocop/cop/style/strip.rb +1 -0
  497. data/lib/rubocop/cop/style/struct_inheritance.rb +15 -0
  498. data/lib/rubocop/cop/style/swap_values.rb +5 -3
  499. data/lib/rubocop/cop/style/symbol_array.rb +3 -3
  500. data/lib/rubocop/cop/style/symbol_literal.rb +1 -3
  501. data/lib/rubocop/cop/style/symbol_proc.rb +55 -10
  502. data/lib/rubocop/cop/style/ternary_parentheses.rb +4 -6
  503. data/lib/rubocop/cop/style/top_level_method_definition.rb +83 -0
  504. data/lib/rubocop/cop/style/trailing_body_on_method_definition.rb +6 -2
  505. data/lib/rubocop/cop/style/trailing_comma_in_block_args.rb +21 -6
  506. data/lib/rubocop/cop/style/trailing_method_end_statement.rb +3 -6
  507. data/lib/rubocop/cop/style/trailing_underscore_variable.rb +4 -10
  508. data/lib/rubocop/cop/style/trivial_accessors.rb +69 -5
  509. data/lib/rubocop/cop/style/unless_else.rb +1 -2
  510. data/lib/rubocop/cop/style/unless_logical_operators.rb +105 -0
  511. data/lib/rubocop/cop/style/unpack_first.rb +2 -1
  512. data/lib/rubocop/cop/style/variable_interpolation.rb +1 -1
  513. data/lib/rubocop/cop/style/when_then.rb +4 -2
  514. data/lib/rubocop/cop/style/while_until_modifier.rb +1 -2
  515. data/lib/rubocop/cop/style/word_array.rb +22 -5
  516. data/lib/rubocop/cop/style/yoda_condition.rb +28 -18
  517. data/lib/rubocop/cop/style/zero_length_predicate.rb +12 -2
  518. data/lib/rubocop/cop/team.rb +2 -5
  519. data/lib/rubocop/cop/util.rb +29 -16
  520. data/lib/rubocop/cop/utils/format_string.rb +1 -3
  521. data/lib/rubocop/cop/variable_force/assignment.rb +1 -2
  522. data/lib/rubocop/cop/variable_force/branch.rb +16 -2
  523. data/lib/rubocop/cop/variable_force/reference.rb +1 -3
  524. data/lib/rubocop/cop/variable_force/scope.rb +4 -8
  525. data/lib/rubocop/cop/variable_force/variable.rb +2 -4
  526. data/lib/rubocop/cop/variable_force/variable_table.rb +1 -1
  527. data/lib/rubocop/cop/variable_force.rb +6 -15
  528. data/lib/rubocop/cops_documentation_generator.rb +24 -26
  529. data/lib/rubocop/directive_comment.rb +123 -11
  530. data/lib/rubocop/ext/regexp_parser.rb +3 -6
  531. data/lib/rubocop/file_finder.rb +1 -3
  532. data/lib/rubocop/formatter/clang_style_formatter.rb +4 -2
  533. data/lib/rubocop/formatter/disabled_config_formatter.rb +3 -8
  534. data/lib/rubocop/formatter/git_hub_actions_formatter.rb +2 -6
  535. data/lib/rubocop/formatter/html_formatter.rb +4 -10
  536. data/lib/rubocop/formatter/json_formatter.rb +1 -5
  537. data/lib/rubocop/formatter/junit_formatter.rb +23 -14
  538. data/lib/rubocop/formatter/offense_count_formatter.rb +1 -1
  539. data/lib/rubocop/formatter/progress_formatter.rb +1 -3
  540. data/lib/rubocop/formatter/tap_formatter.rb +4 -2
  541. data/lib/rubocop/formatter/worst_offenders_formatter.rb +1 -1
  542. data/lib/rubocop/magic_comment.rb +45 -16
  543. data/lib/rubocop/name_similarity.rb +1 -1
  544. data/lib/rubocop/options.rb +153 -159
  545. data/lib/rubocop/path_util.rb +1 -3
  546. data/lib/rubocop/rake_task.rb +4 -1
  547. data/lib/rubocop/remote_config.rb +13 -8
  548. data/lib/rubocop/result_cache.rb +8 -15
  549. data/lib/rubocop/rspec/cop_helper.rb +3 -3
  550. data/lib/rubocop/rspec/expect_offense.rb +11 -12
  551. data/lib/rubocop/rspec/parallel_formatter.rb +90 -0
  552. data/lib/rubocop/rspec/shared_contexts.rb +8 -15
  553. data/lib/rubocop/rspec/support.rb +1 -0
  554. data/lib/rubocop/runner.rb +9 -17
  555. data/lib/rubocop/target_finder.rb +20 -17
  556. data/lib/rubocop/target_ruby.rb +25 -21
  557. data/lib/rubocop/version.rb +1 -1
  558. data/lib/rubocop.rb +30 -3
  559. metadata +44 -11
  560. data/lib/rubocop/core_ext/hash.rb +0 -20
@@ -34,8 +34,7 @@ module RuboCop
34
34
  # interpolation should not be removed if the expanded value
35
35
  # contains a space character.
36
36
  expanded_value = autocorrected_value(final_node)
37
- return if in_array_percent_literal?(begin_node) &&
38
- /\s/.match?(expanded_value)
37
+ return if in_array_percent_literal?(begin_node) && /\s/.match?(expanded_value)
39
38
 
40
39
  add_offense(final_node) do |corrector|
41
40
  return if final_node.dstr_type? # nested, fixed in next iteration
@@ -56,8 +55,7 @@ module RuboCop
56
55
 
57
56
  def special_keyword?(node)
58
57
  # handle strings like __FILE__
59
- (node.str_type? && !node.loc.respond_to?(:begin)) ||
60
- node.source_range.is?('__LINE__')
58
+ (node.str_type? && !node.loc.respond_to?(:begin)) || node.source_range.is?('__LINE__')
61
59
  end
62
60
 
63
61
  def autocorrected_value(node)
@@ -101,8 +99,7 @@ module RuboCop
101
99
  # Does node print its own source when converted to a string?
102
100
  def prints_as_self?(node)
103
101
  node.basic_literal? ||
104
- (COMPOSITE.include?(node.type) &&
105
- node.children.all? { |child| prints_as_self?(child) })
102
+ (COMPOSITE.include?(node.type) && node.children.all? { |child| prints_as_self?(child) })
106
103
  end
107
104
 
108
105
  def space_literal?(node)
@@ -5,9 +5,10 @@ module RuboCop
5
5
  module Lint
6
6
  # This cop checks for uses of `begin...end while/until something`.
7
7
  #
8
- # The cop is marked as unsafe because behaviour can change in some cases, including
9
- # if a local variable inside the loop body is accessed outside of it, or if the
10
- # loop body raises a `StopIteration` exception (which `Kernel#loop` rescues).
8
+ # @safety
9
+ # The cop is unsafe because behaviour can change in some cases, including
10
+ # if a local variable inside the loop body is accessed outside of it, or if the
11
+ # loop body raises a `StopIteration` exception (which `Kernel#loop` rescues).
11
12
  #
12
13
  # @example
13
14
  #
@@ -49,8 +50,7 @@ module RuboCop
49
50
  class Loop < Base
50
51
  extend AutoCorrector
51
52
 
52
- MSG = 'Use `Kernel#loop` with `break` rather than ' \
53
- '`begin/end/until`(or `while`).'
53
+ MSG = 'Use `Kernel#loop` with `break` rather than `begin/end/until`(or `while`).'
54
54
 
55
55
  def on_while_post(node)
56
56
  register_offense(node)
@@ -45,41 +45,52 @@ module RuboCop
45
45
  class MissingCopEnableDirective < Base
46
46
  include RangeHelp
47
47
 
48
- MSG = 'Re-enable %<cop>s cop with `# rubocop:enable` after ' \
49
- 'disabling it.'
50
- MSG_BOUND = 'Re-enable %<cop>s cop within %<max_range>s lines after ' \
51
- 'disabling it.'
48
+ MSG = 'Re-enable %<cop>s %<type>s with `# rubocop:enable` after disabling it.'
49
+ MSG_BOUND = 'Re-enable %<cop>s %<type>s within %<max_range>s lines after disabling it.'
52
50
 
53
- # rubocop:disable Metrics/AbcSize
54
51
  def on_new_investigation
55
- max_range = cop_config['MaximumRangeSize']
56
- processed_source.disabled_line_ranges.each do |cop, line_ranges|
57
- line_ranges.each do |line_range|
58
- # This has to remain a strict inequality to handle
59
- # the case when max_range is Float::INFINITY
60
- next if line_range.max - line_range.min < max_range + 2
52
+ each_missing_enable do |cop, line_range|
53
+ # This has to remain a strict inequality to handle
54
+ # the case when max_range is Float::INFINITY
55
+ next if line_range.max - line_range.min < max_range + 2
61
56
 
62
- range = source_range(processed_source.buffer,
63
- line_range.min,
64
- (0..0))
57
+ range = source_range(processed_source.buffer, line_range.min, (0..0))
58
+ comment = processed_source.comment_at_line(line_range.begin)
65
59
 
66
- add_offense(range, message: message(max_range: max_range, cop: cop))
67
- end
60
+ add_offense(range, message: message(cop, comment))
68
61
  end
69
62
  end
70
- # rubocop:enable Metrics/AbcSize
71
63
 
72
64
  private
73
65
 
74
- def message(max_range:, cop:)
66
+ def each_missing_enable
67
+ processed_source.disabled_line_ranges.each do |cop, line_ranges|
68
+ line_ranges.each { |line_range| yield cop, line_range }
69
+ end
70
+ end
71
+
72
+ def max_range
73
+ @max_range ||= cop_config['MaximumRangeSize']
74
+ end
75
+
76
+ def message(cop, comment, type = 'cop')
77
+ if department_enabled?(cop, comment)
78
+ type = 'department'
79
+ cop = cop.split('/').first
80
+ end
81
+
75
82
  if max_range == Float::INFINITY
76
- format(MSG, cop: cop)
83
+ format(MSG, cop: cop, type: type)
77
84
  else
78
- format(MSG_BOUND, cop: cop, max_range: max_range)
85
+ format(MSG_BOUND, cop: cop, type: type, max_range: max_range)
79
86
  end
80
87
  end
88
+
89
+ def department_enabled?(cop, comment)
90
+ DirectiveComment.new(comment).in_directive_department?(cop)
91
+ end
81
92
  end
82
93
  end
83
94
  end
84
95
  end
85
- # rubocop:enable Lint/RedundantCopDisableDirective, Layout/SpaceAroundOperators
96
+ # rubocop:enable Lint/RedundantCopDisableDirective
@@ -53,8 +53,7 @@ module RuboCop
53
53
  singleton_method_added singleton_method_removed
54
54
  singleton_method_undefined].freeze
55
55
 
56
- CALLBACKS = (CLASS_LIFECYCLE_CALLBACKS +
57
- METHOD_LIFECYCLE_CALLBACKS).to_set.freeze
56
+ CALLBACKS = (CLASS_LIFECYCLE_CALLBACKS + METHOD_LIFECYCLE_CALLBACKS).to_set.freeze
58
57
 
59
58
  def on_def(node)
60
59
  return unless offender?(node)
@@ -21,8 +21,7 @@ module RuboCop
21
21
  # /(FOO)(BAR)/
22
22
  #
23
23
  class MixedRegexpCaptureTypes < Base
24
- MSG = 'Do not mix named captures and numbered captures ' \
25
- 'in a Regexp literal.'
24
+ MSG = 'Do not mix named captures and numbered captures in a Regexp literal.'
26
25
 
27
26
  def on_regexp(node)
28
27
  return if node.interpolation?
@@ -11,14 +11,10 @@ module RuboCop
11
11
  # @example
12
12
  #
13
13
  # # bad
14
- #
15
14
  # x < y < z
16
15
  # 10 <= x <= 20
17
16
  #
18
- # @example
19
- #
20
17
  # # good
21
- #
22
18
  # x < y && y < z
23
19
  # 10 <= x && x <= 20
24
20
  class MultipleComparison < Base
@@ -26,14 +22,19 @@ module RuboCop
26
22
 
27
23
  MSG = 'Use the `&&` operator to compare multiple values.'
28
24
  COMPARISON_METHODS = %i[< > <= >=].freeze
25
+ SET_OPERATION_OPERATORS = %i[& | ^].freeze
29
26
  RESTRICT_ON_SEND = COMPARISON_METHODS
30
27
 
28
+ # @!method multiple_compare?(node)
31
29
  def_node_matcher :multiple_compare?, <<~PATTERN
32
30
  (send (send _ {:< :> :<= :>=} $_) {:#{COMPARISON_METHODS.join(' :')}} _)
33
31
  PATTERN
34
32
 
35
33
  def on_send(node)
36
34
  return unless (center = multiple_compare?(node))
35
+ # It allows multiple comparison using `&`, `|`, and `^` set operation operators.
36
+ # e.g. `x >= y & y < z`
37
+ return if center.send_type? && SET_OPERATION_OPERATORS.include?(center.method_name)
37
38
 
38
39
  add_offense(node) do |corrector|
39
40
  new_center = "#{center.source} && #{center.source}"
@@ -55,8 +55,7 @@ module RuboCop
55
55
  # end
56
56
  # end
57
57
  class NestedMethodDefinition < Base
58
- MSG = 'Method definitions must not be nested. ' \
59
- 'Use `lambda` instead.'
58
+ MSG = 'Method definitions must not be nested. Use `lambda` instead.'
60
59
 
61
60
  def on_def(node)
62
61
  subject, = *node
@@ -81,14 +80,17 @@ module RuboCop
81
80
  class_or_module_or_struct_new_call?(child)
82
81
  end
83
82
 
83
+ # @!method eval_call?(node)
84
84
  def_node_matcher :eval_call?, <<~PATTERN
85
85
  (block (send _ {:instance_eval :class_eval :module_eval} ...) ...)
86
86
  PATTERN
87
87
 
88
+ # @!method exec_call?(node)
88
89
  def_node_matcher :exec_call?, <<~PATTERN
89
90
  (block (send _ {:instance_exec :class_exec :module_exec} ...) ...)
90
91
  PATTERN
91
92
 
93
+ # @!method class_or_module_or_struct_new_call?(node)
92
94
  def_node_matcher :class_or_module_or_struct_new_call?, <<~PATTERN
93
95
  (block (send (const {nil? cbase} {:Class :Module :Struct}) :new ...) ...)
94
96
  PATTERN
@@ -33,15 +33,13 @@ module RuboCop
33
33
  include PercentLiteral
34
34
 
35
35
  MSG = 'Within percent literals, nested percent literals do not ' \
36
- 'function and may be unwanted in the result.'
36
+ 'function and may be unwanted in the result.'
37
37
 
38
38
  # The array of regular expressions representing percent literals that,
39
39
  # if found within a percent literal expression, will cause a
40
40
  # NestedPercentLiteral violation to be emitted.
41
41
  PERCENT_LITERAL_TYPES = PreferredDelimiters::PERCENT_LITERAL_TYPES
42
- REGEXES = PERCENT_LITERAL_TYPES.map do |percent_literal|
43
- /\A#{percent_literal}\W/
44
- end.freeze
42
+ REGEXES = PERCENT_LITERAL_TYPES.map { |percent_literal| /\A#{percent_literal}\W/ }.freeze
45
43
 
46
44
  def on_array(node)
47
45
  process(node, *PERCENT_LITERAL_TYPES)
@@ -25,6 +25,7 @@ module RuboCop
25
25
  class NextWithoutAccumulator < Base
26
26
  MSG = 'Use `next` with an accumulator argument in a `reduce`.'
27
27
 
28
+ # @!method on_body_of_reduce(node)
28
29
  def_node_matcher :on_body_of_reduce, <<~PATTERN
29
30
  (block (send _recv {:reduce :inject} !sym) _blockargs $(begin ...))
30
31
  PATTERN
@@ -14,7 +14,11 @@ module RuboCop
14
14
  # `Dir.glob` and `Dir[]` sort globbed results by default in Ruby 3.0.
15
15
  # So all bad cases are acceptable when Ruby 3.0 or higher are used.
16
16
  #
17
- # This cop will be deprecated and removed when supporting only Ruby 3.0 and higher.
17
+ # NOTE: This cop will be deprecated and removed when supporting only Ruby 3.0 and higher.
18
+ #
19
+ # @safety
20
+ # This cop is unsafe in the case where sorting files changes existing
21
+ # expected behaviour.
18
22
  #
19
23
  # @example
20
24
  #
@@ -66,9 +70,7 @@ module RuboCop
66
70
  loop_variable(node.arguments) do |var_name|
67
71
  return unless var_is_required?(node.body, var_name)
68
72
 
69
- add_offense(node.send_node) do |corrector|
70
- correct_block(corrector, node.send_node)
71
- end
73
+ add_offense(node.send_node) { |corrector| correct_block(corrector, node.send_node) }
72
74
  end
73
75
  end
74
76
 
@@ -129,32 +131,39 @@ module RuboCop
129
131
  unsorted_dir_glob_pass?(node) || unsorted_dir_each_pass?(node)
130
132
  end
131
133
 
134
+ # @!method unsorted_dir_block?(node)
132
135
  def_node_matcher :unsorted_dir_block?, <<~PATTERN
133
136
  (send (const {nil? cbase} :Dir) :glob ...)
134
137
  PATTERN
135
138
 
139
+ # @!method unsorted_dir_each?(node)
136
140
  def_node_matcher :unsorted_dir_each?, <<~PATTERN
137
141
  (send (send (const {nil? cbase} :Dir) {:[] :glob} ...) :each)
138
142
  PATTERN
139
143
 
144
+ # @!method method_require?(node)
140
145
  def_node_matcher :method_require?, <<~PATTERN
141
146
  (block-pass (send nil? :method (sym :require)))
142
147
  PATTERN
143
148
 
149
+ # @!method unsorted_dir_glob_pass?(node)
144
150
  def_node_matcher :unsorted_dir_glob_pass?, <<~PATTERN
145
151
  (send (const {nil? cbase} :Dir) :glob ...
146
152
  (block-pass (send nil? :method (sym :require))))
147
153
  PATTERN
148
154
 
155
+ # @!method unsorted_dir_each_pass?(node)
149
156
  def_node_matcher :unsorted_dir_each_pass?, <<~PATTERN
150
157
  (send (send (const {nil? cbase} :Dir) {:[] :glob} ...) :each
151
158
  (block-pass (send nil? :method (sym :require))))
152
159
  PATTERN
153
160
 
161
+ # @!method loop_variable(node)
154
162
  def_node_matcher :loop_variable, <<~PATTERN
155
163
  (args (arg $_))
156
164
  PATTERN
157
165
 
166
+ # @!method var_is_required?(node, name)
158
167
  def_node_search :var_is_required?, <<~PATTERN
159
168
  (send nil? :require (lvar %1))
160
169
  PATTERN
@@ -73,7 +73,10 @@ module RuboCop
73
73
  !return_node.children.empty?
74
74
  end
75
75
 
76
+ # @!method chained_send?(node)
76
77
  def_node_matcher :chained_send?, '(send !nil? ...)'
78
+
79
+ # @!method define_method?(node)
77
80
  def_node_matcher :define_method?, <<~PATTERN
78
81
  (send _ {:define_method :define_singleton_method} _)
79
82
  PATTERN
@@ -18,6 +18,11 @@ module RuboCop
18
18
  # cop by default). Similarly, Rails' duration methods do not work well
19
19
  # with `Integer()` and can be ignored with `IgnoredMethods`.
20
20
  #
21
+ # @safety
22
+ # Autocorrection is unsafe because it is not guaranteed that the
23
+ # replacement `Kernel` methods are able to properly handle the
24
+ # input if it is not a standard class.
25
+ #
21
26
  # @example
22
27
  #
23
28
  # # bad
@@ -58,14 +63,17 @@ module RuboCop
58
63
  }.freeze
59
64
  MSG = 'Replace unsafe number conversion with number '\
60
65
  'class parsing, instead of using '\
61
- '%<current>s, use stricter '\
62
- '%<corrected_method>s.'
66
+ '`%<current>s`, use stricter '\
67
+ '`%<corrected_method>s`.'
68
+ CONVERSION_METHODS = %i[Integer Float Complex to_i to_f to_c].freeze
63
69
  METHODS = CONVERSION_METHOD_CLASS_MAPPING.keys.map(&:inspect).join(' ')
64
70
 
71
+ # @!method to_method(node)
65
72
  def_node_matcher :to_method, <<~PATTERN
66
73
  (send $_ ${#{METHODS}})
67
74
  PATTERN
68
75
 
76
+ # @!method to_method_symbol(node)
69
77
  def_node_matcher :to_method_symbol, <<~PATTERN
70
78
  {(send _ $_ ${(sym ${#{METHODS}})} ...)
71
79
  (send _ $_ ${(block_pass (sym ${#{METHODS}}))} ...)}
@@ -95,7 +103,7 @@ module RuboCop
95
103
 
96
104
  def handle_as_symbol(node)
97
105
  to_method_symbol(node) do |receiver, sym_node, to_method|
98
- next if receiver.nil?
106
+ next if receiver.nil? || !node.arguments.one?
99
107
 
100
108
  message = format(
101
109
  MSG,
@@ -103,14 +111,15 @@ module RuboCop
103
111
  corrected_method: correct_sym_method(to_method)
104
112
  )
105
113
  add_offense(node, message: message) do |corrector|
114
+ remove_parentheses(corrector, node) if node.parenthesized?
115
+
106
116
  corrector.replace(sym_node, correct_sym_method(to_method))
107
117
  end
108
118
  end
109
119
  end
110
120
 
111
121
  def correct_method(node, receiver)
112
- format(CONVERSION_METHOD_CLASS_MAPPING[node.method_name],
113
- number_object: receiver.source)
122
+ format(CONVERSION_METHOD_CLASS_MAPPING[node.method_name], number_object: receiver.source)
114
123
  end
115
124
 
116
125
  def correct_sym_method(to_method)
@@ -118,8 +127,14 @@ module RuboCop
118
127
  "{ |i| #{body} }"
119
128
  end
120
129
 
130
+ def remove_parentheses(corrector, node)
131
+ corrector.replace(node.loc.begin, ' ')
132
+ corrector.remove(node.loc.end)
133
+ end
134
+
121
135
  def ignore_receiver?(receiver)
122
- if receiver.send_type? && ignored_method?(receiver.method_name)
136
+ if receiver.numeric_type? || (receiver.send_type? &&
137
+ (conversion_method?(receiver.method_name) || ignored_method?(receiver.method_name)))
123
138
  true
124
139
  elsif (receiver = top_receiver(receiver))
125
140
  receiver.const_type? && ignored_class?(receiver.const_name)
@@ -134,6 +149,10 @@ module RuboCop
134
149
  receiver
135
150
  end
136
151
 
152
+ def conversion_method?(method_name)
153
+ CONVERSION_METHODS.include?(method_name)
154
+ end
155
+
137
156
  def ignored_classes
138
157
  cop_config.fetch('IgnoredClasses', [])
139
158
  end
@@ -10,7 +10,7 @@ module RuboCop
10
10
  # ruby 2.7.2p137 (2020-10-01 revision 5445e04352) [x86_64-darwin19]
11
11
  # -e:1: warning: `_1' is reserved for numbered parameter; consider another name
12
12
  #
13
- # Assiging to numbered parameter (from `_1` to `_9`) cause an error in Ruby 3.0.
13
+ # Assigning to a numbered parameter (from `_1` to `_9`) causes an error in Ruby 3.0.
14
14
  #
15
15
  # % ruby -ve '_1 = :value'
16
16
  # ruby 3.0.0p0 (2020-12-25 revision 95aff21468) [x86_64-darwin19]
@@ -9,8 +9,10 @@ module RuboCop
9
9
  # should always be the same. If constants are assigned in multiple
10
10
  # locations, the result may vary depending on the order of `require`.
11
11
  #
12
- # Also, if you already have such an implementation, auto-correction may
13
- # change the result.
12
+ # @safety
13
+ # This cop is unsafe because code that is already conditionally
14
+ # assigning a constant may have its behaviour changed by
15
+ # auto-correction.
14
16
  #
15
17
  # @example
16
18
  #
@@ -31,8 +31,7 @@ module RuboCop
31
31
  include FrozenStringLiteral
32
32
  extend AutoCorrector
33
33
 
34
- MSG = 'The encoding magic comment should precede all other ' \
35
- 'magic comments.'
34
+ MSG = 'The encoding magic comment should precede all other magic comments.'
36
35
 
37
36
  def on_new_investigation
38
37
  return if processed_source.buffer.source.empty?
@@ -6,6 +6,23 @@ module RuboCop
6
6
  # This cops looks for references of Regexp captures that are out of range
7
7
  # and thus always returns nil.
8
8
  #
9
+ # @safety
10
+ # This cop is unsafe because it is naive in how it determines what
11
+ # references are available based on the last encountered regexp, but
12
+ # it cannot handle some cases, such as conditional regexp matches, which
13
+ # leads to false positives, such as:
14
+ #
15
+ # [source,ruby]
16
+ # ----
17
+ # foo ? /(c)(b)/ =~ str : /(b)/ =~ str
18
+ # do_something if $2
19
+ # # $2 is defined for the first condition but not the second, however
20
+ # # the cop will mark this as an offense.
21
+ # ----
22
+ #
23
+ # This might be a good indication of code that should be refactored,
24
+ # however.
25
+ #
9
26
  # @example
10
27
  #
11
28
  # /(foo)bar/ =~ 'foobar'
@@ -48,9 +65,7 @@ module RuboCop
48
65
  def on_when(node)
49
66
  regexp_conditions = node.conditions.select(&:regexp_type?)
50
67
 
51
- @valid_ref = regexp_conditions.map do |condition|
52
- check_regexp(condition)
53
- end.compact.max
68
+ @valid_ref = regexp_conditions.map { |condition| check_regexp(condition) }.compact.max
54
69
  end
55
70
 
56
71
  def on_nth_ref(node)
@@ -29,9 +29,7 @@ module RuboCop
29
29
 
30
30
  range = space_range(node.first_argument.source_range, space_length)
31
31
 
32
- add_offense(range) do |corrector|
33
- corrector.remove(range)
34
- end
32
+ add_offense(range) { |corrector| corrector.remove(range) }
35
33
  end
36
34
  alias on_csend on_send
37
35
 
@@ -9,6 +9,16 @@ module RuboCop
9
9
  # example, mistranslating an array of literals to percent string notation)
10
10
  # rather than meant to be part of the resulting strings.
11
11
  #
12
+ # @safety
13
+ # The cop is unsafe because the correction changes the values in the array
14
+ # and that might have been done purposely.
15
+ #
16
+ # [source,ruby]
17
+ # ----
18
+ # %w('foo', "bar") #=> ["'foo',", '"bar"']
19
+ # %w(foo bar) #=> ['foo', 'bar']
20
+ # ----
21
+ #
12
22
  # @example
13
23
  #
14
24
  # # bad
@@ -29,7 +39,7 @@ module RuboCop
29
39
  TRAILING_QUOTE = /['"]?,?$/.freeze
30
40
 
31
41
  MSG = "Within `%w`/`%W`, quotes and ',' are unnecessary and may be " \
32
- 'unwanted in the resulting strings.'
42
+ 'unwanted in the resulting strings.'
33
43
 
34
44
  def on_array(node)
35
45
  process(node, '%w', '%W')
@@ -25,7 +25,7 @@ module RuboCop
25
25
  extend AutoCorrector
26
26
 
27
27
  MSG = "Within `%i`/`%I`, ':' and ',' are unnecessary and may be " \
28
- 'unwanted in the resulting symbols.'
28
+ 'unwanted in the resulting symbols.'
29
29
 
30
30
  def on_array(node)
31
31
  process(node, '%i', '%I')
@@ -34,9 +34,7 @@ module RuboCop
34
34
  def on_percent_literal(node)
35
35
  return unless contains_colons_or_commas?(node)
36
36
 
37
- add_offense(node) do |corrector|
38
- autocorrect(corrector, node)
39
- end
37
+ add_offense(node) { |corrector| autocorrect(corrector, node) }
40
38
  end
41
39
 
42
40
  private
@@ -13,6 +13,10 @@ module RuboCop
13
13
  # `Exception`. Alternatively, make `Exception` a fully qualified class
14
14
  # name with an explicit namespace.
15
15
  #
16
+ # @safety
17
+ # This cop is unsafe because it will change the exception class being
18
+ # raised, which is a change in behaviour.
19
+ #
16
20
  # @example
17
21
  # # bad
18
22
  # raise Exception, 'Error message here'
@@ -33,18 +37,19 @@ module RuboCop
33
37
  MSG = 'Use `StandardError` over `Exception`.'
34
38
  RESTRICT_ON_SEND = %i[raise fail].freeze
35
39
 
40
+ # @!method exception?(node)
36
41
  def_node_matcher :exception?, <<~PATTERN
37
42
  (send nil? {:raise :fail} $(const ${cbase nil?} :Exception) ... )
38
43
  PATTERN
39
44
 
45
+ # @!method exception_new_with_message?(node)
40
46
  def_node_matcher :exception_new_with_message?, <<~PATTERN
41
47
  (send nil? {:raise :fail}
42
48
  (send $(const ${cbase nil?} :Exception) :new ... ))
43
49
  PATTERN
44
50
 
45
51
  def on_send(node)
46
- exception?(node, &check(node)) ||
47
- exception_new_with_message?(node, &check(node))
52
+ exception?(node, &check(node)) || exception_new_with_message?(node, &check(node))
48
53
  end
49
54
 
50
55
  private
@@ -21,10 +21,10 @@ module RuboCop
21
21
  #
22
22
  # 0 # just use 0 instead
23
23
  class RandOne < Base
24
- MSG = '`%<method>s` always returns `0`. ' \
25
- 'Perhaps you meant `rand(2)` or `rand`?'
24
+ MSG = '`%<method>s` always returns `0`. Perhaps you meant `rand(2)` or `rand`?'
26
25
  RESTRICT_ON_SEND = %i[rand].freeze
27
26
 
27
+ # @!method rand_one?(node)
28
28
  def_node_matcher :rand_one?, <<~PATTERN
29
29
  (send {(const {nil? cbase} :Kernel) nil?} :rand {(int {-1 1}) (float {-1.0 1.0})})
30
30
  PATTERN