rubocop 1.30.1 → 1.64.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (613) hide show
  1. checksums.yaml +4 -4
  2. data/LICENSE.txt +1 -1
  3. data/README.md +8 -6
  4. data/assets/output.css.erb +159 -0
  5. data/assets/output.html.erb +1 -160
  6. data/config/default.yml +584 -73
  7. data/config/obsoletion.yml +30 -1
  8. data/exe/rubocop +15 -7
  9. data/lib/rubocop/arguments_env.rb +17 -0
  10. data/lib/rubocop/arguments_file.rb +17 -0
  11. data/lib/rubocop/cache_config.rb +29 -0
  12. data/lib/rubocop/cached_data.rb +11 -3
  13. data/lib/rubocop/cli/command/{auto_genenerate_config.rb → auto_generate_config.rb} +30 -9
  14. data/lib/rubocop/cli/command/execute_runner.rb +14 -9
  15. data/lib/rubocop/cli/command/init_dotfile.rb +1 -1
  16. data/lib/rubocop/cli/command/lsp.rb +19 -0
  17. data/lib/rubocop/cli/command/show_docs_url.rb +2 -2
  18. data/lib/rubocop/cli/command/suggest_extensions.rb +61 -16
  19. data/lib/rubocop/cli.rb +70 -11
  20. data/lib/rubocop/comment_config.rb +60 -1
  21. data/lib/rubocop/config.rb +84 -28
  22. data/lib/rubocop/config_finder.rb +78 -0
  23. data/lib/rubocop/config_loader.rb +46 -68
  24. data/lib/rubocop/config_loader_resolver.rb +8 -8
  25. data/lib/rubocop/config_obsoletion/changed_parameter.rb +5 -0
  26. data/lib/rubocop/config_obsoletion/parameter_rule.rb +13 -1
  27. data/lib/rubocop/config_obsoletion.rb +15 -7
  28. data/lib/rubocop/config_validator.rb +16 -9
  29. data/lib/rubocop/cop/autocorrect_logic.rb +37 -14
  30. data/lib/rubocop/cop/badge.rb +9 -4
  31. data/lib/rubocop/cop/base.rb +181 -98
  32. data/lib/rubocop/cop/bundler/duplicated_gem.rb +2 -1
  33. data/lib/rubocop/cop/bundler/duplicated_group.rb +127 -0
  34. data/lib/rubocop/cop/bundler/gem_comment.rb +4 -4
  35. data/lib/rubocop/cop/bundler/gem_filename.rb +4 -4
  36. data/lib/rubocop/cop/bundler/gem_version.rb +5 -7
  37. data/lib/rubocop/cop/bundler/ordered_gems.rb +11 -3
  38. data/lib/rubocop/cop/commissioner.rb +19 -6
  39. data/lib/rubocop/cop/cop.rb +54 -34
  40. data/lib/rubocop/cop/corrector.rb +33 -13
  41. data/lib/rubocop/cop/correctors/alignment_corrector.rb +3 -3
  42. data/lib/rubocop/cop/correctors/each_to_for_corrector.rb +4 -8
  43. data/lib/rubocop/cop/correctors/for_to_each_corrector.rb +6 -14
  44. data/lib/rubocop/cop/correctors/lambda_literal_to_method_corrector.rb +7 -4
  45. data/lib/rubocop/cop/correctors/line_break_corrector.rb +1 -1
  46. data/lib/rubocop/cop/correctors/multiline_literal_brace_corrector.rb +26 -10
  47. data/lib/rubocop/cop/correctors/ordered_gem_corrector.rb +2 -7
  48. data/lib/rubocop/cop/correctors/parentheses_corrector.rb +58 -0
  49. data/lib/rubocop/cop/correctors/percent_literal_corrector.rb +2 -2
  50. data/lib/rubocop/cop/correctors/unused_arg_corrector.rb +1 -1
  51. data/lib/rubocop/cop/documentation.rb +16 -6
  52. data/lib/rubocop/cop/exclude_limit.rb +1 -1
  53. data/lib/rubocop/cop/gemspec/dependency_version.rb +22 -26
  54. data/lib/rubocop/cop/gemspec/deprecated_attribute_assignment.rb +33 -18
  55. data/lib/rubocop/cop/gemspec/development_dependencies.rb +107 -0
  56. data/lib/rubocop/cop/gemspec/duplicated_assignment.rb +1 -1
  57. data/lib/rubocop/cop/gemspec/ordered_dependencies.rb +10 -2
  58. data/lib/rubocop/cop/gemspec/require_mfa.rb +21 -21
  59. data/lib/rubocop/cop/gemspec/required_ruby_version.rb +5 -1
  60. data/lib/rubocop/cop/generator/require_file_injector.rb +3 -3
  61. data/lib/rubocop/cop/generator.rb +6 -3
  62. data/lib/rubocop/cop/internal_affairs/cop_description.rb +38 -12
  63. data/lib/rubocop/cop/internal_affairs/create_empty_file.rb +37 -0
  64. data/lib/rubocop/cop/internal_affairs/example_description.rb +46 -24
  65. data/lib/rubocop/cop/internal_affairs/example_heredoc_delimiter.rb +111 -0
  66. data/lib/rubocop/cop/internal_affairs/inherit_deprecated_cop_class.rb +1 -1
  67. data/lib/rubocop/cop/internal_affairs/lambda_or_proc.rb +46 -0
  68. data/lib/rubocop/cop/internal_affairs/location_expression.rb +37 -0
  69. data/lib/rubocop/cop/internal_affairs/location_line_equality_comparison.rb +3 -1
  70. data/lib/rubocop/cop/internal_affairs/method_name_end_with.rb +8 -6
  71. data/lib/rubocop/cop/internal_affairs/method_name_equal.rb +19 -20
  72. data/lib/rubocop/cop/internal_affairs/node_first_or_last_argument.rb +53 -0
  73. data/lib/rubocop/cop/internal_affairs/node_matcher_directive.rb +128 -38
  74. data/lib/rubocop/cop/internal_affairs/node_type_predicate.rb +1 -1
  75. data/lib/rubocop/cop/internal_affairs/numblock_handler.rb +69 -0
  76. data/lib/rubocop/cop/internal_affairs/processed_source_buffer_name.rb +42 -0
  77. data/lib/rubocop/cop/internal_affairs/redundant_expect_offense_arguments.rb +34 -0
  78. data/lib/rubocop/cop/internal_affairs/redundant_let_rubocop_config_new.rb +11 -3
  79. data/lib/rubocop/cop/internal_affairs/redundant_location_argument.rb +1 -1
  80. data/lib/rubocop/cop/internal_affairs/redundant_message_argument.rb +1 -1
  81. data/lib/rubocop/cop/internal_affairs/redundant_method_dispatch_node.rb +11 -2
  82. data/lib/rubocop/cop/internal_affairs/redundant_source_range.rb +66 -0
  83. data/lib/rubocop/cop/internal_affairs/single_line_comparison.rb +62 -0
  84. data/lib/rubocop/cop/internal_affairs/useless_message_assertion.rb +2 -0
  85. data/lib/rubocop/cop/internal_affairs/useless_restrict_on_send.rb +60 -0
  86. data/lib/rubocop/cop/internal_affairs.rb +11 -0
  87. data/lib/rubocop/cop/layout/argument_alignment.rb +1 -1
  88. data/lib/rubocop/cop/layout/array_alignment.rb +1 -1
  89. data/lib/rubocop/cop/layout/block_alignment.rb +16 -12
  90. data/lib/rubocop/cop/layout/block_end_newline.rb +31 -9
  91. data/lib/rubocop/cop/layout/class_structure.rb +44 -27
  92. data/lib/rubocop/cop/layout/closing_heredoc_indentation.rb +2 -3
  93. data/lib/rubocop/cop/layout/closing_parenthesis_indentation.rb +2 -6
  94. data/lib/rubocop/cop/layout/comment_indentation.rb +4 -2
  95. data/lib/rubocop/cop/layout/dot_position.rb +1 -5
  96. data/lib/rubocop/cop/layout/empty_comment.rb +6 -4
  97. data/lib/rubocop/cop/layout/empty_line_after_guard_clause.rb +42 -9
  98. data/lib/rubocop/cop/layout/empty_line_after_magic_comment.rb +14 -7
  99. data/lib/rubocop/cop/layout/empty_line_between_defs.rb +28 -5
  100. data/lib/rubocop/cop/layout/empty_lines.rb +3 -1
  101. data/lib/rubocop/cop/layout/empty_lines_around_access_modifier.rb +7 -2
  102. data/lib/rubocop/cop/layout/empty_lines_around_attribute_accessor.rb +25 -4
  103. data/lib/rubocop/cop/layout/empty_lines_around_block_body.rb +2 -0
  104. data/lib/rubocop/cop/layout/empty_lines_around_exception_handling_keywords.rb +2 -0
  105. data/lib/rubocop/cop/layout/end_alignment.rb +23 -3
  106. data/lib/rubocop/cop/layout/end_of_line.rb +4 -4
  107. data/lib/rubocop/cop/layout/extra_spacing.rb +12 -9
  108. data/lib/rubocop/cop/layout/first_argument_indentation.rb +15 -4
  109. data/lib/rubocop/cop/layout/first_array_element_indentation.rb +44 -20
  110. data/lib/rubocop/cop/layout/first_array_element_line_break.rb +35 -8
  111. data/lib/rubocop/cop/layout/first_hash_element_indentation.rb +51 -12
  112. data/lib/rubocop/cop/layout/first_hash_element_line_break.rb +36 -1
  113. data/lib/rubocop/cop/layout/first_method_argument_line_break.rb +57 -8
  114. data/lib/rubocop/cop/layout/first_method_parameter_line_break.rb +52 -19
  115. data/lib/rubocop/cop/layout/first_parameter_indentation.rb +1 -1
  116. data/lib/rubocop/cop/layout/heredoc_argument_closing_parenthesis.rb +12 -6
  117. data/lib/rubocop/cop/layout/heredoc_indentation.rb +12 -12
  118. data/lib/rubocop/cop/layout/indentation_style.rb +8 -3
  119. data/lib/rubocop/cop/layout/indentation_width.rb +9 -5
  120. data/lib/rubocop/cop/layout/initial_indentation.rb +2 -2
  121. data/lib/rubocop/cop/layout/leading_comment_space.rb +2 -2
  122. data/lib/rubocop/cop/layout/line_continuation_leading_space.rb +144 -0
  123. data/lib/rubocop/cop/layout/line_continuation_spacing.rb +140 -0
  124. data/lib/rubocop/cop/layout/line_end_string_concatenation_indentation.rb +2 -0
  125. data/lib/rubocop/cop/layout/line_length.rb +8 -1
  126. data/lib/rubocop/cop/layout/multiline_array_line_breaks.rb +31 -1
  127. data/lib/rubocop/cop/layout/multiline_assignment_layout.rb +1 -1
  128. data/lib/rubocop/cop/layout/multiline_block_layout.rb +4 -2
  129. data/lib/rubocop/cop/layout/multiline_hash_key_line_breaks.rb +29 -1
  130. data/lib/rubocop/cop/layout/multiline_method_argument_line_breaks.rb +39 -2
  131. data/lib/rubocop/cop/layout/multiline_method_call_indentation.rb +20 -5
  132. data/lib/rubocop/cop/layout/multiline_method_parameter_line_breaks.rb +77 -0
  133. data/lib/rubocop/cop/layout/multiline_operation_indentation.rb +2 -2
  134. data/lib/rubocop/cop/layout/redundant_line_break.rb +35 -13
  135. data/lib/rubocop/cop/layout/rescue_ensure_alignment.rb +6 -6
  136. data/lib/rubocop/cop/layout/single_line_block_chain.rb +5 -0
  137. data/lib/rubocop/cop/layout/space_after_comma.rb +9 -1
  138. data/lib/rubocop/cop/layout/space_after_not.rb +1 -1
  139. data/lib/rubocop/cop/layout/space_around_block_parameters.rb +2 -2
  140. data/lib/rubocop/cop/layout/space_around_keyword.rb +3 -3
  141. data/lib/rubocop/cop/layout/space_around_method_call_operator.rb +2 -2
  142. data/lib/rubocop/cop/layout/space_around_operators.rb +54 -22
  143. data/lib/rubocop/cop/layout/space_before_block_braces.rb +22 -11
  144. data/lib/rubocop/cop/layout/space_before_first_arg.rb +2 -2
  145. data/lib/rubocop/cop/layout/space_in_lambda_literal.rb +2 -2
  146. data/lib/rubocop/cop/layout/space_inside_array_literal_brackets.rb +22 -20
  147. data/lib/rubocop/cop/layout/space_inside_array_percent_literal.rb +3 -0
  148. data/lib/rubocop/cop/layout/space_inside_block_braces.rb +32 -12
  149. data/lib/rubocop/cop/layout/space_inside_hash_literal_braces.rb +31 -4
  150. data/lib/rubocop/cop/layout/space_inside_parens.rb +3 -3
  151. data/lib/rubocop/cop/layout/space_inside_percent_literal_delimiters.rb +34 -0
  152. data/lib/rubocop/cop/layout/space_inside_range_literal.rb +1 -1
  153. data/lib/rubocop/cop/layout/space_inside_reference_brackets.rb +10 -6
  154. data/lib/rubocop/cop/layout/space_inside_string_interpolation.rb +5 -4
  155. data/lib/rubocop/cop/layout/trailing_empty_lines.rb +6 -1
  156. data/lib/rubocop/cop/layout/trailing_whitespace.rb +13 -6
  157. data/lib/rubocop/cop/legacy/corrections_proxy.rb +1 -1
  158. data/lib/rubocop/cop/legacy/corrector.rb +1 -1
  159. data/lib/rubocop/cop/lint/ambiguous_block_association.rb +40 -8
  160. data/lib/rubocop/cop/lint/ambiguous_operator.rb +4 -0
  161. data/lib/rubocop/cop/lint/assignment_in_condition.rb +17 -7
  162. data/lib/rubocop/cop/lint/binary_operator_with_identical_operands.rb +2 -2
  163. data/lib/rubocop/cop/lint/constant_overwritten_in_rescue.rb +51 -0
  164. data/lib/rubocop/cop/lint/constant_resolution.rb +5 -1
  165. data/lib/rubocop/cop/lint/debugger.rb +69 -34
  166. data/lib/rubocop/cop/lint/deprecated_class_methods.rb +66 -110
  167. data/lib/rubocop/cop/lint/deprecated_constants.rb +8 -1
  168. data/lib/rubocop/cop/lint/deprecated_open_ssl_constant.rb +1 -1
  169. data/lib/rubocop/cop/lint/duplicate_branch.rb +0 -2
  170. data/lib/rubocop/cop/lint/duplicate_hash_key.rb +2 -1
  171. data/lib/rubocop/cop/lint/duplicate_magic_comment.rb +73 -0
  172. data/lib/rubocop/cop/lint/duplicate_match_pattern.rb +122 -0
  173. data/lib/rubocop/cop/lint/duplicate_methods.rb +49 -19
  174. data/lib/rubocop/cop/lint/duplicate_regexp_character_class_element.rb +55 -11
  175. data/lib/rubocop/cop/lint/duplicate_require.rb +1 -1
  176. data/lib/rubocop/cop/lint/else_layout.rb +3 -7
  177. data/lib/rubocop/cop/lint/empty_block.rb +4 -8
  178. data/lib/rubocop/cop/lint/empty_class.rb +3 -1
  179. data/lib/rubocop/cop/lint/empty_conditional_body.rb +110 -2
  180. data/lib/rubocop/cop/lint/empty_interpolation.rb +1 -1
  181. data/lib/rubocop/cop/lint/erb_new_arguments.rb +15 -16
  182. data/lib/rubocop/cop/lint/float_comparison.rb +10 -0
  183. data/lib/rubocop/cop/lint/format_parameter_mismatch.rb +14 -7
  184. data/lib/rubocop/cop/lint/hash_compare_by_identity.rb +2 -1
  185. data/lib/rubocop/cop/lint/heredoc_method_call_position.rb +16 -18
  186. data/lib/rubocop/cop/lint/identity_comparison.rb +0 -1
  187. data/lib/rubocop/cop/lint/implicit_string_concatenation.rb +1 -1
  188. data/lib/rubocop/cop/lint/incompatible_io_select_with_fiber_scheduler.rb +5 -3
  189. data/lib/rubocop/cop/lint/ineffective_access_modifier.rb +1 -1
  190. data/lib/rubocop/cop/lint/inherit_exception.rb +9 -0
  191. data/lib/rubocop/cop/lint/interpolation_check.rb +5 -4
  192. data/lib/rubocop/cop/lint/it_without_arguments_in_block.rb +56 -0
  193. data/lib/rubocop/cop/lint/lambda_without_literal_block.rb +1 -1
  194. data/lib/rubocop/cop/lint/literal_as_condition.rb +5 -0
  195. data/lib/rubocop/cop/lint/literal_assignment_in_condition.rb +85 -0
  196. data/lib/rubocop/cop/lint/literal_in_interpolation.rb +49 -3
  197. data/lib/rubocop/cop/lint/missing_cop_enable_directive.rb +18 -3
  198. data/lib/rubocop/cop/lint/missing_super.rb +63 -5
  199. data/lib/rubocop/cop/lint/mixed_case_range.rb +116 -0
  200. data/lib/rubocop/cop/lint/mixed_regexp_capture_types.rb +1 -0
  201. data/lib/rubocop/cop/lint/nested_method_definition.rb +53 -9
  202. data/lib/rubocop/cop/lint/next_without_accumulator.rb +11 -7
  203. data/lib/rubocop/cop/lint/non_atomic_file_operation.rb +165 -0
  204. data/lib/rubocop/cop/lint/non_deterministic_require_order.rb +15 -5
  205. data/lib/rubocop/cop/lint/number_conversion.rb +45 -13
  206. data/lib/rubocop/cop/lint/numbered_parameter_assignment.rb +2 -2
  207. data/lib/rubocop/cop/lint/or_assignment_to_constant.rb +2 -0
  208. data/lib/rubocop/cop/lint/ordered_magic_comments.rb +4 -6
  209. data/lib/rubocop/cop/lint/out_of_range_regexp_ref.rb +17 -2
  210. data/lib/rubocop/cop/lint/parentheses_as_grouped_expression.rb +6 -1
  211. data/lib/rubocop/cop/lint/percent_string_array.rb +1 -1
  212. data/lib/rubocop/cop/lint/percent_symbol_array.rb +1 -1
  213. data/lib/rubocop/cop/lint/redundant_cop_disable_directive.rb +54 -14
  214. data/lib/rubocop/cop/lint/redundant_cop_enable_directive.rb +7 -7
  215. data/lib/rubocop/cop/lint/redundant_dir_glob_sort.rb +7 -0
  216. data/lib/rubocop/cop/lint/redundant_regexp_quantifiers.rb +130 -0
  217. data/lib/rubocop/cop/lint/redundant_require_statement.rb +57 -10
  218. data/lib/rubocop/cop/lint/redundant_safe_navigation.rb +85 -8
  219. data/lib/rubocop/cop/lint/redundant_splat_expansion.rb +1 -1
  220. data/lib/rubocop/cop/lint/redundant_string_coercion.rb +35 -15
  221. data/lib/rubocop/cop/lint/redundant_with_index.rb +18 -11
  222. data/lib/rubocop/cop/lint/redundant_with_object.rb +13 -12
  223. data/lib/rubocop/cop/lint/refinement_import_methods.rb +2 -1
  224. data/lib/rubocop/cop/lint/regexp_as_condition.rb +8 -2
  225. data/lib/rubocop/cop/lint/require_parentheses.rb +3 -1
  226. data/lib/rubocop/cop/lint/require_range_parentheses.rb +57 -0
  227. data/lib/rubocop/cop/lint/rescue_type.rb +2 -4
  228. data/lib/rubocop/cop/lint/safe_navigation_chain.rb +50 -11
  229. data/lib/rubocop/cop/lint/safe_navigation_consistency.rb +1 -1
  230. data/lib/rubocop/cop/lint/script_permission.rb +3 -3
  231. data/lib/rubocop/cop/lint/self_assignment.rb +38 -0
  232. data/lib/rubocop/cop/lint/send_with_mixin_argument.rb +6 -6
  233. data/lib/rubocop/cop/lint/shadowed_argument.rb +1 -0
  234. data/lib/rubocop/cop/lint/shadowed_exception.rb +21 -22
  235. data/lib/rubocop/cop/lint/shadowing_outer_local_variable.rb +35 -4
  236. data/lib/rubocop/cop/lint/struct_new_override.rb +14 -14
  237. data/lib/rubocop/cop/lint/suppressed_exception.rb +3 -3
  238. data/lib/rubocop/cop/lint/symbol_conversion.rb +8 -3
  239. data/lib/rubocop/cop/lint/syntax.rb +10 -3
  240. data/lib/rubocop/cop/lint/to_enum_arguments.rb +23 -6
  241. data/lib/rubocop/cop/lint/top_level_return_with_argument.rb +23 -9
  242. data/lib/rubocop/cop/lint/trailing_comma_in_attribute_declaration.rb +2 -2
  243. data/lib/rubocop/cop/lint/unmodified_reduce_accumulator.rb +2 -2
  244. data/lib/rubocop/cop/lint/unreachable_code.rb +4 -2
  245. data/lib/rubocop/cop/lint/unreachable_loop.rb +20 -8
  246. data/lib/rubocop/cop/lint/unused_method_argument.rb +6 -1
  247. data/lib/rubocop/cop/lint/useless_access_modifier.rb +19 -14
  248. data/lib/rubocop/cop/lint/useless_assignment.rb +94 -10
  249. data/lib/rubocop/cop/lint/useless_else_without_rescue.rb +44 -0
  250. data/lib/rubocop/cop/lint/useless_method_definition.rb +12 -4
  251. data/lib/rubocop/cop/lint/useless_rescue.rb +89 -0
  252. data/lib/rubocop/cop/lint/useless_ruby2_keywords.rb +15 -5
  253. data/lib/rubocop/cop/lint/useless_times.rb +3 -3
  254. data/lib/rubocop/cop/lint/void.rb +126 -25
  255. data/lib/rubocop/cop/metrics/abc_size.rb +7 -5
  256. data/lib/rubocop/cop/metrics/block_length.rb +17 -12
  257. data/lib/rubocop/cop/metrics/block_nesting.rb +2 -2
  258. data/lib/rubocop/cop/metrics/class_length.rb +17 -6
  259. data/lib/rubocop/cop/metrics/collection_literal_length.rb +76 -0
  260. data/lib/rubocop/cop/metrics/cyclomatic_complexity.rb +1 -1
  261. data/lib/rubocop/cop/metrics/method_length.rb +18 -12
  262. data/lib/rubocop/cop/metrics/module_length.rb +10 -5
  263. data/lib/rubocop/cop/metrics/parameter_lists.rb +27 -0
  264. data/lib/rubocop/cop/metrics/perceived_complexity.rb +1 -1
  265. data/lib/rubocop/cop/metrics/utils/abc_size_calculator.rb +4 -8
  266. data/lib/rubocop/cop/metrics/utils/code_length_calculator.rb +43 -12
  267. data/lib/rubocop/cop/migration/department_name.rb +3 -3
  268. data/lib/rubocop/cop/mixin/alignment.rb +2 -2
  269. data/lib/rubocop/cop/mixin/allowed_identifiers.rb +2 -2
  270. data/lib/rubocop/cop/mixin/allowed_methods.rb +23 -2
  271. data/lib/rubocop/cop/mixin/allowed_pattern.rb +17 -1
  272. data/lib/rubocop/cop/mixin/allowed_receivers.rb +34 -0
  273. data/lib/rubocop/cop/mixin/annotation_comment.rb +14 -7
  274. data/lib/rubocop/cop/mixin/check_line_breakable.rb +5 -1
  275. data/lib/rubocop/cop/mixin/code_length.rb +12 -1
  276. data/lib/rubocop/cop/mixin/comments_help.rb +37 -11
  277. data/lib/rubocop/cop/mixin/configurable_enforced_style.rb +21 -9
  278. data/lib/rubocop/cop/mixin/configurable_formatting.rb +1 -0
  279. data/lib/rubocop/cop/mixin/def_node.rb +3 -8
  280. data/lib/rubocop/cop/mixin/documentation_comment.rb +1 -1
  281. data/lib/rubocop/cop/mixin/end_keyword_alignment.rb +1 -1
  282. data/lib/rubocop/cop/mixin/enforce_superclass.rb +2 -1
  283. data/lib/rubocop/cop/mixin/first_element_line_break.rb +11 -7
  284. data/lib/rubocop/cop/mixin/frozen_string_literal.rb +4 -0
  285. data/lib/rubocop/cop/mixin/hash_alignment_styles.rb +1 -1
  286. data/lib/rubocop/cop/mixin/hash_shorthand_syntax.rb +162 -12
  287. data/lib/rubocop/cop/mixin/hash_transform_method.rb +13 -9
  288. data/lib/rubocop/cop/mixin/heredoc.rb +6 -2
  289. data/lib/rubocop/cop/mixin/line_length_help.rb +11 -2
  290. data/lib/rubocop/cop/mixin/method_complexity.rb +28 -22
  291. data/lib/rubocop/cop/mixin/min_branches_count.rb +40 -0
  292. data/lib/rubocop/cop/mixin/multiline_element_indentation.rb +34 -12
  293. data/lib/rubocop/cop/mixin/multiline_element_line_breaks.rb +5 -6
  294. data/lib/rubocop/cop/mixin/multiline_expression_indentation.rb +4 -3
  295. data/lib/rubocop/cop/mixin/ordered_gem_node.rb +1 -1
  296. data/lib/rubocop/cop/mixin/percent_array.rb +58 -1
  297. data/lib/rubocop/cop/mixin/percent_literal.rb +1 -1
  298. data/lib/rubocop/cop/mixin/preceding_following_alignment.rb +7 -9
  299. data/lib/rubocop/cop/mixin/range_help.rb +28 -7
  300. data/lib/rubocop/cop/mixin/require_library.rb +2 -0
  301. data/lib/rubocop/cop/mixin/rescue_node.rb +5 -3
  302. data/lib/rubocop/cop/mixin/safe_assignment.rb +1 -1
  303. data/lib/rubocop/cop/mixin/space_after_punctuation.rb +1 -1
  304. data/lib/rubocop/cop/mixin/space_before_punctuation.rb +1 -1
  305. data/lib/rubocop/cop/mixin/statement_modifier.rb +18 -3
  306. data/lib/rubocop/cop/mixin/string_help.rb +4 -2
  307. data/lib/rubocop/cop/mixin/surrounding_space.rb +13 -11
  308. data/lib/rubocop/cop/mixin/trailing_comma.rb +3 -3
  309. data/lib/rubocop/cop/mixin/visibility_help.rb +40 -5
  310. data/lib/rubocop/cop/naming/ascii_identifiers.rb +1 -1
  311. data/lib/rubocop/cop/naming/block_forwarding.rb +39 -8
  312. data/lib/rubocop/cop/naming/block_parameter_name.rb +1 -1
  313. data/lib/rubocop/cop/naming/class_and_module_camel_case.rb +3 -1
  314. data/lib/rubocop/cop/naming/constant_name.rb +4 -5
  315. data/lib/rubocop/cop/naming/file_name.rb +3 -3
  316. data/lib/rubocop/cop/naming/heredoc_delimiter_case.rb +1 -1
  317. data/lib/rubocop/cop/naming/heredoc_delimiter_naming.rb +3 -1
  318. data/lib/rubocop/cop/naming/inclusive_language.rb +29 -8
  319. data/lib/rubocop/cop/naming/memoized_instance_variable_name.rb +26 -11
  320. data/lib/rubocop/cop/naming/method_name.rb +3 -3
  321. data/lib/rubocop/cop/naming/predicate_name.rb +33 -4
  322. data/lib/rubocop/cop/naming/rescued_exceptions_variable_name.rb +12 -4
  323. data/lib/rubocop/cop/naming/variable_name.rb +6 -1
  324. data/lib/rubocop/cop/registry.rb +74 -46
  325. data/lib/rubocop/cop/security/compound_hash.rb +4 -3
  326. data/lib/rubocop/cop/security/open.rb +2 -2
  327. data/lib/rubocop/cop/style/access_modifier_declarations.rb +142 -3
  328. data/lib/rubocop/cop/style/accessor_grouping.rb +50 -20
  329. data/lib/rubocop/cop/style/alias.rb +19 -9
  330. data/lib/rubocop/cop/style/arguments_forwarding.rb +414 -62
  331. data/lib/rubocop/cop/style/array_first_last.rb +64 -0
  332. data/lib/rubocop/cop/style/array_intersect.rb +119 -0
  333. data/lib/rubocop/cop/style/ascii_comments.rb +1 -1
  334. data/lib/rubocop/cop/style/attr.rb +11 -1
  335. data/lib/rubocop/cop/style/auto_resource_cleanup.rb +21 -14
  336. data/lib/rubocop/cop/style/begin_block.rb +1 -2
  337. data/lib/rubocop/cop/style/bisected_attr_accessor.rb +3 -3
  338. data/lib/rubocop/cop/style/block_comments.rb +3 -3
  339. data/lib/rubocop/cop/style/block_delimiters.rb +52 -15
  340. data/lib/rubocop/cop/style/case_equality.rb +40 -10
  341. data/lib/rubocop/cop/style/case_like_if.rb +25 -8
  342. data/lib/rubocop/cop/style/character_literal.rb +1 -1
  343. data/lib/rubocop/cop/style/class_and_module_children.rb +9 -16
  344. data/lib/rubocop/cop/style/class_check.rb +1 -0
  345. data/lib/rubocop/cop/style/class_equality_comparison.rb +79 -12
  346. data/lib/rubocop/cop/style/class_methods_definitions.rb +2 -1
  347. data/lib/rubocop/cop/style/class_vars.rb +3 -3
  348. data/lib/rubocop/cop/style/collection_compact.rb +44 -12
  349. data/lib/rubocop/cop/style/collection_methods.rb +4 -0
  350. data/lib/rubocop/cop/style/colon_method_call.rb +2 -2
  351. data/lib/rubocop/cop/style/combinable_loops.rb +38 -8
  352. data/lib/rubocop/cop/style/command_literal.rb +1 -1
  353. data/lib/rubocop/cop/style/comment_annotation.rb +1 -1
  354. data/lib/rubocop/cop/style/commented_keyword.rb +7 -4
  355. data/lib/rubocop/cop/style/comparable_clamp.rb +125 -0
  356. data/lib/rubocop/cop/style/concat_array_literals.rb +95 -0
  357. data/lib/rubocop/cop/style/conditional_assignment.rb +16 -20
  358. data/lib/rubocop/cop/style/copyright.rb +32 -22
  359. data/lib/rubocop/cop/style/data_inheritance.rb +75 -0
  360. data/lib/rubocop/cop/style/date_time.rb +5 -4
  361. data/lib/rubocop/cop/style/dir.rb +1 -1
  362. data/lib/rubocop/cop/style/dir_empty.rb +54 -0
  363. data/lib/rubocop/cop/style/disable_cops_within_source_code_directive.rb +2 -2
  364. data/lib/rubocop/cop/style/document_dynamic_eval_definition.rb +3 -3
  365. data/lib/rubocop/cop/style/documentation.rb +22 -10
  366. data/lib/rubocop/cop/style/documentation_method.rb +30 -4
  367. data/lib/rubocop/cop/style/double_negation.rb +4 -2
  368. data/lib/rubocop/cop/style/each_for_simple_loop.rb +45 -10
  369. data/lib/rubocop/cop/style/each_with_object.rb +40 -9
  370. data/lib/rubocop/cop/style/empty_block_parameter.rb +2 -2
  371. data/lib/rubocop/cop/style/empty_case_condition.rb +6 -1
  372. data/lib/rubocop/cop/style/empty_else.rb +37 -0
  373. data/lib/rubocop/cop/style/empty_heredoc.rb +73 -0
  374. data/lib/rubocop/cop/style/empty_lambda_parameter.rb +2 -2
  375. data/lib/rubocop/cop/style/empty_literal.rb +1 -1
  376. data/lib/rubocop/cop/style/empty_method.rb +17 -2
  377. data/lib/rubocop/cop/style/encoding.rb +1 -1
  378. data/lib/rubocop/cop/style/endless_method.rb +1 -1
  379. data/lib/rubocop/cop/style/eval_with_location.rb +14 -23
  380. data/lib/rubocop/cop/style/exact_regexp_match.rb +70 -0
  381. data/lib/rubocop/cop/style/explicit_block_argument.rb +8 -4
  382. data/lib/rubocop/cop/style/fetch_env_var.rb +10 -177
  383. data/lib/rubocop/cop/style/file_empty.rb +71 -0
  384. data/lib/rubocop/cop/style/file_read.rb +3 -3
  385. data/lib/rubocop/cop/style/file_write.rb +1 -1
  386. data/lib/rubocop/cop/style/for.rb +5 -1
  387. data/lib/rubocop/cop/style/format_string.rb +33 -12
  388. data/lib/rubocop/cop/style/format_string_token.rb +73 -23
  389. data/lib/rubocop/cop/style/frozen_string_literal_comment.rb +5 -3
  390. data/lib/rubocop/cop/style/guard_clause.rb +159 -42
  391. data/lib/rubocop/cop/style/hash_as_last_array_item.rb +2 -1
  392. data/lib/rubocop/cop/style/hash_conversion.rb +10 -0
  393. data/lib/rubocop/cop/style/hash_each_methods.rb +131 -22
  394. data/lib/rubocop/cop/style/hash_except.rb +101 -9
  395. data/lib/rubocop/cop/style/hash_like_case.rb +3 -9
  396. data/lib/rubocop/cop/style/hash_syntax.rb +51 -5
  397. data/lib/rubocop/cop/style/hash_transform_keys.rb +2 -2
  398. data/lib/rubocop/cop/style/hash_transform_values.rb +2 -2
  399. data/lib/rubocop/cop/style/identical_conditional_branches.rb +47 -3
  400. data/lib/rubocop/cop/style/if_inside_else.rb +6 -0
  401. data/lib/rubocop/cop/style/if_unless_modifier.rb +112 -16
  402. data/lib/rubocop/cop/style/if_with_boolean_literal_branches.rb +34 -5
  403. data/lib/rubocop/cop/style/if_with_semicolon.rb +6 -6
  404. data/lib/rubocop/cop/style/implicit_runtime_error.rb +2 -2
  405. data/lib/rubocop/cop/style/infinite_loop.rb +2 -5
  406. data/lib/rubocop/cop/style/inverse_methods.rb +21 -16
  407. data/lib/rubocop/cop/style/invertible_unless_condition.rb +160 -0
  408. data/lib/rubocop/cop/style/keyword_parameters_order.rb +1 -1
  409. data/lib/rubocop/cop/style/lambda.rb +3 -3
  410. data/lib/rubocop/cop/style/lambda_call.rb +5 -0
  411. data/lib/rubocop/cop/style/line_end_concatenation.rb +5 -2
  412. data/lib/rubocop/cop/style/magic_comment_format.rb +307 -0
  413. data/lib/rubocop/cop/style/map_compact_with_conditional_block.rb +8 -10
  414. data/lib/rubocop/cop/style/map_into_array.rb +175 -0
  415. data/lib/rubocop/cop/style/map_to_hash.rb +21 -8
  416. data/lib/rubocop/cop/style/map_to_set.rb +64 -0
  417. data/lib/rubocop/cop/style/method_call_with_args_parentheses/omit_parentheses.rb +63 -32
  418. data/lib/rubocop/cop/style/method_call_with_args_parentheses/require_parentheses.rb +5 -1
  419. data/lib/rubocop/cop/style/method_call_with_args_parentheses.rb +50 -45
  420. data/lib/rubocop/cop/style/method_call_without_args_parentheses.rb +41 -2
  421. data/lib/rubocop/cop/style/method_called_on_do_end_block.rb +4 -1
  422. data/lib/rubocop/cop/style/method_def_parentheses.rb +12 -5
  423. data/lib/rubocop/cop/style/min_max.rb +3 -3
  424. data/lib/rubocop/cop/style/min_max_comparison.rb +83 -0
  425. data/lib/rubocop/cop/style/missing_else.rb +13 -1
  426. data/lib/rubocop/cop/style/missing_respond_to_missing.rb +2 -2
  427. data/lib/rubocop/cop/style/mixin_grouping.rb +5 -5
  428. data/lib/rubocop/cop/style/module_function.rb +30 -8
  429. data/lib/rubocop/cop/style/multiline_block_chain.rb +4 -2
  430. data/lib/rubocop/cop/style/multiline_if_modifier.rb +2 -6
  431. data/lib/rubocop/cop/style/multiline_if_then.rb +1 -1
  432. data/lib/rubocop/cop/style/multiline_in_pattern_then.rb +2 -4
  433. data/lib/rubocop/cop/style/multiline_memoization.rb +2 -2
  434. data/lib/rubocop/cop/style/multiline_method_signature.rb +18 -6
  435. data/lib/rubocop/cop/style/multiline_ternary_operator.rb +22 -5
  436. data/lib/rubocop/cop/style/multiline_when_then.rb +1 -3
  437. data/lib/rubocop/cop/style/multiple_comparison.rb +14 -0
  438. data/lib/rubocop/cop/style/negated_if_else_condition.rb +17 -10
  439. data/lib/rubocop/cop/style/nested_parenthesized_calls.rb +10 -1
  440. data/lib/rubocop/cop/style/nested_ternary_operator.rb +18 -14
  441. data/lib/rubocop/cop/style/next.rb +4 -6
  442. data/lib/rubocop/cop/style/nil_comparison.rb +2 -0
  443. data/lib/rubocop/cop/style/nil_lambda.rb +4 -4
  444. data/lib/rubocop/cop/style/not.rb +1 -1
  445. data/lib/rubocop/cop/style/numbered_parameters_limit.rb +11 -3
  446. data/lib/rubocop/cop/style/numeric_literal_prefix.rb +1 -1
  447. data/lib/rubocop/cop/style/numeric_literals.rb +16 -1
  448. data/lib/rubocop/cop/style/numeric_predicate.rb +53 -11
  449. data/lib/rubocop/cop/style/object_then.rb +10 -3
  450. data/lib/rubocop/cop/style/one_line_conditional.rb +4 -7
  451. data/lib/rubocop/cop/style/open_struct_use.rb +1 -1
  452. data/lib/rubocop/cop/style/operator_method_call.rb +73 -0
  453. data/lib/rubocop/cop/style/parallel_assignment.rb +32 -24
  454. data/lib/rubocop/cop/style/parentheses_around_condition.rb +8 -0
  455. data/lib/rubocop/cop/style/percent_literal_delimiters.rb +2 -3
  456. data/lib/rubocop/cop/style/percent_q_literals.rb +1 -1
  457. data/lib/rubocop/cop/style/perl_backrefs.rb +22 -1
  458. data/lib/rubocop/cop/style/preferred_hash_methods.rb +1 -1
  459. data/lib/rubocop/cop/style/proc.rb +4 -1
  460. data/lib/rubocop/cop/style/quoted_symbols.rb +1 -1
  461. data/lib/rubocop/cop/style/raise_args.rb +4 -1
  462. data/lib/rubocop/cop/style/redundant_argument.rb +37 -5
  463. data/lib/rubocop/cop/style/redundant_array_constructor.rb +77 -0
  464. data/lib/rubocop/cop/style/redundant_assignment.rb +10 -2
  465. data/lib/rubocop/cop/style/redundant_begin.rb +13 -2
  466. data/lib/rubocop/cop/style/redundant_condition.rb +41 -8
  467. data/lib/rubocop/cop/style/redundant_conditional.rb +2 -14
  468. data/lib/rubocop/cop/style/redundant_constant_base.rb +85 -0
  469. data/lib/rubocop/cop/style/redundant_current_directory_in_path.rb +39 -0
  470. data/lib/rubocop/cop/style/redundant_double_splat_hash_braces.rb +133 -0
  471. data/lib/rubocop/cop/style/redundant_each.rb +119 -0
  472. data/lib/rubocop/cop/style/redundant_exception.rb +32 -12
  473. data/lib/rubocop/cop/style/redundant_fetch_block.rb +10 -8
  474. data/lib/rubocop/cop/style/redundant_filter_chain.rb +118 -0
  475. data/lib/rubocop/cop/style/redundant_heredoc_delimiter_quotes.rb +58 -0
  476. data/lib/rubocop/cop/style/redundant_initialize.rb +3 -1
  477. data/lib/rubocop/cop/style/redundant_interpolation.rb +2 -2
  478. data/lib/rubocop/cop/style/redundant_line_continuation.rb +199 -0
  479. data/lib/rubocop/cop/style/redundant_parentheses.rb +91 -44
  480. data/lib/rubocop/cop/style/redundant_percent_q.rb +2 -2
  481. data/lib/rubocop/cop/style/redundant_regexp_argument.rb +100 -0
  482. data/lib/rubocop/cop/style/redundant_regexp_character_class.rb +9 -3
  483. data/lib/rubocop/cop/style/redundant_regexp_constructor.rb +46 -0
  484. data/lib/rubocop/cop/style/redundant_regexp_escape.rb +22 -4
  485. data/lib/rubocop/cop/style/redundant_return.rb +21 -3
  486. data/lib/rubocop/cop/style/redundant_self.rb +19 -2
  487. data/lib/rubocop/cop/style/redundant_self_assignment.rb +1 -1
  488. data/lib/rubocop/cop/style/redundant_self_assignment_branch.rb +8 -1
  489. data/lib/rubocop/cop/style/redundant_sort.rb +33 -17
  490. data/lib/rubocop/cop/style/redundant_sort_by.rb +24 -8
  491. data/lib/rubocop/cop/style/redundant_string_escape.rb +185 -0
  492. data/lib/rubocop/cop/style/regexp_literal.rb +11 -2
  493. data/lib/rubocop/cop/style/require_order.rb +139 -0
  494. data/lib/rubocop/cop/style/rescue_modifier.rb +2 -4
  495. data/lib/rubocop/cop/style/rescue_standard_error.rb +2 -2
  496. data/lib/rubocop/cop/style/return_nil.rb +6 -2
  497. data/lib/rubocop/cop/style/return_nil_in_predicate_method_definition.rb +95 -0
  498. data/lib/rubocop/cop/style/safe_navigation.rb +41 -10
  499. data/lib/rubocop/cop/style/sample.rb +3 -4
  500. data/lib/rubocop/cop/style/select_by_regexp.rb +30 -11
  501. data/lib/rubocop/cop/style/self_assignment.rb +3 -3
  502. data/lib/rubocop/cop/style/semicolon.rb +71 -8
  503. data/lib/rubocop/cop/style/send.rb +4 -4
  504. data/lib/rubocop/cop/style/send_with_literal_method_name.rb +83 -0
  505. data/lib/rubocop/cop/style/signal_exception.rb +9 -7
  506. data/lib/rubocop/cop/style/single_argument_dig.rb +7 -3
  507. data/lib/rubocop/cop/style/single_line_block_params.rb +1 -1
  508. data/lib/rubocop/cop/style/single_line_do_end_block.rb +67 -0
  509. data/lib/rubocop/cop/style/single_line_methods.rb +1 -1
  510. data/lib/rubocop/cop/style/slicing_with_range.rb +77 -11
  511. data/lib/rubocop/cop/style/sole_nested_conditional.rb +25 -12
  512. data/lib/rubocop/cop/style/special_global_vars.rb +4 -6
  513. data/lib/rubocop/cop/style/static_class.rb +32 -1
  514. data/lib/rubocop/cop/style/stderr_puts.rb +1 -1
  515. data/lib/rubocop/cop/style/string_chars.rb +1 -0
  516. data/lib/rubocop/cop/style/string_hash_keys.rb +4 -1
  517. data/lib/rubocop/cop/style/string_literals.rb +1 -5
  518. data/lib/rubocop/cop/style/string_literals_in_interpolation.rb +30 -5
  519. data/lib/rubocop/cop/style/strip.rb +7 -4
  520. data/lib/rubocop/cop/style/struct_inheritance.rb +3 -3
  521. data/lib/rubocop/cop/style/super_arguments.rb +137 -0
  522. data/lib/rubocop/cop/style/super_with_args_parentheses.rb +35 -0
  523. data/lib/rubocop/cop/style/swap_values.rb +1 -1
  524. data/lib/rubocop/cop/style/symbol_array.rb +40 -19
  525. data/lib/rubocop/cop/style/symbol_proc.rb +110 -15
  526. data/lib/rubocop/cop/style/ternary_parentheses.rb +1 -13
  527. data/lib/rubocop/cop/style/top_level_method_definition.rb +3 -1
  528. data/lib/rubocop/cop/style/trailing_body_on_class.rb +1 -0
  529. data/lib/rubocop/cop/style/trailing_comma_in_arguments.rb +4 -4
  530. data/lib/rubocop/cop/style/trailing_comma_in_block_args.rb +1 -1
  531. data/lib/rubocop/cop/style/trailing_underscore_variable.rb +1 -1
  532. data/lib/rubocop/cop/style/trivial_accessors.rb +4 -1
  533. data/lib/rubocop/cop/style/unless_logical_operators.rb +1 -0
  534. data/lib/rubocop/cop/style/unpack_first.rb +11 -14
  535. data/lib/rubocop/cop/style/word_array.rb +59 -5
  536. data/lib/rubocop/cop/style/yaml_file_read.rb +66 -0
  537. data/lib/rubocop/cop/style/yoda_condition.rb +17 -8
  538. data/lib/rubocop/cop/style/yoda_expression.rb +91 -0
  539. data/lib/rubocop/cop/style/zero_length_predicate.rb +40 -19
  540. data/lib/rubocop/cop/team.rb +66 -56
  541. data/lib/rubocop/cop/util.rb +46 -10
  542. data/lib/rubocop/cop/utils/regexp_ranges.rb +113 -0
  543. data/lib/rubocop/cop/variable_force/assignment.rb +45 -4
  544. data/lib/rubocop/cop/variable_force/scope.rb +3 -3
  545. data/lib/rubocop/cop/variable_force/variable.rb +5 -3
  546. data/lib/rubocop/cop/variable_force/variable_table.rb +6 -4
  547. data/lib/rubocop/cop/variable_force.rb +19 -30
  548. data/lib/rubocop/cops_documentation_generator.rb +60 -18
  549. data/lib/rubocop/directive_comment.rb +14 -12
  550. data/lib/rubocop/ext/comment.rb +18 -0
  551. data/lib/rubocop/ext/processed_source.rb +2 -0
  552. data/lib/rubocop/ext/range.rb +15 -0
  553. data/lib/rubocop/ext/regexp_node.rb +10 -5
  554. data/lib/rubocop/ext/regexp_parser.rb +5 -2
  555. data/lib/rubocop/feature_loader.rb +94 -0
  556. data/lib/rubocop/file_finder.rb +4 -7
  557. data/lib/rubocop/file_patterns.rb +43 -0
  558. data/lib/rubocop/formatter/clang_style_formatter.rb +4 -8
  559. data/lib/rubocop/formatter/disabled_config_formatter.rb +47 -15
  560. data/lib/rubocop/formatter/formatter_set.rb +27 -20
  561. data/lib/rubocop/formatter/{git_hub_actions_formatter.rb → github_actions_formatter.rb} +15 -2
  562. data/lib/rubocop/formatter/html_formatter.rb +38 -18
  563. data/lib/rubocop/formatter/json_formatter.rb +0 -1
  564. data/lib/rubocop/formatter/junit_formatter.rb +4 -1
  565. data/lib/rubocop/formatter/markdown_formatter.rb +1 -1
  566. data/lib/rubocop/formatter/offense_count_formatter.rb +21 -6
  567. data/lib/rubocop/formatter/simple_text_formatter.rb +7 -8
  568. data/lib/rubocop/formatter/tap_formatter.rb +4 -8
  569. data/lib/rubocop/formatter/worst_offenders_formatter.rb +6 -3
  570. data/lib/rubocop/formatter.rb +34 -0
  571. data/lib/rubocop/lockfile.rb +56 -7
  572. data/lib/rubocop/lsp/logger.rb +22 -0
  573. data/lib/rubocop/lsp/routes.rb +243 -0
  574. data/lib/rubocop/lsp/runtime.rb +99 -0
  575. data/lib/rubocop/lsp/server.rb +73 -0
  576. data/lib/rubocop/lsp/severity.rb +27 -0
  577. data/lib/rubocop/lsp.rb +36 -0
  578. data/lib/rubocop/magic_comment.rb +13 -11
  579. data/lib/rubocop/options.rb +101 -32
  580. data/lib/rubocop/path_util.rb +54 -22
  581. data/lib/rubocop/rake_task.rb +35 -10
  582. data/lib/rubocop/result_cache.rb +29 -24
  583. data/lib/rubocop/rspec/cop_helper.rb +32 -3
  584. data/lib/rubocop/rspec/expect_offense.rb +18 -8
  585. data/lib/rubocop/rspec/shared_contexts.rb +86 -33
  586. data/lib/rubocop/rspec/support.rb +19 -2
  587. data/lib/rubocop/runner.rb +91 -23
  588. data/lib/rubocop/server/cache.rb +155 -0
  589. data/lib/rubocop/server/cli.rb +147 -0
  590. data/lib/rubocop/server/client_command/base.rb +44 -0
  591. data/lib/rubocop/server/client_command/exec.rb +64 -0
  592. data/lib/rubocop/server/client_command/restart.rb +25 -0
  593. data/lib/rubocop/server/client_command/start.rb +48 -0
  594. data/lib/rubocop/server/client_command/status.rb +28 -0
  595. data/lib/rubocop/server/client_command/stop.rb +31 -0
  596. data/lib/rubocop/server/client_command.rb +26 -0
  597. data/lib/rubocop/server/core.rb +111 -0
  598. data/lib/rubocop/server/errors.rb +23 -0
  599. data/lib/rubocop/server/helper.rb +34 -0
  600. data/lib/rubocop/server/server_command/base.rb +50 -0
  601. data/lib/rubocop/server/server_command/exec.rb +33 -0
  602. data/lib/rubocop/server/server_command/stop.rb +24 -0
  603. data/lib/rubocop/server/server_command.rb +21 -0
  604. data/lib/rubocop/server/socket_reader.rb +69 -0
  605. data/lib/rubocop/server.rb +53 -0
  606. data/lib/rubocop/string_interpreter.rb +3 -3
  607. data/lib/rubocop/target_finder.rb +92 -82
  608. data/lib/rubocop/target_ruby.rb +86 -80
  609. data/lib/rubocop/version.rb +44 -12
  610. data/lib/rubocop.rb +73 -35
  611. metadata +145 -39
  612. data/lib/rubocop/cop/gemspec/date_assignment.rb +0 -49
  613. data/lib/rubocop/cop/mixin/ignored_methods.rb +0 -52
