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
@@ -31,8 +31,7 @@ module RuboCop
31
31
  include NilMethods
32
32
  extend AutoCorrector
33
33
 
34
- MSG = 'Ensure that safe navigation is used consistently ' \
35
- 'inside of `&&` and `||`.'
34
+ MSG = 'Ensure that safe navigation is used consistently inside of `&&` and `||`.'
36
35
 
37
36
  def on_csend(node)
38
37
  return unless node.parent&.operator_keyword?
@@ -46,15 +45,12 @@ module RuboCop
46
45
  safe_nav_receiver = node.receiver
47
46
 
48
47
  method_calls = conditions.select(&:send_type?)
49
- unsafe_method_calls =
50
- unsafe_method_calls(method_calls, safe_nav_receiver)
48
+ unsafe_method_calls = unsafe_method_calls(method_calls, safe_nav_receiver)
51
49
 
52
50
  unsafe_method_calls.each do |unsafe_method_call|
53
51
  location = location(node, unsafe_method_call)
54
52
 
55
- add_offense(location) do |corrector|
56
- autocorrect(corrector, unsafe_method_call)
57
- end
53
+ add_offense(location) { |corrector| autocorrect(corrector, unsafe_method_call) }
58
54
 
59
55
  ignore_node(unsafe_method_call)
60
56
  end
@@ -76,9 +72,7 @@ module RuboCop
76
72
  parent = node.parent
77
73
  unless parent &&
78
74
  (parent.operator_keyword? ||
79
- (parent.begin_type? &&
80
- parent.parent &&
81
- parent.parent.operator_keyword?))
75
+ (parent.begin_type? && parent.parent && parent.parent.operator_keyword?))
82
76
  return node
83
77
  end
84
78
 
@@ -22,9 +22,9 @@ module RuboCop
22
22
  class SafeNavigationWithEmpty < Base
23
23
  extend AutoCorrector
24
24
 
25
- MSG = 'Avoid calling `empty?` with the safe navigation operator ' \
26
- 'in conditionals.'
25
+ MSG = 'Avoid calling `empty?` with the safe navigation operator in conditionals.'
27
26
 
27
+ # @!method safe_navigation_empty_in_conditional?(node)
28
28
  def_node_matcher :safe_navigation_empty_in_conditional?, <<~PATTERN
29
29
  (if (csend (send ...) :empty?) ...)
30
30
  PATTERN
@@ -43,6 +43,7 @@ module RuboCop
43
43
  SEND_METHODS = %i[send public_send __send__].freeze
44
44
  RESTRICT_ON_SEND = SEND_METHODS
45
45
 
46
+ # @!method send_with_mixin_argument?(node)
46
47
  def_node_matcher :send_with_mixin_argument?, <<~PATTERN