@@ -9,32 +9,15 @@ module RuboCop
9
9
  # On the other hand, `ENV.fetch` raises KeyError or returns the explicitly
10
10
  # specified default value.
11
11
  #
12
- # When an `ENV[]` is the LHS of `||`, the autocorrect makes the RHS
13
- # the default value of `ENV.fetch`.
14
- #
15
12
  # @example
16
13
  # # bad
17
14
  # ENV['X']
18
- # ENV['X'] || 'string literal'
19
- # ENV['X'] || some_method
20
15
  # x = ENV['X']
21
16
  #
22
- # ENV['X'] || y.map do |a|
23
- # puts a * 2
24
- # end
25
- #
26
17
  # # good
27
18
  # ENV.fetch('X')
28
- # ENV.fetch('X', 'string literal')
29
- # ENV.fetch('X') { some_method }
30
19
  # x = ENV.fetch('X')
31
20
  #
32
- # ENV.fetch('X') do
33
- # y.map do |a|
34
- # puts a * 2
35
- # end
36
- # end
37
- #
38
21
  # # also good
39
22
  # !ENV['X']
40
23
  # ENV['X'].some_method # (e.g. `.nil?`)
@@ -42,48 +25,20 @@ module RuboCop
42
25
  class FetchEnvVar < Base