47
48
  (send
48
49
  (const _ _) {:#{SEND_METHODS.join(' :')}}
@@ -52,9 +53,7 @@ module RuboCop
52
53
 
53
54
  def on_send(node)
54
55
  send_with_mixin_argument?(node) do |method, module_name|
55
- message = message(
56
- method, module_name.source, bad_location(node).source
57
- )
56
+ message = message(method, module_name.source, bad_location(node).source)
58
57
 
59
58
  bad_location = bad_location(node)
60
59
  add_offense(bad_location, message: message) do |corrector|
@@ -72,10 +71,7 @@ module RuboCop
72
71
  end
73
72
 
74
73
  def message(method, module_name, bad_method)
75
- format(
76
- MSG,
77
- method: method, module_name: module_name, bad_method: bad_method
78
- )
74
+ format(MSG, method: method, module_name: module_name, bad_method: bad_method)
79
75
  end
80
76
 
81
77
  def mixin_method?(node)
@@ -64,9 +64,9 @@ module RuboCop
64
64
  # end
65
65
  #
66
66
  class ShadowedArgument < Base
67
- MSG = 'Argument `%<argument>s` was shadowed by a local variable ' \
68
- 'before it was used.'
67
+ MSG = 'Argument `%<argument>s` was shadowed by a local variable before it was used.'
69
68
 
69
+ # @!method uses_var?(node)
70
70
  def_node_search :uses_var?, '(lvar %)'
71
71
 
72
72
  def self.joining_forces
@@ -74,9 +74,7 @@ module RuboCop
74
74
  end
75
75
 
76
76
  def after_leaving_scope(scope, _variable_table)
77
- scope.variables.each_value do |variable|
78
- check_argument(variable)
79
- end
77
+ scope.variables.each_value { |variable| check_argument(variable) }
80
78
  end
81
79
 
82
80
  private
@@ -127,8 +125,7 @@ module RuboCop
127
125
  next false if assignment_node.shorthand_asgn?
128
126
 
129
127
  node_within_block_or_conditional =
130
- node_within_block_or_conditional?(assignment_node.parent,
131
- argument.scope.node)
128
+ node_within_block_or_conditional?(assignment_node.parent, argument.scope.node)
132
129
 
133
130
  unless uses_var?(assignment_node, argument.name)
134
131
  # It's impossible to decide whether a branch or block is executed,
@@ -144,7 +141,7 @@ module RuboCop
144
141
  end
145
142
 
146
143
  def reference_pos(node)
147
- node = node.parent.masgn_type? ? node.parent : node
144
+ node = node.parent if node.parent.masgn_type?
148
145
 
149
146
  node.source_range.begin_pos
150
147
  end
@@ -161,10 +158,7 @@ module RuboCop
161
158
  # Get argument references without assignments' references
162
159
  #
163
160
  def argument_references(argument)
164
- assignment_references = argument
165
- .assignments
166
- .flat_map(&:references)
167
- .map(&:source_range)
161
+ assignment_references = argument.assignments.flat_map(&:references).map(&:source_range)
168
162
 
169
163
  argument.references.reject do |ref|
170
164
  next false unless ref.explicit?
@@ -59,8 +59,7 @@ module RuboCop
59
59
  contains_multiple_levels_of_exceptions?(group)
60
60
  end
61
61
 
62
- return if !rescue_group_rescues_multiple_levels &&
63
- sorted?(rescued_groups)
62
+ return if !rescue_group_rescues_multiple_levels && sorted?(rescued_groups)
64
63
 
65
64
  add_offense(offense_range(rescues))
66
65
  end
@@ -74,18 +73,14 @@ module RuboCop
74
73
  end
75
74
 
76
75
  def rescued_groups_for(rescues)
77
- rescues.map do |group|
78
- evaluate_exceptions(group)
79
- end
76
+ rescues.map { |group| evaluate_exceptions(group) }
80
77
  end
81
78
 
82
79
  def contains_multiple_levels_of_exceptions?(group)
83
80
  # Always treat `Exception` as the highest level exception.
84
81
  return true if group.size > 1 && group.include?(Exception)
85
82
 
86
- group.combination(2).any? do |a, b|
87
- compare_exceptions(a, b)
88
- end
83
+ group.combination(2).any? { |a, b| compare_exceptions(a, b) }
89
84
  end
90
85
 
91
86
  def compare_exceptions(exception, other_exception)
@@ -111,6 +106,9 @@ module RuboCop
111
106
 
112
107
  if rescued_exceptions.any?
113
108
  rescued_exceptions.each_with_object([]) do |exception, converted|
109
+ # FIXME: Workaround `rubocop:disable` comment for JRuby.
110
+ # https://github.com/jruby/jruby/issues/6642
111
+ # rubocop:disable Style/RedundantBegin
114
112
  begin
115
113
  RuboCop::Util.silence_warnings do
116
114
  # Avoid printing deprecation warnings about constants
@@ -119,6 +117,7 @@ module RuboCop
119
117
  rescue NameError
120
118
  converted << nil
121
119
  end
120
+ # rubocop:enable Style/RedundantBegin
122
121
  end
123
122
  else
124
123
  # treat an empty `rescue` as `rescue StandardError`
@@ -10,7 +10,7 @@ module RuboCop
10
10
  #
11
11
  # NOTE: Shadowing of variables in block passed to `Ractor.new` is allowed
12
12
  # because `Ractor` should not access outer variables.
13
- # eg. following syle is encouraged:
13
+ # eg. following style is encouraged:
14
14
  #
15
15
  # worker_id, pipe = env
16
16
  # Ractor.new(worker_id, pipe) do |worker_id, pipe|
@@ -42,6 +42,7 @@ module RuboCop
42
42
  class ShadowingOuterLocalVariable < Base
43
43
  MSG = 'Shadowing outer local variable - `%<variable>s`.'
44
44
 
45
+ # @!method ractor_block?(node)
45
46
  def_node_matcher :ractor_block?, <<~PATTERN
46
47
  (block (send (const nil? :Ractor) :new ...) ...)
47
48
  PATTERN
@@ -29,6 +29,7 @@ module RuboCop
29
29
  STRUCT_METHOD_NAMES = Struct.instance_methods
30
30
  STRUCT_MEMBER_NAME_TYPES = %i[sym str].freeze
31
31
 
32
+ # @!method struct_new(node)
32
33
  def_node_matcher :struct_new, <<~PATTERN
33
34
  (send
34
35
  (const ${nil? cbase} :Struct) :new ...)
@@ -47,8 +48,7 @@ module RuboCop
47
48
 
48
49
  next unless STRUCT_METHOD_NAMES.include?(member_name.to_sym)
49
50
 
50
- message = format(MSG, member_name: member_name.inspect,
51
- method_name: member_name.to_s)
51
+ message = format(MSG, member_name: member_name.inspect, method_name: member_name.to_s)
52
52
  add_offense(arg, message: message)
53
53
  end
54
54
  end
@@ -64,12 +64,51 @@ module RuboCop
64
64
  # rescue
65
65
  # # do nothing
66
66
  # end
67
+ #
68
+ # @example AllowNil: true (default)
69
+ #
70
+ # # good
71
+ # def some_method
72
+ # do_something
73
+ # rescue
74
+ # nil
75
+ # end
76
+ #
77
+ # # good
78
+ # begin
79
+ # do_something
80
+ # rescue
81
+ # # do nothing
82
+ # end
83
+ #
84
+ # # good
85
+ # do_something rescue nil
86
+ #
87
+ # @example AllowNil: false
88
+ #
89
+ # # bad
90
+ # def some_method
91
+ # do_something
92
+ # rescue
93
+ # nil
94
+ # end
95
+ #
96
+ # # bad
97
+ # begin
98
+ # do_something
99
+ # rescue
100
+ # nil
101
+ # end
102
+ #
103
+ # # bad
104
+ # do_something rescue nil
67
105
  class SuppressedException < Base
68
106
  MSG = 'Do not suppress exceptions.'
69
107
 
70
108
  def on_resbody(node)
71
- return if node.body
109
+ return if node.body && !nil_body?(node)
72
110
  return if cop_config['AllowComments'] && comment_between_rescue_and_end?(node)
111
+ return if cop_config['AllowNil'] && nil_body?(node)
73
112
 
74
113
  add_offense(node)
75
114
  end
@@ -83,6 +122,10 @@ module RuboCop
83
122
  end_line = ancestor.loc.end.line
84
123
  processed_source[node.first_line...end_line].any? { |line| comment_line?(line) }
85
124
  end
125
+
126
+ def nil_body?(node)
127
+ node.body&.nil_type?
128
+ end
86
129
  end
87
130
  end
88
131
  end
@@ -6,6 +6,12 @@ module RuboCop
6
6
  # This cop checks for uses of literal strings converted to
7
7
  # a symbol where a literal symbol could be used instead.
8
8
  #
9
+ # There are two possible styles for this cop.
10
+ # `strict` (default) will register an offense for any incorrect usage.
11
+ # `consistent` additionally requires hashes to use the same style for
12
+ # every symbol key (ie. if any symbol key needs to be quoted it requires
13
+ # all keys to be quoted).
14
+ #
9
15
  # @example
10
16
  # # bad
11
17
  # 'string'.to_sym
@@ -21,10 +27,50 @@ module RuboCop
21
27
  # :underscored_symbol
22
28
  # :'hyphenated-string'
23
29
  #
30
+ # @example EnforcedStyle: strict (default)
31
+ #
32
+ # # bad
33
+ # {
34
+ # 'a': 1,
35
+ # "b": 2,
36
+ # 'c-d': 3
37
+ # }
38
+ #
39
+ # # good (don't quote keys that don't require quoting)
40
+ # {
41
+ # a: 1,
42
+ # b: 2,
43
+ # 'c-d': 3
44
+ # }
45
+ #
46
+ # @example EnforcedStyle: consistent
47
+ #
48
+ # # bad
49
+ # {
50
+ # a: 1,
51
+ # 'b-c': 2
52
+ # }
53
+ #
54
+ # # good (quote all keys if any need quoting)
55
+ # {
56
+ # 'a': 1,
57
+ # 'b-c': 2
58
+ # }
59
+ #
60
+ # # good (no quoting required)
61
+ # {
62
+ # a: 1,
63
+ # b: 2
64
+ # }
65
+ #
24
66
  class SymbolConversion < Base
25
67
  extend AutoCorrector
68
+ include ConfigurableEnforcedStyle
69
+ include SymbolHelp
26
70
 
27
71
  MSG = 'Unnecessary symbol conversion; use `%<correction>s` instead.'
72
+ MSG_CONSISTENCY = 'Symbol hash key should be quoted for consistency; ' \
73
+ 'use `%<correction>s` instead.'
28
74
  RESTRICT_ON_SEND = %i[to_sym intern].freeze
29
75
 
30
76
  def on_send(node)
@@ -35,7 +81,7 @@ module RuboCop
35
81
  end
36
82
 
37
83
  def on_sym(node)
38
- return if properly_quoted?(node.source, node.value.inspect)
84
+ return if ignored_node?(node) || properly_quoted?(node.source, node.value.inspect)
39
85
 
40
86
  # `alias` arguments are symbols but since a symbol that requires
41
87
  # being quoted is not a valid method identifier, it can be ignored
@@ -51,16 +97,29 @@ module RuboCop
51
97
  register_offense(node, correction: node.value.inspect)
52
98
  end
53
99
 
100
+ def on_hash(node)
101
+ # For `EnforcedStyle: strict`, hash keys are evaluated in `on_sym`
102
+ return unless style == :consistent
103
+
104
+ keys = node.keys.select(&:sym_type?)
105
+
106
+ if keys.any? { |key| requires_quotes?(key) }
107
+ correct_inconsistent_hash_keys(keys)
108
+ else
109
+ # If there are no symbol keys requiring quoting,
110
+ # treat the hash like `EnforcedStyle: strict`.
111
+ keys.each { |key| correct_hash_key(key) }
112
+ end
113
+ end
114
+
54
115
  private
55
116
 
56
117
  def register_offense(node, correction:, message: format(MSG, correction: correction))
57
- add_offense(node, message: message) do |corrector|
58
- corrector.replace(node, correction)
59
- end
118
+ add_offense(node, message: message) { |corrector| corrector.replace(node, correction) }
60
119
  end
61
120
 
62
121
  def properly_quoted?(source, value)
63
- return true if !source.match?(/['"]/) || value.end_with?('=')
122
+ return true if style == :strict && (!source.match?(/['"]/) || value.end_with?('='))
64
123
 
65
124
  source == value ||
66
125
  # `Symbol#inspect` uses double quotes, but allow single-quoted
@@ -68,6 +127,10 @@ module RuboCop
68
127
  source.tr("'", '"') == value
69
128
  end
70
129
 
130
+ def requires_quotes?(sym_node)
131
+ sym_node.value.inspect.match?(/^:".*?"|=$/)
132
+ end
133
+
71
134
  def in_alias?(node)
72
135
  node.parent&.alias_type?
73
136
  end
@@ -76,19 +139,15 @@ module RuboCop
76
139
  node.parent&.array_type? && node.parent&.percent_literal?
77
140
  end
78
141
 
79
- def hash_key?(node)
80
- node.parent&.pair_type? && node == node.parent.child_nodes.first
81
- end
82
-
83
142
  def correct_hash_key(node)
84
143
  # Although some operators can be converted to symbols normally
85
144
  # (ie. `:==`), these are not accepted as hash keys and will
86
145
  # raise a syntax error (eg. `{ ==: ... }`). Therefore, if the
87
- # symbol does not start with an alpha-numeric or underscore, it
146
+ # symbol does not start with an alphanumeric or underscore, it
88
147
  # will be ignored.
89
148
  return unless node.value.to_s.match?(/\A[a-z0-9_]/i)
90
149
 
91
- correction = node.value.inspect.gsub(/\A:/, '')
150
+ correction = node.value.inspect.delete_prefix(':')
92
151
  return if properly_quoted?(node.source, correction)
93
152
 
94
153
  register_offense(
@@ -97,6 +156,22 @@ module RuboCop
97
156
  message: format(MSG, correction: "#{correction}:")
98
157
  )
99
158
  end
159
+
160
+ def correct_inconsistent_hash_keys(keys)
161
+ keys.each do |key|
162
+ ignore_node(key)
163
+
164
+ next if requires_quotes?(key)
165
+ next if properly_quoted?(key.source, %("#{key.value}"))
166
+
167
+ correction = %("#{key.value}")
168
+ register_offense(
169
+ key,
170
+ correction: correction,
171
+ message: format(MSG_CONSISTENCY, correction: "#{correction}:")
172
+ )
173
+ end
174
+ end
100
175
  end
101
176
  end
102
177
  end
@@ -21,9 +21,7 @@ module RuboCop
21
21
  message =
22
22
  "#{diagnostic.message}\n(Using Ruby #{ruby_version} parser; " \
23
23
  'configure using `TargetRubyVersion` parameter, under `AllCops`)'
24
- add_offense(diagnostic.location,
25
- message: message,
26
- severity: diagnostic.level)
24
+ add_offense(diagnostic.location, message: message, severity: diagnostic.level)
27
25
  end
28
26
 
29
27
  def add_offense_from_error(error)
@@ -23,14 +23,17 @@ module RuboCop
23
23
 
24
24
  RESTRICT_ON_SEND = %i[to_enum enum_for].freeze
25
25
 
26
+ # @!method enum_conversion_call?(node)
26
27
  def_node_matcher :enum_conversion_call?, <<~PATTERN
27
28
  (send {nil? self} {:to_enum :enum_for} $_ $...)
28
29
  PATTERN
29
30
 
31
+ # @!method method_name?(node, name)
30
32
  def_node_matcher :method_name?, <<~PATTERN
31
33
  {(send nil? {:__method__ :__callee__}) (sym %1)}
32
34
  PATTERN
33
35
 
36
+ # @!method passing_keyword_arg?(node, name)
34
37
  def_node_matcher :passing_keyword_arg?, <<~PATTERN
35
38
  (pair (sym %1) (lvar %1))
36
39
  PATTERN
@@ -31,8 +31,7 @@ module RuboCop
31
31
  class ToJSON < Base
32
32
  extend AutoCorrector
33
33
 
34
- MSG = '`#to_json` requires an optional argument to be parsable ' \
35
- 'via JSON.generate(obj).'
34
+ MSG = '`#to_json` requires an optional argument to be parsable via JSON.generate(obj).'
36
35
 
37
36
  def on_def(node)
38
37
  return unless node.method?(:to_json) && node.arguments.empty?
@@ -38,9 +38,7 @@ module RuboCop
38
38
 
39
39
  trailing_comma = trailing_comma_range(node)
40
40
 
41
- add_offense(trailing_comma) do |corrector|
42
- corrector.remove(trailing_comma)
43
- end
41
+ add_offense(trailing_comma) { |corrector| corrector.remove(trailing_comma) }
44
42
  end
45
43
 
46
44
  private
@@ -3,7 +3,7 @@
3
3
  module RuboCop
4
4
  module Cop
5
5
  module Lint
6
- # This cop checks for "triple quotes" (strings delimted by any odd number
6
+ # This cop checks for "triple quotes" (strings delimited by any odd number
7
7
  # of quotes greater than 1).
8
8
  #
9
9
  # Ruby allows multiple strings to be implicitly concatenated by just
@@ -48,9 +48,7 @@ module RuboCop
48
48
  end
49
49
 
50
50
  def after_leaving_scope(scope, _variable_table)
51
- scope.variables.each_value do |variable|
52
- check_variable(variable)
53
- end
51
+ scope.variables.each_value { |variable| check_variable(variable) }
54
52
  end
55
53
 
56
54
  def check_variable(variable)
@@ -13,14 +13,19 @@ module RuboCop
13
13
  # Keyword arguments (including `**kwargs`) do not get counted towards
14
14
  # this, as they are not used by the methods in question.
15
15
  #
16
- # NOTE: This cop matches for method names only and hence cannot tell apart
17
- # methods with same name in different classes.
18
- #
19
16
  # Method names and their expected arity can be configured like this:
20
17
  #
18
+ # [source,yaml]
19
+ # ----
21
20
  # Methods:
22
21
  # inject: 2
23
22
  # reduce: 2
23
+ # ----
24
+ #
25
+ # @safety
26
+ # This cop matches for method names only and hence cannot tell apart
27
+ # methods with same name in different classes, which may lead to a
28
+ # false positive.
24
29
  #
25
30
  # @example
26
31
  # # bad
@@ -22,6 +22,7 @@ module RuboCop
22
22
 
23
23
  MSG = 'Use `Integer` instead of `%<klass>s`.'
24
24
 
25
+ # @!method fixnum_or_bignum_const(node)
25
26
  def_node_matcher :fixnum_or_bignum_const, <<~PATTERN
26
27
  (:const {nil? (:cbase)} ${:Fixnum :Bignum})
27
28
  PATTERN
@@ -66,6 +66,7 @@ module RuboCop
66
66
  MSG = 'Ensure the accumulator `%<accum>s` will be modified by `%<method>s`.'
67
67
  MSG_INDEX = 'Do not return an element of the accumulator in `%<method>s`.'
68
68
 
69
+ # @!method reduce_with_block?(node)
69
70
  def_node_matcher :reduce_with_block?, <<~PATTERN
70
71
  {
71
72
  (block (send _recv {:reduce :inject} ...) args ...)
@@ -73,10 +74,12 @@ module RuboCop
73
74
  }
74
75
  PATTERN
75
76
 
77
+ # @!method accumulator_index?(node, accumulator_name)
76
78
  def_node_matcher :accumulator_index?, <<~PATTERN
77
79
  (send (lvar %1) {:[] :[]=} ...)
78
80
  PATTERN
79
81
 
82
+ # @!method element_modified?(node, element_name)
80
83
  def_node_search :element_modified?, <<~PATTERN
81
84
  {
82
85
  (send _receiver !{:[] :[]=} <`(lvar %1) `_ ...>) # method(el, ...)
@@ -86,6 +89,7 @@ module RuboCop
86
89
  }
87
90
  PATTERN
88
91
 
92
+ # @!method lvar_used?(node, name)
89
93
  def_node_matcher :lvar_used?, <<~PATTERN
90
94
  {
91
95
  (lvar %1)
@@ -96,6 +100,7 @@ module RuboCop
96
100
  }
97
101
  PATTERN
98
102
 
103
+ # @!method expression_values(node)
99
104
  def_node_search :expression_values, <<~PATTERN
100
105
  {
101
106
  (%RuboCop::AST::Node::VARIABLES $_)
@@ -51,6 +51,7 @@ module RuboCop
51
51
 
52
52
  private
53
53
 
54
+ # @!method flow_command?(node)
54
55
  def_node_matcher :flow_command?, <<~PATTERN
55
56
  {
56
57
  return next break retry redo
@@ -80,8 +81,7 @@ module RuboCop
80
81
  def check_if(node)
81
82
  if_branch = node.if_branch
82
83
  else_branch = node.else_branch
83
- if_branch && else_branch &&
84
- flow_expression?(if_branch) && flow_expression?(else_branch)
84
+ if_branch && else_branch && flow_expression?(if_branch) && flow_expression?(else_branch)
85
85
  end
86
86
 
87
87
  def check_case(node)
@@ -89,9 +89,7 @@ module RuboCop
89
89
  return false unless else_branch
90
90
  return false unless flow_expression?(else_branch)
91
91
 
92
- node.when_branches.all? do |branch|
93
- branch.body && flow_expression?(branch.body)
94
- end
92
+ node.when_branches.all? { |branch| branch.body && flow_expression?(branch.body) }
95
93
  end
96
94
  end
97
95
  end