43
26
  extend AutoCorrector
44
27
 
45
- # rubocop:disable Layout/LineLength
46
- MSG_DEFAULT_NIL = 'Use `ENV.fetch(%<key>s)` or `ENV.fetch(%<key>s, nil)` instead of `ENV[%<key>s]`.'
47
- MSG_DEFAULT_RHS_SECOND_ARG_OF_FETCH = 'Use `ENV.fetch(%<key>s, %<default>s)` instead of `ENV[%<key>s] || %<default>s`.'
48
- MSG_DEFAULT_RHS_SINGLE_LINE_BLOCK = 'Use `ENV.fetch(%<key>s) { %<default>s }` instead of `ENV[%<key>s] || %<default>s`.'
49
- MSG_DEFAULT_RHS_MULTILINE_BLOCK = 'Use `ENV.fetch(%<key>s)` with a block containing `%<default>s ...`'
50
- # rubocop:enable Layout/LineLength
28
+ MSG = 'Use `ENV.fetch(%<key>s)` or `ENV.fetch(%<key>s, nil)` instead of `ENV[%<key>s]`.'
51
29
 
52
30
  # @!method env_with_bracket?(node)
53
31
  def_node_matcher :env_with_bracket?, <<~PATTERN
54
32
  (send (const nil? :ENV) :[] $_)
55
33
  PATTERN
56
34
 
57
- # @!method operand_of_or?(node)
58
- def_node_matcher :operand_of_or?, <<~PATTERN
59
- (^or ...)
60
- PATTERN
61
-
62
- # @!method block_control?(node)
63
- def_node_matcher :block_control?, <<~PATTERN
64
- ({next | break | retry | redo})
65
- PATTERN
66
-
67
- # @!method offensive_nodes(node)
68
- def_node_search :offensive_nodes, <<~PATTERN
69
- [#env_with_bracket? #offensive?]
70
- PATTERN
71
-
72
35
  def on_send(node)
73
36
  env_with_bracket?(node) do |name_node|
74
37
  break unless offensive?(node)
75
38
 
76
- if operand_of_or?(node)
77
- target_node = offensive_nodes(or_chain_root(node)).to_a.last
78
- target_name_node = env_with_bracket?(target_node)
79
-
80
- if default_to_rhs?(target_node)
81
- default_rhs(target_node, target_name_node)
82
- else
83
- default_nil(target_node, target_name_node)
84
- end
85
- else
86
- default_nil(node, name_node)
39
+ message = format(MSG, key: name_node.source)
40
+ add_offense(node, message: message) do |corrector|
41
+ corrector.replace(node, new_code(name_node))
87
42
  end
88
43
  end
89
44
  end
@@ -130,17 +85,6 @@ module RuboCop
130
85
  !(allowed_var?(node) || allowable_use?(node))
131
86
  end
132
87
 
133
- def or_chain_root(node)
134
- while operand_of_or?(ancestor_or ||= node.parent)
135
- ancestor_or = ancestor_or.parent
136
- end
137
- ancestor_or
138
- end
139
-
140
- def default_to_rhs?(node)
141
- operand_of_or?(node) && !right_end_of_or_chains?(node) && rhs_can_be_default_value?(node)
142
- end
143
-
144
88
  # Check if the node is a receiver and receives a message with dot syntax.
145
89
  def message_chained_with_dot?(node)
146
90
  return false if node.root?
@@ -157,8 +101,9 @@ module RuboCop
157
101
  # it simply checks whether the variable is set.
158
102
  # - Receiving a message with dot syntax, e.g. `ENV['X'].nil?`.
159
103
  # - `ENV['key']` assigned by logical AND/OR assignment.
104
+ # - `ENV['key']` is the LHS of a `||`.
160
105
  def allowable_use?(node)
161
- used_as_flag?(node) || message_chained_with_dot?(node) || assigned?(node)
106
+ used_as_flag?(node) || message_chained_with_dot?(node) || assigned?(node) || or_lhs?(node)
162
107
  end
163
108
 
164
109
  # The following are allowed cases:
@@ -172,127 +117,15 @@ module RuboCop
172
117
  node == lhs
173
118
  end
174
119
 
175
- def left_end_of_or_chains?(node)
176
- return false unless operand_of_or?(node)
177
-
178
- node.parent.lhs == node
179
- end
180
-
181
- def right_end_of_or_chains?(node)
182
- !(left_end_of_or_chains?(node) || node.parent&.parent&.or_type?)
183
- end
184
-
185
- def conterpart_rhs_of(node)
186
- left_end_of_or_chains?(node) ? node.parent.rhs : node.parent.parent.rhs
187
- end
188
-
189
- def rhs_can_be_default_value?(node)
190
- !rhs_is_block_control?(node)
191
- end
120
+ def or_lhs?(node)
121
+ return false unless (parent = node.parent)&.or_type?
192
122
 
193
- def rhs_is_block_control?(node)
194
- block_control?(conterpart_rhs_of(node))
123
+ parent.lhs == node || parent.parent&.or_type?
195
124
  end
196
125
 
197
- def new_code_default_nil(name_node)
126
+ def new_code(name_node)
198
127
  "ENV.fetch(#{name_node.source}, nil)"
199
128
  end
200
-
201
- def new_code_default_rhs_single_line(node, name_node)
202
- parent = node.parent
203
- if parent.rhs.basic_literal?
204
- "ENV.fetch(#{name_node.source}, #{parent.rhs.source})"
205
- else
206
- "ENV.fetch(#{name_node.source}) { #{parent.rhs.source} }"
207
- end
208
- end
209
-
210
- def new_code_default_rhs_multiline(node, name_node)
211
- env_indent = indent(node.parent)
212
- default = node.parent.rhs.source.split("\n").map do |line|
213
- "#{env_indent}#{line}"
214
- end.join("\n")
215
- <<~NEW_CODE.chomp
216
- ENV.fetch(#{name_node.source}) do
217
- #{configured_indentation}#{default}
218
- #{env_indent}end
219
- NEW_CODE
220
- end
221
-
222
- def new_code_default_rhs(node, name_node)
223
- if node.parent.rhs.single_line?
224
- new_code_default_rhs_single_line(node, name_node)
225
- else
226
- new_code_default_rhs_multiline(node, name_node)
227
- end
228
- end
229
-
230
- def default_rhs(node, name_node)
231
- if left_end_of_or_chains?(node)
232
- default_rhs_in_same_or(node, name_node)
233
- else
234
- default_rhs_in_outer_or(node, name_node)
235
- end
236
- end
237
-
238
- # Adds an offense and sets `nil` to the default value of `ENV.fetch`.
239
- # `ENV['X']` --> `ENV.fetch('X', nil)`
240
- def default_nil(node, name_node)
241
- message = format(MSG_DEFAULT_NIL, key: name_node.source)
242
-
243
- add_offense(node, message: message) do |corrector|
244
- corrector.replace(node, new_code_default_nil(name_node))
245
- end
246
- end
247
-
248
- # Adds an offense and makes the RHS the default value of `ENV.fetch`.
249
- # `ENV['X'] || y` --> `ENV.fetch('X') { y }`
250
- def default_rhs_in_same_or(node, name_node)
251
- template = message_template_for(node.parent.rhs)
252
- message = format(template,
253
- key: name_node.source,
254
- default: first_line_of(node.parent.rhs.source))
255
-
256
- add_offense(node, message: message) do |corrector|
257
- corrector.replace(node.parent, new_code_default_rhs(node, name_node))
258
- end
259
- end
260
-
261
- # Adds an offense and makes the RHS the default value of `ENV.fetch`.
262
- # `z || ENV['X'] || y` --> `z || ENV.fetch('X') { y }`
263
- def default_rhs_in_outer_or(node, name_node)
264
- parent = node.parent
265
- grand_parent = parent.parent
266
-
267
- template = message_template_for(grand_parent.rhs)
268
- message = format(template,
269
- key: name_node.source,
270
- default: first_line_of(grand_parent.rhs.source))
271
-
272
- add_offense(node, message: message) do |corrector|
273
- lhs_code = parent.lhs.source
274
- rhs_code = new_code_default_rhs(parent, name_node)
275
- corrector.replace(grand_parent, "#{lhs_code} || #{rhs_code}")
276
- end
277
- end
278
-
279
- def message_template_for(rhs)
280
- if rhs.multiline?
281
- MSG_DEFAULT_RHS_MULTILINE_BLOCK
282
- elsif rhs.basic_literal?
283
- MSG_DEFAULT_RHS_SECOND_ARG_OF_FETCH
284
- else
285
- MSG_DEFAULT_RHS_SINGLE_LINE_BLOCK
286
- end
287
- end
288
-
289
- def configured_indentation
290
- ' ' * (config.for_cop('Layout/IndentationWidth')['Width'] || 2)
291
- end
292
-
293
- def first_line_of(source)
294
- source.split("\n").first
295
- end
296
129
  end
297
130
  end
298
131
  end
@@ -0,0 +1,71 @@
1
+ # frozen_string_literal: true
2
+
3
+ module RuboCop
4
+ module Cop
5
+ module Style
6
+ # Prefer to use `File.empty?('path/to/file')` when checking if a file is empty.
7
+ #
8
+ # @safety
9
+ # This cop is unsafe, because `File.size`, `File.read`, and `File.binread`
10
+ # raise `ENOENT` exception when there is no file corresponding to the path,
11
+ # while `File.empty?` does not raise an exception.
12
+ #
13
+ # @example
14
+ # # bad
15
+ # File.zero?('path/to/file')
16
+ # File.size('path/to/file') == 0
17
+ # File.size('path/to/file') >= 0
18
+ # File.size('path/to/file').zero?
19
+ # File.read('path/to/file').empty?
20
+ # File.binread('path/to/file') == ''
21
+ # FileTest.zero?('path/to/file')
22
+ #
23
+ # # good
24
+ # File.empty?('path/to/file')
25
+ # FileTest.empty?('path/to/file')
26
+ #
27
+ class FileEmpty < Base
28
+ extend AutoCorrector
29
+ extend TargetRubyVersion
30
+
31
+ MSG = 'Use `%<file_class>s.empty?(%<arg>s)` instead.'
32
+ RESTRICT_ON_SEND = %i[>= != == zero? empty?].freeze
33
+
34
+ minimum_target_ruby_version 2.4
35
+
36
+ # @!method offensive?(node)
37
+ def_node_matcher :offensive?, <<~PATTERN
38
+ {
39
+ (send $(const {nil? cbase} {:File :FileTest}) :zero? $_)
40
+ (send (send $(const {nil? cbase} {:File :FileTest}) :size $_) {:== :>=} (int 0))
41
+ (send (send (send $(const {nil? cbase} {:File :FileTest}) :size $_) :!) {:== :>=} (int 0))
42
+ (send (send $(const {nil? cbase} {:File :FileTest}) :size $_) :zero?)
43
+ (send (send $(const {nil? cbase} {:File :FileTest}) {:read :binread} $_) {:!= :==} (str empty?))
44
+ (send (send (send $(const {nil? cbase} {:File :FileTest}) {:read :binread} $_) :!) {:!= :==} (str empty?))
45
+ (send (send $(const {nil? cbase} {:File :FileTest}) {:read :binread} $_) :empty?)
46
+ }
47
+ PATTERN
48
+
49
+ def on_send(node)
50
+ offensive?(node) do |const_node, arg_node|
51
+ add_offense(node,
52
+ message: format(MSG, file_class: const_node.source,
53
+ arg: arg_node.source)) do |corrector|
54
+ corrector.replace(node,
55
+ "#{bang(node)}#{const_node.source}.empty?(#{arg_node.source})")
56
+ end
57
+ end
58
+ end
59
+
60
+ private
61
+
62
+ def bang(node)
63
+ if (node.method?(:==) && node.child_nodes.first.method?(:!)) ||
64
+ (%i[>= !=].include?(node.method_name) && !node.child_nodes.first.method?(:!))
65
+ '!'
66
+ end
67
+ end
68
+ end
69
+ end
70
+ end
71
+ end
@@ -63,7 +63,7 @@ module RuboCop
63
63
 
64
64
  # @!method block_read?(node)
65
65
  def_node_matcher :block_read?, <<~PATTERN
66
- (block _ (args (arg $_)) (send (lvar $_) :read))
66
+ (block _ (args (arg _name)) (send (lvar _name) :read))
67
67
  PATTERN
68
68
 
69
69
  def on_send(node)
@@ -71,7 +71,7 @@ module RuboCop
71
71
  message = format(MSG, read_method: read_method(mode))
72
72
 
73
73
  add_offense(read_node, message: message) do |corrector|
74
- range = range_between(node.loc.selector.begin_pos, read_node.loc.expression.end_pos)
74
+ range = range_between(node.loc.selector.begin_pos, read_node.source_range.end_pos)
75
75
  replacement = "#{read_method(mode)}(#{filename.source})"
76
76
 
77
77
  corrector.replace(range, replacement)
@@ -100,7 +100,7 @@ module RuboCop
100
100
  def file_open_read?(node)
101
101
  return true if send_read?(node)
102
102
 
103
- block_read?(node) { |block_arg, read_lvar| block_arg == read_lvar }
103
+ block_read?(node)
104
104
  end
105
105
 
106
106
  def read_method(mode)
@@ -74,7 +74,7 @@ module RuboCop
74
74
  message = format(MSG, write_method: write_method(mode))
75
75
 
76
76
  add_offense(write_node, message: message) do |corrector|
77
- range = range_between(node.loc.selector.begin_pos, write_node.loc.expression.end_pos)
77
+ range = range_between(node.loc.selector.begin_pos, write_node.source_range.end_pos)
78
78
  replacement = replacement(mode, filename, content, write_node)
79
79
 
80
80
  corrector.replace(range, replacement)
@@ -66,6 +66,8 @@ module RuboCop
66
66
  return unless suspect_enumerable?(node)
67
67
 
68
68
  if style == :for
69
+ return unless node.receiver
70
+
69
71
  add_offense(node, message: PREFER_FOR) do |corrector|
70
72
  EachToForCorrector.new(node).call(corrector)
71
73
  opposite_style_detected
@@ -75,10 +77,12 @@ module RuboCop
75
77
  end
76
78
  end
77
79
 
80
+ alias on_numblock on_block
81
+
78
82
  private
79
83
 
80
84
  def suspect_enumerable?(node)
81
- node.multiline? && node.send_node.method?(:each) && !node.send_node.arguments?
85
+ node.multiline? && node.method?(:each) && !node.send_node.arguments?
82
86
  end
83
87
  end
84
88
  end
@@ -4,36 +4,48 @@ module RuboCop
4
4
  module Cop
5
5
  module Style
6
6
  # Enforces the use of a single string formatting utility.
7
- # Valid options include Kernel#format, Kernel#sprintf and String#%.
7
+ # Valid options include `Kernel#format`, `Kernel#sprintf`, and `String#%`.
8
8
  #
9
- # The detection of String#% cannot be implemented in a reliable
9
+ # The detection of `String#%` cannot be implemented in a reliable
10
10
  # manner for all cases, so only two scenarios are considered -
11
11
  # if the first argument is a string literal and if the second
12
12
  # argument is an array literal.
13
13
  #
14
+ # Autocorrection will be applied when using argument is a literal or known built-in conversion
15
+ # methods such as `to_d`, `to_f`, `to_h`, `to_i`, `to_r`, `to_s`, and `to_sym` on variables,
16
+ # provided that their return value is not an array. For example, when using `to_s`,
17
+ # `'%s' % [1, 2, 3].to_s` can be autocorrected without any incompatibility:
18
+ #
19
+ # [source,ruby]
20
+ # ----
21
+ # '%s' % [1, 2, 3] #=> '1'
22
+ # format('%s', [1, 2, 3]) #=> '[1, 2, 3]'
23
+ # '%s' % [1, 2, 3].to_s #=> '[1, 2, 3]'
24
+ # ----
25
+ #
14
26
  # @example EnforcedStyle: format (default)
15
27
  # # bad
16
- # puts sprintf('%10s', 'hoge')
17
- # puts '%10s' % 'hoge'
28
+ # puts sprintf('%10s', 'foo')
29
+ # puts '%10s' % 'foo'
18
30
  #
19
31
  # # good
20
- # puts format('%10s', 'hoge')
32
+ # puts format('%10s', 'foo')
21
33
  #
22
34
  # @example EnforcedStyle: sprintf
23
35
  # # bad
24
- # puts format('%10s', 'hoge')
25
- # puts '%10s' % 'hoge'
36
+ # puts format('%10s', 'foo')
37
+ # puts '%10s' % 'foo'
26
38
  #
27
39
  # # good
28
- # puts sprintf('%10s', 'hoge')
40
+ # puts sprintf('%10s', 'foo')
29
41
  #
30
42
  # @example EnforcedStyle: percent
31
43
  # # bad
32
- # puts format('%10s', 'hoge')
33
- # puts sprintf('%10s', 'hoge')
44
+ # puts format('%10s', 'foo')
45
+ # puts sprintf('%10s', 'foo')
34
46
  #
35
47
  # # good
36
- # puts '%10s' % 'hoge'
48
+ # puts '%10s' % 'foo'
37
49
  #
38
50
  class FormatString < Base
39
51
  include ConfigurableEnforcedStyle
@@ -42,6 +54,9 @@ module RuboCop
42
54
  MSG = 'Favor `%<prefer>s` over `%<current>s`.'
43
55
  RESTRICT_ON_SEND = %i[format sprintf %].freeze
44
56
 
57
+ # Known conversion methods whose return value is not an array.
58
+ AUTOCORRECTABLE_METHODS = %i[to_d to_f to_h to_i to_r to_s to_sym].freeze
59
+
45
60
  # @!method formatter(node)
46
61
  def_node_matcher :formatter, <<~PATTERN
47
62
  {
@@ -53,7 +68,7 @@ module RuboCop
53
68
 
54
69
  # @!method variable_argument?(node)
55
70
  def_node_matcher :variable_argument?, <<~PATTERN
56
- (send {str dstr} :% {send_type? lvar_type?})
71
+ (send {str dstr} :% #autocorrectable?)
57
72
  PATTERN
58
73
 
59
74
  def on_send(node)
@@ -70,6 +85,12 @@ module RuboCop
70
85
 
71
86
  private
72
87
 
88
+ def autocorrectable?(node)
89
+ return true if node.lvar_type?
90
+
91
+ node.send_type? && !AUTOCORRECTABLE_METHODS.include?(node.method_name)
92
+ end
93
+
73
94
  def message(detected_style)
74
95
  format(MSG, prefer: method_name(style), current: method_name(detected_style))
75
96
  end
@@ -11,7 +11,8 @@ module RuboCop
11
11
  # The reason is that _unannotated_ format is very similar
12
12
  # to encoded URLs or Date/Time formatting strings.
13
13
  #
14
- # This cop can be customized ignored methods with `IgnoredMethods`.
14
+ # This cop can be customized allowed methods with `AllowedMethods`.
15
+ # By default, there are no methods to allowed.
15
16
  #
16
17
  # @example EnforcedStyle: annotated (default)
17
18
  #
@@ -61,29 +62,41 @@ module RuboCop
61
62
  # # good
62
63
  # format('%06d', 10)
63
64
  #
64
- # @example IgnoredMethods: [redirect]
65
+ # @example AllowedMethods: [] (default)
66
+ #
67
+ # # bad
68
+ # redirect('foo/%{bar_id}')
69
+ #
70
+ # @example AllowedMethods: [redirect]
71
+ #
72
+ # # good
73
+ # redirect('foo/%{bar_id}')
74
+ #
75
+ # @example AllowedPatterns: [] (default)
76
+ #
77
+ # # bad
78
+ # redirect('foo/%{bar_id}')
79
+ #
80
+ # @example AllowedPatterns: ['redirect']
65
81
  #
66
82
  # # good
67
83
  # redirect('foo/%{bar_id}')
68
84
  #
69
85
  class FormatStringToken < Base
70
86
  include ConfigurableEnforcedStyle
71
- include IgnoredMethods
87
+ include AllowedMethods
88
+ include AllowedPattern
89
+ extend AutoCorrector
72
90
 
73
91
  def on_str(node)
74
- return if format_string_token?(node) || use_ignored_method?(node)
92
+ return if format_string_token?(node) || use_allowed_method?(node)
75
93
 
76
94
  detections = collect_detections(node)
77
95
  return if detections.empty?
78
96
  return if allowed_unannotated?(detections)
79
97
 
80
- detections.each do |detected_style, token_range|
81
- if detected_style == style
82
- correct_style_detected
83
- else
84
- style_detected(detected_style)
85
- add_offense(token_range, message: message(detected_style))
86
- end
98
+ detections.each do |detected_sequence, token_range|
99
+ check_sequence(detected_sequence, token_range)
87
100
  end
88
101
  end
89
102
 
@@ -101,9 +114,43 @@ module RuboCop
101
114
  !node.value.include?('%') || node.each_ancestor(:xstr, :regexp).any?
102
115
  end
103
116
 
104
- def use_ignored_method?(node)
117
+ def use_allowed_method?(node)
105
118
  send_parent = node.each_ancestor(:send).first
106
- send_parent && ignored_method?(send_parent.method_name)
119
+ send_parent &&
120
+ (allowed_method?(send_parent.method_name) ||
121
+ matches_allowed_pattern?(send_parent.method_name))
122
+ end
123
+
124
+ def check_sequence(detected_sequence, token_range)
125
+ if detected_sequence.style == style
126
+ correct_style_detected
127
+ elsif correctable_sequence?(detected_sequence.type)
128
+ style_detected(detected_sequence.style)
129
+ add_offense(token_range, message: message(detected_sequence.style)) do |corrector|
130
+ autocorrect_sequence(corrector, detected_sequence, token_range)
131
+ end
132
+ end
133
+ end
134
+
135
+ def correctable_sequence?(detected_type)
136
+ detected_type == 's' || style == :annotated || style == :unannotated
137
+ end
138
+
139
+ def autocorrect_sequence(corrector, detected_sequence, token_range)
140
+ return if style == :unannotated
141
+
142
+ name = detected_sequence.name
143
+ return if name.nil?
144
+
145
+ flags = detected_sequence.flags
146
+ width = detected_sequence.width
147
+ precision = detected_sequence.precision
148
+ type = detected_sequence.style == :template ? 's' : detected_sequence.type
149
+ correction = case style
150
+ when :annotated then "%<#{name}>#{flags}#{width}#{precision}#{type}"
151
+ when :template then "%#{flags}#{width}#{precision}{#{name}}"
152
+ end
153
+ corrector.replace(token_range, correction)
107
154
  end
108
155
 
109
156
  def unannotated_format?(node, detected_style)
@@ -143,30 +190,33 @@ module RuboCop
143
190
  def token_ranges(contents)
144
191
  format_string = RuboCop::Cop::Utils::FormatString.new(contents.source)
145
192
 
146
- format_string.format_sequences.each do |seq|
147
- next if seq.percent?
193
+ format_string.format_sequences.each do |detected_sequence|
194
+ next if detected_sequence.percent?
148
195
 
149
- detected_style = seq.style
150
- token = contents.begin.adjust(begin_pos: seq.begin_pos, end_pos: seq.end_pos)
196
+ token = contents.begin.adjust(begin_pos: detected_sequence.begin_pos,
197
+ end_pos: detected_sequence.end_pos)
151
198
 
152
- yield(detected_style, token)
199
+ yield(detected_sequence, token)
153
200
  end
154
201
  end
155
202
 
156
203
  def collect_detections(node)
157
204
  detections = []
158
- tokens(node) do |detected_style, token_range|
159
- unless unannotated_format?(node, detected_style)
160
- detections << [detected_style, token_range]
205
+ tokens(node) do |detected_sequence, token_range|
206
+ unless unannotated_format?(node, detected_sequence.style)
207
+ detections << [detected_sequence, token_range]
161
208
  end
162
209
  end
163
210
  detections
164
211
  end
165
212
 
166
213
  def allowed_unannotated?(detections)
167
- return false if detections.size > max_unannotated_placeholders_allowed
214
+ return false unless detections.all? do |detected_sequence,|
215
+ detected_sequence.style == :unannotated
216
+ end
217
+ return true if detections.size <= max_unannotated_placeholders_allowed
168
218
 
169
- detections.all? { |detected_style,| detected_style == :unannotated }
219
+ detections.any? { |detected_sequence,| !correctable_sequence?(detected_sequence.type) }
170
220
  end
171
221
 
172
222
  def max_unannotated_placeholders_allowed
@@ -142,13 +142,15 @@ module RuboCop
142
142
  end
143
143
 
144
144
  next_token = processed_source.tokens[token_number]
145
- token = next_token if Encoding::ENCODING_PATTERN.match?(next_token&.text)
145
+ if next_token&.text&.valid_encoding? && Encoding::ENCODING_PATTERN.match?(next_token.text)
146
+ token = next_token
147
+ end
146
148
 
147
149
  token
148
150
  end
149
151
 
150
152
  def frozen_string_literal_comment(processed_source)
151
- processed_source.find_token do |token|
153
+ processed_source.tokens.find do |token|
152
154
  token.text.start_with?(FROZEN_STRING_LITERAL)
153
155
  end
154
156
  end
@@ -182,7 +184,7 @@ module RuboCop
182
184
  end
183
185
 
184
186
  def remove_comment(corrector, node)
185
- corrector.remove(range_with_surrounding_space(range: node.pos, side: :right))
187
+ corrector.remove(range_with_surrounding_space(node.pos, side: :right))
186
188
  end
187
189
 
188
190
  def enable_comment(corrector)