rubocop 1.31.1 → 1.52.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (475) hide show
  1. checksums.yaml +4 -4
  2. data/LICENSE.txt +1 -1
  3. data/README.md +5 -5
  4. data/config/default.yml +362 -54
  5. data/config/obsoletion.yml +23 -1
  6. data/exe/rubocop +1 -1
  7. data/lib/rubocop/arguments_env.rb +17 -0
  8. data/lib/rubocop/arguments_file.rb +17 -0
  9. data/lib/rubocop/cache_config.rb +29 -0
  10. data/lib/rubocop/cli/command/{auto_genenerate_config.rb → auto_generate_config.rb} +9 -2
  11. data/lib/rubocop/cli/command/execute_runner.rb +14 -9
  12. data/lib/rubocop/cli/command/init_dotfile.rb +1 -1
  13. data/lib/rubocop/cli/command/suggest_extensions.rb +61 -16
  14. data/lib/rubocop/cli.rb +56 -9
  15. data/lib/rubocop/comment_config.rb +60 -1
  16. data/lib/rubocop/config.rb +48 -20
  17. data/lib/rubocop/config_finder.rb +68 -0
  18. data/lib/rubocop/config_loader.rb +46 -68
  19. data/lib/rubocop/config_loader_resolver.rb +11 -12
  20. data/lib/rubocop/config_obsoletion/changed_parameter.rb +5 -0
  21. data/lib/rubocop/config_obsoletion/parameter_rule.rb +4 -0
  22. data/lib/rubocop/config_obsoletion.rb +9 -4
  23. data/lib/rubocop/config_validator.rb +1 -1
  24. data/lib/rubocop/cop/autocorrect_logic.rb +29 -13
  25. data/lib/rubocop/cop/badge.rb +9 -4
  26. data/lib/rubocop/cop/base.rb +116 -84
  27. data/lib/rubocop/cop/bundler/gem_comment.rb +1 -1
  28. data/lib/rubocop/cop/commissioner.rb +19 -6
  29. data/lib/rubocop/cop/cop.rb +54 -34
  30. data/lib/rubocop/cop/corrector.rb +31 -11
  31. data/lib/rubocop/cop/correctors/alignment_corrector.rb +3 -3
  32. data/lib/rubocop/cop/correctors/each_to_for_corrector.rb +3 -3
  33. data/lib/rubocop/cop/correctors/for_to_each_corrector.rb +3 -3
  34. data/lib/rubocop/cop/correctors/line_break_corrector.rb +1 -1
  35. data/lib/rubocop/cop/correctors/multiline_literal_brace_corrector.rb +23 -7
  36. data/lib/rubocop/cop/correctors/ordered_gem_corrector.rb +2 -7
  37. data/lib/rubocop/cop/correctors/parentheses_corrector.rb +58 -0
  38. data/lib/rubocop/cop/correctors/percent_literal_corrector.rb +2 -2
  39. data/lib/rubocop/cop/gemspec/dependency_version.rb +17 -19
  40. data/lib/rubocop/cop/gemspec/deprecated_attribute_assignment.rb +1 -1
  41. data/lib/rubocop/cop/gemspec/development_dependencies.rb +107 -0
  42. data/lib/rubocop/cop/gemspec/require_mfa.rb +1 -1
  43. data/lib/rubocop/cop/generator/require_file_injector.rb +2 -2
  44. data/lib/rubocop/cop/generator.rb +5 -2
  45. data/lib/rubocop/cop/internal_affairs/cop_description.rb +38 -12
  46. data/lib/rubocop/cop/internal_affairs/create_empty_file.rb +37 -0
  47. data/lib/rubocop/cop/internal_affairs/example_heredoc_delimiter.rb +111 -0
  48. data/lib/rubocop/cop/internal_affairs/inherit_deprecated_cop_class.rb +1 -1
  49. data/lib/rubocop/cop/internal_affairs/lambda_or_proc.rb +46 -0
  50. data/lib/rubocop/cop/internal_affairs/location_expression.rb +37 -0
  51. data/lib/rubocop/cop/internal_affairs/node_matcher_directive.rb +3 -3
  52. data/lib/rubocop/cop/internal_affairs/node_type_predicate.rb +1 -1
  53. data/lib/rubocop/cop/internal_affairs/numblock_handler.rb +69 -0
  54. data/lib/rubocop/cop/internal_affairs/processed_source_buffer_name.rb +42 -0
  55. data/lib/rubocop/cop/internal_affairs/redundant_let_rubocop_config_new.rb +11 -3
  56. data/lib/rubocop/cop/internal_affairs/redundant_location_argument.rb +1 -1
  57. data/lib/rubocop/cop/internal_affairs/redundant_message_argument.rb +1 -1
  58. data/lib/rubocop/cop/internal_affairs/redundant_source_range.rb +66 -0
  59. data/lib/rubocop/cop/internal_affairs/single_line_comparison.rb +62 -0
  60. data/lib/rubocop/cop/internal_affairs/useless_restrict_on_send.rb +60 -0
  61. data/lib/rubocop/cop/internal_affairs.rb +9 -0
  62. data/lib/rubocop/cop/layout/array_alignment.rb +1 -1
  63. data/lib/rubocop/cop/layout/block_alignment.rb +16 -12
  64. data/lib/rubocop/cop/layout/block_end_newline.rb +31 -9
  65. data/lib/rubocop/cop/layout/class_structure.rb +37 -27
  66. data/lib/rubocop/cop/layout/closing_heredoc_indentation.rb +1 -2
  67. data/lib/rubocop/cop/layout/closing_parenthesis_indentation.rb +2 -6
  68. data/lib/rubocop/cop/layout/comment_indentation.rb +3 -1
  69. data/lib/rubocop/cop/layout/empty_comment.rb +3 -3
  70. data/lib/rubocop/cop/layout/empty_line_between_defs.rb +1 -1
  71. data/lib/rubocop/cop/layout/empty_lines.rb +3 -1
  72. data/lib/rubocop/cop/layout/empty_lines_around_access_modifier.rb +7 -2
  73. data/lib/rubocop/cop/layout/empty_lines_around_block_body.rb +2 -0
  74. data/lib/rubocop/cop/layout/end_alignment.rb +9 -1
  75. data/lib/rubocop/cop/layout/end_of_line.rb +4 -4
  76. data/lib/rubocop/cop/layout/extra_spacing.rb +15 -6
  77. data/lib/rubocop/cop/layout/first_argument_indentation.rb +15 -4
  78. data/lib/rubocop/cop/layout/first_array_element_indentation.rb +6 -5
  79. data/lib/rubocop/cop/layout/first_array_element_line_break.rb +35 -8
  80. data/lib/rubocop/cop/layout/first_hash_element_indentation.rb +5 -5
  81. data/lib/rubocop/cop/layout/first_hash_element_line_break.rb +36 -1
  82. data/lib/rubocop/cop/layout/first_method_argument_line_break.rb +57 -8
  83. data/lib/rubocop/cop/layout/first_method_parameter_line_break.rb +52 -19
  84. data/lib/rubocop/cop/layout/heredoc_argument_closing_parenthesis.rb +10 -4
  85. data/lib/rubocop/cop/layout/heredoc_indentation.rb +8 -11
  86. data/lib/rubocop/cop/layout/indentation_style.rb +7 -2
  87. data/lib/rubocop/cop/layout/indentation_width.rb +6 -2
  88. data/lib/rubocop/cop/layout/initial_indentation.rb +1 -1
  89. data/lib/rubocop/cop/layout/leading_comment_space.rb +1 -1
  90. data/lib/rubocop/cop/layout/line_continuation_leading_space.rb +80 -12
  91. data/lib/rubocop/cop/layout/line_continuation_spacing.rb +18 -8
  92. data/lib/rubocop/cop/layout/line_length.rb +8 -1
  93. data/lib/rubocop/cop/layout/multiline_array_line_breaks.rb +31 -1
  94. data/lib/rubocop/cop/layout/multiline_assignment_layout.rb +1 -1
  95. data/lib/rubocop/cop/layout/multiline_block_layout.rb +3 -1
  96. data/lib/rubocop/cop/layout/multiline_hash_key_line_breaks.rb +29 -1
  97. data/lib/rubocop/cop/layout/multiline_method_argument_line_breaks.rb +39 -2
  98. data/lib/rubocop/cop/layout/multiline_method_parameter_line_breaks.rb +77 -0
  99. data/lib/rubocop/cop/layout/redundant_line_break.rb +9 -10
  100. data/lib/rubocop/cop/layout/rescue_ensure_alignment.rb +2 -2
  101. data/lib/rubocop/cop/layout/space_around_block_parameters.rb +1 -1
  102. data/lib/rubocop/cop/layout/space_around_keyword.rb +3 -3
  103. data/lib/rubocop/cop/layout/space_around_operators.rb +1 -1
  104. data/lib/rubocop/cop/layout/space_before_block_braces.rb +2 -0
  105. data/lib/rubocop/cop/layout/space_before_first_arg.rb +1 -1
  106. data/lib/rubocop/cop/layout/space_in_lambda_literal.rb +2 -2
  107. data/lib/rubocop/cop/layout/space_inside_array_literal_brackets.rb +22 -20
  108. data/lib/rubocop/cop/layout/space_inside_array_percent_literal.rb +3 -0
  109. data/lib/rubocop/cop/layout/space_inside_block_braces.rb +27 -9
  110. data/lib/rubocop/cop/layout/space_inside_hash_literal_braces.rb +30 -3
  111. data/lib/rubocop/cop/layout/space_inside_parens.rb +2 -2
  112. data/lib/rubocop/cop/layout/space_inside_percent_literal_delimiters.rb +34 -0
  113. data/lib/rubocop/cop/layout/space_inside_reference_brackets.rb +10 -6
  114. data/lib/rubocop/cop/layout/space_inside_string_interpolation.rb +5 -4
  115. data/lib/rubocop/cop/layout/trailing_empty_lines.rb +1 -1
  116. data/lib/rubocop/cop/layout/trailing_whitespace.rb +12 -5
  117. data/lib/rubocop/cop/legacy/corrections_proxy.rb +1 -1
  118. data/lib/rubocop/cop/legacy/corrector.rb +1 -1
  119. data/lib/rubocop/cop/lint/ambiguous_block_association.rb +40 -8
  120. data/lib/rubocop/cop/lint/ambiguous_operator.rb +4 -0
  121. data/lib/rubocop/cop/lint/assignment_in_condition.rb +11 -1
  122. data/lib/rubocop/cop/lint/constant_resolution.rb +5 -1
  123. data/lib/rubocop/cop/lint/debugger.rb +27 -31
  124. data/lib/rubocop/cop/lint/deprecated_class_methods.rb +66 -110
  125. data/lib/rubocop/cop/lint/deprecated_constants.rb +8 -1
  126. data/lib/rubocop/cop/lint/deprecated_open_ssl_constant.rb +1 -1
  127. data/lib/rubocop/cop/lint/duplicate_branch.rb +0 -2
  128. data/lib/rubocop/cop/lint/duplicate_magic_comment.rb +73 -0
  129. data/lib/rubocop/cop/lint/duplicate_match_pattern.rb +122 -0
  130. data/lib/rubocop/cop/lint/duplicate_methods.rb +48 -18
  131. data/lib/rubocop/cop/lint/duplicate_regexp_character_class_element.rb +26 -9
  132. data/lib/rubocop/cop/lint/duplicate_require.rb +1 -1
  133. data/lib/rubocop/cop/lint/else_layout.rb +3 -7
  134. data/lib/rubocop/cop/lint/empty_block.rb +3 -7
  135. data/lib/rubocop/cop/lint/empty_class.rb +3 -1
  136. data/lib/rubocop/cop/lint/empty_conditional_body.rb +110 -2
  137. data/lib/rubocop/cop/lint/empty_interpolation.rb +1 -1
  138. data/lib/rubocop/cop/lint/erb_new_arguments.rb +12 -13
  139. data/lib/rubocop/cop/lint/format_parameter_mismatch.rb +14 -7
  140. data/lib/rubocop/cop/lint/heredoc_method_call_position.rb +15 -17
  141. data/lib/rubocop/cop/lint/identity_comparison.rb +0 -1
  142. data/lib/rubocop/cop/lint/implicit_string_concatenation.rb +1 -1
  143. data/lib/rubocop/cop/lint/incompatible_io_select_with_fiber_scheduler.rb +5 -3
  144. data/lib/rubocop/cop/lint/ineffective_access_modifier.rb +1 -1
  145. data/lib/rubocop/cop/lint/inherit_exception.rb +9 -0
  146. data/lib/rubocop/cop/lint/interpolation_check.rb +4 -3
  147. data/lib/rubocop/cop/lint/lambda_without_literal_block.rb +1 -1
  148. data/lib/rubocop/cop/lint/literal_in_interpolation.rb +48 -2
  149. data/lib/rubocop/cop/lint/missing_cop_enable_directive.rb +18 -3
  150. data/lib/rubocop/cop/lint/missing_super.rb +34 -2
  151. data/lib/rubocop/cop/lint/mixed_regexp_capture_types.rb +1 -0
  152. data/lib/rubocop/cop/lint/nested_method_definition.rb +53 -9
  153. data/lib/rubocop/cop/lint/next_without_accumulator.rb +25 -6
  154. data/lib/rubocop/cop/lint/non_atomic_file_operation.rb +68 -28
  155. data/lib/rubocop/cop/lint/non_deterministic_require_order.rb +12 -0
  156. data/lib/rubocop/cop/lint/number_conversion.rb +28 -6
  157. data/lib/rubocop/cop/lint/numbered_parameter_assignment.rb +2 -2
  158. data/lib/rubocop/cop/lint/or_assignment_to_constant.rb +2 -0
  159. data/lib/rubocop/cop/lint/ordered_magic_comments.rb +4 -6
  160. data/lib/rubocop/cop/lint/out_of_range_regexp_ref.rb +17 -2
  161. data/lib/rubocop/cop/lint/parentheses_as_grouped_expression.rb +5 -0
  162. data/lib/rubocop/cop/lint/percent_string_array.rb +1 -1
  163. data/lib/rubocop/cop/lint/percent_symbol_array.rb +1 -1
  164. data/lib/rubocop/cop/lint/redundant_cop_disable_directive.rb +49 -9
  165. data/lib/rubocop/cop/lint/redundant_cop_enable_directive.rb +6 -6
  166. data/lib/rubocop/cop/lint/redundant_dir_glob_sort.rb +7 -0
  167. data/lib/rubocop/cop/lint/redundant_require_statement.rb +48 -10
  168. data/lib/rubocop/cop/lint/redundant_safe_navigation.rb +13 -0
  169. data/lib/rubocop/cop/lint/redundant_splat_expansion.rb +1 -1
  170. data/lib/rubocop/cop/lint/redundant_string_coercion.rb +35 -15
  171. data/lib/rubocop/cop/lint/redundant_with_index.rb +14 -11
  172. data/lib/rubocop/cop/lint/redundant_with_object.rb +13 -12
  173. data/lib/rubocop/cop/lint/refinement_import_methods.rb +2 -1
  174. data/lib/rubocop/cop/lint/regexp_as_condition.rb +6 -0
  175. data/lib/rubocop/cop/lint/require_parentheses.rb +3 -1
  176. data/lib/rubocop/cop/lint/require_range_parentheses.rb +57 -0
  177. data/lib/rubocop/cop/lint/rescue_type.rb +3 -3
  178. data/lib/rubocop/cop/lint/safe_navigation_chain.rb +41 -8
  179. data/lib/rubocop/cop/lint/safe_navigation_consistency.rb +1 -1
  180. data/lib/rubocop/cop/lint/script_permission.rb +1 -1
  181. data/lib/rubocop/cop/lint/send_with_mixin_argument.rb +6 -6
  182. data/lib/rubocop/cop/lint/shadowed_exception.rb +21 -22
  183. data/lib/rubocop/cop/lint/shadowing_outer_local_variable.rb +28 -3
  184. data/lib/rubocop/cop/lint/suppressed_exception.rb +1 -1
  185. data/lib/rubocop/cop/lint/syntax.rb +4 -0
  186. data/lib/rubocop/cop/lint/to_enum_arguments.rb +13 -3
  187. data/lib/rubocop/cop/lint/top_level_return_with_argument.rb +23 -9
  188. data/lib/rubocop/cop/lint/unreachable_loop.rb +12 -6
  189. data/lib/rubocop/cop/lint/unused_method_argument.rb +6 -1
  190. data/lib/rubocop/cop/lint/useless_access_modifier.rb +17 -12
  191. data/lib/rubocop/cop/lint/useless_assignment.rb +59 -1
  192. data/lib/rubocop/cop/lint/useless_method_definition.rb +12 -4
  193. data/lib/rubocop/cop/lint/useless_rescue.rb +89 -0
  194. data/lib/rubocop/cop/lint/useless_ruby2_keywords.rb +15 -5
  195. data/lib/rubocop/cop/lint/useless_times.rb +1 -1
  196. data/lib/rubocop/cop/lint/void.rb +92 -21
  197. data/lib/rubocop/cop/metrics/abc_size.rb +4 -2
  198. data/lib/rubocop/cop/metrics/block_length.rb +16 -11
  199. data/lib/rubocop/cop/metrics/block_nesting.rb +2 -2
  200. data/lib/rubocop/cop/metrics/class_length.rb +11 -5
  201. data/lib/rubocop/cop/metrics/collection_literal_length.rb +76 -0
  202. data/lib/rubocop/cop/metrics/cyclomatic_complexity.rb +1 -1
  203. data/lib/rubocop/cop/metrics/method_length.rb +17 -11
  204. data/lib/rubocop/cop/metrics/module_length.rb +10 -5
  205. data/lib/rubocop/cop/metrics/parameter_lists.rb +27 -0
  206. data/lib/rubocop/cop/metrics/perceived_complexity.rb +1 -1
  207. data/lib/rubocop/cop/metrics/utils/abc_size_calculator.rb +4 -8
  208. data/lib/rubocop/cop/metrics/utils/code_length_calculator.rb +9 -6
  209. data/lib/rubocop/cop/migration/department_name.rb +1 -1
  210. data/lib/rubocop/cop/mixin/alignment.rb +2 -2
  211. data/lib/rubocop/cop/mixin/allowed_identifiers.rb +2 -2
  212. data/lib/rubocop/cop/mixin/allowed_methods.rb +23 -2
  213. data/lib/rubocop/cop/mixin/allowed_pattern.rb +17 -1
  214. data/lib/rubocop/cop/mixin/allowed_receivers.rb +34 -0
  215. data/lib/rubocop/cop/mixin/annotation_comment.rb +14 -7
  216. data/lib/rubocop/cop/mixin/check_line_breakable.rb +5 -1
  217. data/lib/rubocop/cop/mixin/code_length.rb +1 -1
  218. data/lib/rubocop/cop/mixin/comments_help.rb +29 -7
  219. data/lib/rubocop/cop/mixin/configurable_enforced_style.rb +21 -9
  220. data/lib/rubocop/cop/mixin/def_node.rb +2 -7
  221. data/lib/rubocop/cop/mixin/documentation_comment.rb +1 -1
  222. data/lib/rubocop/cop/mixin/enforce_superclass.rb +2 -1
  223. data/lib/rubocop/cop/mixin/first_element_line_break.rb +11 -7
  224. data/lib/rubocop/cop/mixin/frozen_string_literal.rb +4 -0
  225. data/lib/rubocop/cop/mixin/hash_alignment_styles.rb +1 -1
  226. data/lib/rubocop/cop/mixin/hash_shorthand_syntax.rb +152 -12
  227. data/lib/rubocop/cop/mixin/hash_transform_method.rb +13 -9
  228. data/lib/rubocop/cop/mixin/line_length_help.rb +11 -2
  229. data/lib/rubocop/cop/mixin/method_complexity.rb +13 -16
  230. data/lib/rubocop/cop/mixin/min_branches_count.rb +40 -0
  231. data/lib/rubocop/cop/mixin/multiline_element_indentation.rb +7 -14
  232. data/lib/rubocop/cop/mixin/multiline_element_line_breaks.rb +5 -6
  233. data/lib/rubocop/cop/mixin/ordered_gem_node.rb +1 -1
  234. data/lib/rubocop/cop/mixin/percent_array.rb +58 -1
  235. data/lib/rubocop/cop/mixin/preceding_following_alignment.rb +1 -1
  236. data/lib/rubocop/cop/mixin/range_help.rb +22 -5
  237. data/lib/rubocop/cop/mixin/require_library.rb +2 -0
  238. data/lib/rubocop/cop/mixin/rescue_node.rb +5 -3
  239. data/lib/rubocop/cop/mixin/space_after_punctuation.rb +1 -1
  240. data/lib/rubocop/cop/mixin/statement_modifier.rb +18 -3
  241. data/lib/rubocop/cop/mixin/surrounding_space.rb +13 -11
  242. data/lib/rubocop/cop/mixin/trailing_comma.rb +2 -2
  243. data/lib/rubocop/cop/mixin/visibility_help.rb +40 -5
  244. data/lib/rubocop/cop/naming/ascii_identifiers.rb +1 -1
  245. data/lib/rubocop/cop/naming/block_forwarding.rb +5 -1
  246. data/lib/rubocop/cop/naming/block_parameter_name.rb +1 -1
  247. data/lib/rubocop/cop/naming/class_and_module_camel_case.rb +3 -1
  248. data/lib/rubocop/cop/naming/constant_name.rb +3 -3
  249. data/lib/rubocop/cop/naming/heredoc_delimiter_case.rb +1 -1
  250. data/lib/rubocop/cop/naming/inclusive_language.rb +28 -6
  251. data/lib/rubocop/cop/naming/memoized_instance_variable_name.rb +22 -7
  252. data/lib/rubocop/cop/naming/method_name.rb +3 -3
  253. data/lib/rubocop/cop/naming/predicate_name.rb +31 -2
  254. data/lib/rubocop/cop/naming/rescued_exceptions_variable_name.rb +12 -4
  255. data/lib/rubocop/cop/naming/variable_name.rb +6 -1
  256. data/lib/rubocop/cop/registry.rb +73 -45
  257. data/lib/rubocop/cop/security/compound_hash.rb +2 -1
  258. data/lib/rubocop/cop/style/access_modifier_declarations.rb +92 -3
  259. data/lib/rubocop/cop/style/accessor_grouping.rb +50 -20
  260. data/lib/rubocop/cop/style/alias.rb +9 -1
  261. data/lib/rubocop/cop/style/arguments_forwarding.rb +6 -5
  262. data/lib/rubocop/cop/style/array_intersect.rb +111 -0
  263. data/lib/rubocop/cop/style/ascii_comments.rb +1 -1
  264. data/lib/rubocop/cop/style/attr.rb +11 -1
  265. data/lib/rubocop/cop/style/begin_block.rb +1 -2
  266. data/lib/rubocop/cop/style/bisected_attr_accessor.rb +1 -1
  267. data/lib/rubocop/cop/style/block_comments.rb +2 -2
  268. data/lib/rubocop/cop/style/block_delimiters.rb +44 -10
  269. data/lib/rubocop/cop/style/case_equality.rb +40 -10
  270. data/lib/rubocop/cop/style/case_like_if.rb +20 -3
  271. data/lib/rubocop/cop/style/character_literal.rb +1 -1
  272. data/lib/rubocop/cop/style/class_and_module_children.rb +9 -16
  273. data/lib/rubocop/cop/style/class_equality_comparison.rb +72 -12
  274. data/lib/rubocop/cop/style/class_methods_definitions.rb +2 -1
  275. data/lib/rubocop/cop/style/collection_compact.rb +27 -5
  276. data/lib/rubocop/cop/style/collection_methods.rb +2 -0
  277. data/lib/rubocop/cop/style/colon_method_call.rb +2 -2
  278. data/lib/rubocop/cop/style/combinable_loops.rb +29 -7
  279. data/lib/rubocop/cop/style/command_literal.rb +1 -1
  280. data/lib/rubocop/cop/style/comment_annotation.rb +1 -1
  281. data/lib/rubocop/cop/style/commented_keyword.rb +2 -2
  282. data/lib/rubocop/cop/style/comparable_clamp.rb +125 -0
  283. data/lib/rubocop/cop/style/concat_array_literals.rb +94 -0
  284. data/lib/rubocop/cop/style/conditional_assignment.rb +8 -14
  285. data/lib/rubocop/cop/style/copyright.rb +6 -3
  286. data/lib/rubocop/cop/style/data_inheritance.rb +75 -0
  287. data/lib/rubocop/cop/style/dir.rb +1 -1
  288. data/lib/rubocop/cop/style/dir_empty.rb +54 -0
  289. data/lib/rubocop/cop/style/disable_cops_within_source_code_directive.rb +2 -2
  290. data/lib/rubocop/cop/style/document_dynamic_eval_definition.rb +2 -2
  291. data/lib/rubocop/cop/style/documentation.rb +22 -10
  292. data/lib/rubocop/cop/style/documentation_method.rb +10 -4
  293. data/lib/rubocop/cop/style/double_negation.rb +4 -2
  294. data/lib/rubocop/cop/style/each_for_simple_loop.rb +41 -6
  295. data/lib/rubocop/cop/style/each_with_object.rb +40 -9
  296. data/lib/rubocop/cop/style/empty_block_parameter.rb +2 -2
  297. data/lib/rubocop/cop/style/empty_else.rb +37 -0
  298. data/lib/rubocop/cop/style/empty_heredoc.rb +73 -0
  299. data/lib/rubocop/cop/style/empty_lambda_parameter.rb +2 -2
  300. data/lib/rubocop/cop/style/empty_method.rb +1 -1
  301. data/lib/rubocop/cop/style/endless_method.rb +1 -1
  302. data/lib/rubocop/cop/style/eval_with_location.rb +8 -8
  303. data/lib/rubocop/cop/style/exact_regexp_match.rb +68 -0
  304. data/lib/rubocop/cop/style/explicit_block_argument.rb +5 -1
  305. data/lib/rubocop/cop/style/fetch_env_var.rb +10 -177
  306. data/lib/rubocop/cop/style/file_empty.rb +71 -0
  307. data/lib/rubocop/cop/style/file_read.rb +3 -3
  308. data/lib/rubocop/cop/style/file_write.rb +1 -1
  309. data/lib/rubocop/cop/style/for.rb +2 -0
  310. data/lib/rubocop/cop/style/format_string_token.rb +25 -6
  311. data/lib/rubocop/cop/style/frozen_string_literal_comment.rb +1 -1
  312. data/lib/rubocop/cop/style/guard_clause.rb +127 -38
  313. data/lib/rubocop/cop/style/hash_as_last_array_item.rb +1 -0
  314. data/lib/rubocop/cop/style/hash_each_methods.rb +36 -21
  315. data/lib/rubocop/cop/style/hash_except.rb +27 -16
  316. data/lib/rubocop/cop/style/hash_like_case.rb +3 -9
  317. data/lib/rubocop/cop/style/hash_syntax.rb +26 -2
  318. data/lib/rubocop/cop/style/hash_transform_keys.rb +2 -2
  319. data/lib/rubocop/cop/style/hash_transform_values.rb +2 -2
  320. data/lib/rubocop/cop/style/identical_conditional_branches.rb +15 -0
  321. data/lib/rubocop/cop/style/if_inside_else.rb +6 -0
  322. data/lib/rubocop/cop/style/if_unless_modifier.rb +112 -16
  323. data/lib/rubocop/cop/style/if_with_boolean_literal_branches.rb +29 -2
  324. data/lib/rubocop/cop/style/if_with_semicolon.rb +4 -4
  325. data/lib/rubocop/cop/style/infinite_loop.rb +2 -5
  326. data/lib/rubocop/cop/style/inverse_methods.rb +15 -11
  327. data/lib/rubocop/cop/style/invertible_unless_condition.rb +118 -0
  328. data/lib/rubocop/cop/style/line_end_concatenation.rb +4 -1
  329. data/lib/rubocop/cop/style/magic_comment_format.rb +307 -0
  330. data/lib/rubocop/cop/style/map_compact_with_conditional_block.rb +2 -2
  331. data/lib/rubocop/cop/style/map_to_hash.rb +4 -1
  332. data/lib/rubocop/cop/style/map_to_set.rb +64 -0
  333. data/lib/rubocop/cop/style/method_call_with_args_parentheses/omit_parentheses.rb +41 -26
  334. data/lib/rubocop/cop/style/method_call_with_args_parentheses/require_parentheses.rb +5 -1
  335. data/lib/rubocop/cop/style/method_call_with_args_parentheses.rb +48 -41
  336. data/lib/rubocop/cop/style/method_call_without_args_parentheses.rb +21 -2
  337. data/lib/rubocop/cop/style/method_called_on_do_end_block.rb +4 -1
  338. data/lib/rubocop/cop/style/method_def_parentheses.rb +11 -4
  339. data/lib/rubocop/cop/style/min_max.rb +3 -3
  340. data/lib/rubocop/cop/style/min_max_comparison.rb +83 -0
  341. data/lib/rubocop/cop/style/missing_else.rb +13 -1
  342. data/lib/rubocop/cop/style/mixin_grouping.rb +4 -4
  343. data/lib/rubocop/cop/style/module_function.rb +30 -8
  344. data/lib/rubocop/cop/style/multiline_block_chain.rb +3 -1
  345. data/lib/rubocop/cop/style/multiline_if_modifier.rb +0 -4
  346. data/lib/rubocop/cop/style/multiline_in_pattern_then.rb +1 -1
  347. data/lib/rubocop/cop/style/multiline_memoization.rb +2 -2
  348. data/lib/rubocop/cop/style/multiline_method_signature.rb +7 -4
  349. data/lib/rubocop/cop/style/multiline_ternary_operator.rb +18 -3
  350. data/lib/rubocop/cop/style/multiple_comparison.rb +14 -0
  351. data/lib/rubocop/cop/style/negated_if_else_condition.rb +17 -10
  352. data/lib/rubocop/cop/style/nested_parenthesized_calls.rb +9 -0
  353. data/lib/rubocop/cop/style/next.rb +3 -5
  354. data/lib/rubocop/cop/style/nil_lambda.rb +4 -4
  355. data/lib/rubocop/cop/style/numbered_parameters_limit.rb +11 -3
  356. data/lib/rubocop/cop/style/numeric_literals.rb +16 -1
  357. data/lib/rubocop/cop/style/numeric_predicate.rb +43 -9
  358. data/lib/rubocop/cop/style/object_then.rb +5 -0
  359. data/lib/rubocop/cop/style/one_line_conditional.rb +3 -6
  360. data/lib/rubocop/cop/style/operator_method_call.rb +67 -0
  361. data/lib/rubocop/cop/style/parallel_assignment.rb +29 -19
  362. data/lib/rubocop/cop/style/percent_literal_delimiters.rb +2 -3
  363. data/lib/rubocop/cop/style/percent_q_literals.rb +1 -1
  364. data/lib/rubocop/cop/style/perl_backrefs.rb +22 -1
  365. data/lib/rubocop/cop/style/proc.rb +4 -1
  366. data/lib/rubocop/cop/style/quoted_symbols.rb +1 -1
  367. data/lib/rubocop/cop/style/redundant_argument.rb +3 -0
  368. data/lib/rubocop/cop/style/redundant_array_constructor.rb +77 -0
  369. data/lib/rubocop/cop/style/redundant_begin.rb +3 -0
  370. data/lib/rubocop/cop/style/redundant_condition.rb +41 -8
  371. data/lib/rubocop/cop/style/redundant_conditional.rb +0 -4
  372. data/lib/rubocop/cop/style/redundant_constant_base.rb +85 -0
  373. data/lib/rubocop/cop/style/redundant_double_splat_hash_braces.rb +45 -0
  374. data/lib/rubocop/cop/style/redundant_each.rb +116 -0
  375. data/lib/rubocop/cop/style/redundant_fetch_block.rb +7 -5
  376. data/lib/rubocop/cop/style/redundant_filter_chain.rb +101 -0
  377. data/lib/rubocop/cop/style/redundant_heredoc_delimiter_quotes.rb +58 -0
  378. data/lib/rubocop/cop/style/redundant_initialize.rb +3 -1
  379. data/lib/rubocop/cop/style/redundant_interpolation.rb +2 -2
  380. data/lib/rubocop/cop/style/redundant_line_continuation.rb +183 -0
  381. data/lib/rubocop/cop/style/redundant_parentheses.rb +22 -24
  382. data/lib/rubocop/cop/style/redundant_percent_q.rb +1 -1
  383. data/lib/rubocop/cop/style/redundant_regexp_character_class.rb +9 -3
  384. data/lib/rubocop/cop/style/redundant_regexp_constructor.rb +46 -0
  385. data/lib/rubocop/cop/style/redundant_regexp_escape.rb +21 -4
  386. data/lib/rubocop/cop/style/redundant_return.rb +7 -0
  387. data/lib/rubocop/cop/style/redundant_self.rb +2 -0
  388. data/lib/rubocop/cop/style/redundant_sort.rb +24 -9
  389. data/lib/rubocop/cop/style/redundant_sort_by.rb +24 -8
  390. data/lib/rubocop/cop/style/redundant_string_escape.rb +183 -0
  391. data/lib/rubocop/cop/style/regexp_literal.rb +11 -2
  392. data/lib/rubocop/cop/style/require_order.rb +139 -0
  393. data/lib/rubocop/cop/style/rescue_modifier.rb +2 -4
  394. data/lib/rubocop/cop/style/rescue_standard_error.rb +2 -2
  395. data/lib/rubocop/cop/style/safe_navigation.rb +41 -10
  396. data/lib/rubocop/cop/style/select_by_regexp.rb +23 -5
  397. data/lib/rubocop/cop/style/self_assignment.rb +2 -2
  398. data/lib/rubocop/cop/style/semicolon.rb +63 -5
  399. data/lib/rubocop/cop/style/signal_exception.rb +8 -6
  400. data/lib/rubocop/cop/style/single_line_block_params.rb +1 -1
  401. data/lib/rubocop/cop/style/single_line_methods.rb +1 -1
  402. data/lib/rubocop/cop/style/slicing_with_range.rb +1 -1
  403. data/lib/rubocop/cop/style/sole_nested_conditional.rb +20 -9
  404. data/lib/rubocop/cop/style/special_global_vars.rb +3 -4
  405. data/lib/rubocop/cop/style/static_class.rb +32 -1
  406. data/lib/rubocop/cop/style/stderr_puts.rb +1 -1
  407. data/lib/rubocop/cop/style/string_hash_keys.rb +4 -1
  408. data/lib/rubocop/cop/style/string_literals.rb +1 -5
  409. data/lib/rubocop/cop/style/struct_inheritance.rb +1 -1
  410. data/lib/rubocop/cop/style/symbol_array.rb +6 -5
  411. data/lib/rubocop/cop/style/symbol_proc.rb +42 -10
  412. data/lib/rubocop/cop/style/ternary_parentheses.rb +1 -13
  413. data/lib/rubocop/cop/style/top_level_method_definition.rb +3 -1
  414. data/lib/rubocop/cop/style/trailing_body_on_class.rb +1 -0
  415. data/lib/rubocop/cop/style/trailing_comma_in_arguments.rb +4 -4
  416. data/lib/rubocop/cop/style/trailing_comma_in_block_args.rb +1 -1
  417. data/lib/rubocop/cop/style/trailing_underscore_variable.rb +1 -1
  418. data/lib/rubocop/cop/style/trivial_accessors.rb +4 -1
  419. data/lib/rubocop/cop/style/unless_logical_operators.rb +1 -0
  420. data/lib/rubocop/cop/style/unpack_first.rb +3 -3
  421. data/lib/rubocop/cop/style/word_array.rb +59 -5
  422. data/lib/rubocop/cop/style/yoda_condition.rb +13 -6
  423. data/lib/rubocop/cop/style/yoda_expression.rb +90 -0
  424. data/lib/rubocop/cop/style/zero_length_predicate.rb +40 -19
  425. data/lib/rubocop/cop/team.rb +63 -56
  426. data/lib/rubocop/cop/util.rb +44 -8
  427. data/lib/rubocop/cop/variable_force/assignment.rb +34 -2
  428. data/lib/rubocop/cop/variable_force/scope.rb +3 -3
  429. data/lib/rubocop/cop/variable_force/variable.rb +5 -3
  430. data/lib/rubocop/cop/variable_force/variable_table.rb +6 -4
  431. data/lib/rubocop/cop/variable_force.rb +19 -30
  432. data/lib/rubocop/cops_documentation_generator.rb +45 -15
  433. data/lib/rubocop/directive_comment.rb +4 -4
  434. data/lib/rubocop/ext/comment.rb +18 -0
  435. data/lib/rubocop/ext/processed_source.rb +2 -0
  436. data/lib/rubocop/ext/range.rb +15 -0
  437. data/lib/rubocop/ext/regexp_node.rb +1 -1
  438. data/lib/rubocop/ext/regexp_parser.rb +1 -1
  439. data/lib/rubocop/feature_loader.rb +94 -0
  440. data/lib/rubocop/file_patterns.rb +43 -0
  441. data/lib/rubocop/formatter/clang_style_formatter.rb +1 -1
  442. data/lib/rubocop/formatter/disabled_config_formatter.rb +26 -9
  443. data/lib/rubocop/formatter/html_formatter.rb +4 -4
  444. data/lib/rubocop/formatter/junit_formatter.rb +4 -1
  445. data/lib/rubocop/formatter/markdown_formatter.rb +1 -1
  446. data/lib/rubocop/formatter/offense_count_formatter.rb +8 -5
  447. data/lib/rubocop/formatter/simple_text_formatter.rb +1 -1
  448. data/lib/rubocop/formatter/tap_formatter.rb +1 -1
  449. data/lib/rubocop/formatter/worst_offenders_formatter.rb +6 -3
  450. data/lib/rubocop/formatter.rb +4 -1
  451. data/lib/rubocop/options.rb +55 -22
  452. data/lib/rubocop/path_util.rb +50 -22
  453. data/lib/rubocop/rake_task.rb +5 -1
  454. data/lib/rubocop/result_cache.rb +26 -24
  455. data/lib/rubocop/rspec/cop_helper.rb +26 -3
  456. data/lib/rubocop/rspec/expect_offense.rb +6 -4
  457. data/lib/rubocop/rspec/shared_contexts.rb +31 -14
  458. data/lib/rubocop/rspec/support.rb +17 -2
  459. data/lib/rubocop/runner.rb +73 -18
  460. data/lib/rubocop/server/cache.rb +48 -2
  461. data/lib/rubocop/server/cli.rb +62 -19
  462. data/lib/rubocop/server/client_command/base.rb +1 -1
  463. data/lib/rubocop/server/client_command/exec.rb +8 -2
  464. data/lib/rubocop/server/client_command/start.rb +6 -1
  465. data/lib/rubocop/server/core.rb +42 -10
  466. data/lib/rubocop/server/helper.rb +1 -1
  467. data/lib/rubocop/server/server_command/exec.rb +1 -1
  468. data/lib/rubocop/server/socket_reader.rb +5 -1
  469. data/lib/rubocop/server.rb +1 -1
  470. data/lib/rubocop/target_finder.rb +1 -1
  471. data/lib/rubocop/target_ruby.rb +5 -5
  472. data/lib/rubocop/version.rb +17 -7
  473. data/lib/rubocop.rb +49 -9
  474. metadata +65 -36
  475. data/lib/rubocop/cop/mixin/ignored_methods.rb +0 -52
@@ -9,6 +9,11 @@ module RuboCop
9
9
  # Applications of visibility methods to symbols can be controlled
10
10
  # using AllowModifiersOnSymbols config.
11
11
  #
12
+ # @safety
13
+ # Autocorrection is not safe, because the visibility of dynamically
14
+ # defined methods can vary depending on the state determined by
15
+ # the group access modifier.
16
+ #
12
17
  # @example EnforcedStyle: group (default)
13
18
  # # bad
14
19
  # class Foo
@@ -63,7 +68,10 @@ module RuboCop
63
68
  #
64
69
  # end
65
70
  class AccessModifierDeclarations < Base
71
+ extend AutoCorrector
72
+
66
73
  include ConfigurableEnforcedStyle
74
+ include RangeHelp
67
75
 
68
76
  GROUP_STYLE_MESSAGE = [
69
77
  '`%<access_modifier>s` should not be',
@@ -77,6 +85,8 @@ module RuboCop
77
85
 
78
86
  RESTRICT_ON_SEND = %i[private protected public module_function].freeze
79
87
 
88
+ ALLOWED_NODE_TYPES = %i[pair block].freeze
89
+
80
90
  # @!method access_modifier_with_symbol?(node)
81
91
  def_node_matcher :access_modifier_with_symbol?, <<~PATTERN
82
92
  (send nil? {:private :protected :public :module_function} (sym _))
@@ -84,11 +94,14 @@ module RuboCop
84
94
 
85
95
  def on_send(node)
86
96
  return unless node.access_modifier?
87
- return if node.parent&.pair_type?
97
+ return if ALLOWED_NODE_TYPES.include?(node.parent&.type)
88
98
  return if allow_modifiers_on_symbols?(node)
89
99
 
90
100
  if offense?(node)
91
- add_offense(node.loc.selector) { opposite_style_detected }
101
+ add_offense(node.loc.selector) do |corrector|
102
+ autocorrect(corrector, node)
103
+ end
104
+ opposite_style_detected
92
105
  else
93
106
  correct_style_detected
94
107
  end
@@ -96,12 +109,28 @@ module RuboCop
96
109
 
97
110
  private
98
111
 
112
+ def autocorrect(corrector, node)
113
+ case style
114
+ when :group
115
+ def_node = find_corresponding_def_node(node)
116
+ return unless def_node
117
+
118
+ replace_def(corrector, node, def_node)
119
+ when :inline
120
+ remove_node(corrector, node)
121
+ select_grouped_def_nodes(node).each do |grouped_def_node|
122
+ insert_inline_modifier(corrector, grouped_def_node, node.method_name)
123
+ end
124
+ end
125
+ end
126
+
99
127
  def allow_modifiers_on_symbols?(node)
100
128
  cop_config['AllowModifiersOnSymbols'] && access_modifier_with_symbol?(node)
101
129
  end
102
130
 
103
131
  def offense?(node)
104
- (group_style? && access_modifier_is_inlined?(node)) ||
132
+ (group_style? && access_modifier_is_inlined?(node) &&
133
+ !right_siblings_same_inline_method?(node)) ||
105
134
  (inline_style? && access_modifier_is_not_inlined?(node))
106
135
  end
107
136
 
@@ -121,6 +150,12 @@ module RuboCop
121
150
  !access_modifier_is_inlined?(node)
122
151
  end
123
152
 
153
+ def right_siblings_same_inline_method?(node)
154
+ node.right_siblings.any? do |sibling|
155
+ sibling.send_type? && sibling.method?(node.method_name) && !sibling.arguments.empty?
156
+ end
157
+ end
158
+
124
159
  def message(range)
125
160
  access_modifier = range.source
126
161
 
@@ -130,6 +165,60 @@ module RuboCop
130
165
  format(INLINE_STYLE_MESSAGE, access_modifier: access_modifier)
131
166
  end
132
167
  end
168
+
169
+ def find_corresponding_def_node(node)
170
+ if access_modifier_with_symbol?(node)
171
+ method_name = node.arguments.first.value
172
+ node.parent.each_child_node(:def).find do |child|
173
+ child.method?(method_name)
174
+ end
175
+ else
176
+ node.arguments.first
177
+ end
178
+ end
179
+
180
+ def find_argument_less_modifier_node(node)
181
+ return unless (parent = node.parent)
182
+
183
+ parent.each_child_node(:send).find do |child|
184
+ child.method?(node.method_name) && child.arguments.empty?
185
+ end
186
+ end
187
+
188
+ def select_grouped_def_nodes(node)
189
+ node.right_siblings.take_while do |sibling|
190
+ !(sibling.send_type? && sibling.bare_access_modifier_declaration?)
191
+ end.select(&:def_type?)
192
+ end
193
+
194
+ def replace_def(corrector, node, def_node)
195
+ source = def_source(node, def_node)
196
+ argument_less_modifier_node = find_argument_less_modifier_node(node)
197
+ if argument_less_modifier_node
198
+ corrector.insert_after(argument_less_modifier_node, "\n\n#{source}")
199
+ elsif (ancestor = node.each_ancestor(:block, :class, :module).first)
200
+
201
+ corrector.insert_before(ancestor.loc.end, "#{node.method_name}\n\n#{source}\n")
202
+ else
203
+ corrector.replace(node, "#{node.method_name}\n\n#{source}")
204
+ return
205
+ end
206
+
207
+ remove_node(corrector, def_node)
208
+ remove_node(corrector, node)
209
+ end
210
+
211
+ def insert_inline_modifier(corrector, node, modifier_name)
212
+ corrector.insert_before(node, "#{modifier_name} ")
213
+ end
214
+
215
+ def remove_node(corrector, node)
216
+ corrector.remove(range_with_comments_and_lines(node))
217
+ end
218
+
219
+ def def_source(node, def_node)
220
+ [*processed_source.ast_with_comments[node].map(&:text), def_node.source].join("\n")
221
+ end
133
222
  end
134
223
  end
135
224
  end
@@ -7,19 +7,32 @@ module RuboCop
7
7
  # By default it enforces accessors to be placed in grouped declarations,
8
8
  # but it can be configured to enforce separating them in multiple declarations.
9
9
  #
10
- # NOTE: `Sorbet` is not compatible with "grouped" style. Consider "separated" style
11
- # or disabling this cop.
10
+ # NOTE: If there is a method call before the accessor method it is always allowed
11
+ # as it might be intended like Sorbet.
12
12
  #
13
13
  # @example EnforcedStyle: grouped (default)
14
14
  # # bad
15
15
  # class Foo
16
16
  # attr_reader :bar
17
+ # attr_reader :bax
17
18
  # attr_reader :baz
18
19
  # end
19
20
  #
20
21
  # # good
21
22
  # class Foo
22
- # attr_reader :bar, :baz
23
+ # attr_reader :bar, :bax, :baz
24
+ # end
25
+ #
26
+ # # good
27
+ # class Foo
28
+ # # may be intended comment for bar.
29
+ # attr_reader :bar
30
+ #
31
+ # sig { returns(String) }
32
+ # attr_reader :bax
33
+ #
34
+ # may_be_intended_annotation :baz
35
+ # attr_reader :baz
23
36
  # end
24
37
  #
25
38
  # @example EnforcedStyle: separated
@@ -43,11 +56,9 @@ module RuboCop
43
56
  GROUPED_MSG = 'Group together all `%<accessor>s` attributes.'
44
57
  SEPARATED_MSG = 'Use one attribute per `%<accessor>s`.'
45
58
 
46
- ACCESSOR_METHODS = %i[attr_reader attr_writer attr_accessor attr].freeze
47
-
48
59
  def on_class(node)
49
60
  class_send_elements(node).each do |macro|
50
- next unless accessor?(macro)
61
+ next unless macro.attribute_accessor?
51
62
 
52
63
  check(macro)
53
64
  end
@@ -58,8 +69,8 @@ module RuboCop
58
69
  private
59
70
 
60
71
  def check(send_node)
61
- return if previous_line_comment?(send_node)
62
- return unless (grouped_style? && sibling_accessors(send_node).size > 1) ||
72
+ return if previous_line_comment?(send_node) || !groupable_accessor?(send_node)
73
+ return unless (grouped_style? && groupable_sibling_accessors(send_node).size > 1) ||
63
74
  (separated_style? && send_node.arguments.size > 1)
64
75
 
65
76
  message = message(send_node)
@@ -72,7 +83,7 @@ module RuboCop
72
83
  if (preferred_accessors = preferred_accessors(node))
73
84
  corrector.replace(node, preferred_accessors)
74
85
  else
75
- range = range_with_surrounding_space(node.loc.expression, side: :left)
86
+ range = range_with_surrounding_space(node.source_range, side: :left)
76
87
  corrector.remove(range)
77
88
  end
78
89
  end
@@ -81,6 +92,25 @@ module RuboCop
81
92
  comment_line?(processed_source[node.first_line - 2])
82
93
  end
83
94
 
95
+ # rubocop:disable Metrics/CyclomaticComplexity
96
+ def groupable_accessor?(node)
97
+ return true unless (previous_expression = node.left_siblings.last)
98
+
99
+ # Accessors with Sorbet `sig { ... }` blocks shouldn't be groupable.
100
+ if previous_expression.block_type?
101
+ previous_expression.child_nodes.each do |child_node|
102
+ break previous_expression = child_node if child_node.send_type?
103
+ end
104
+ end
105
+
106
+ return true unless previous_expression.send_type?
107
+
108
+ previous_expression.attribute_accessor? ||
109
+ previous_expression.access_modifier? ||
110
+ node.first_line - previous_expression.last_line > 1 # there is a space between nodes
111
+ end
112
+ # rubocop:enable Metrics/CyclomaticComplexity
113
+
84
114
  def class_send_elements(class_node)
85
115
  class_def = class_node.body
86
116
 
@@ -93,10 +123,6 @@ module RuboCop
93
123
  end
94
124
  end
95
125
 
96
- def accessor?(send_node)
97
- send_node.macro? && ACCESSOR_METHODS.include?(send_node.method_name)
98
- end
99
-
100
126
  def grouped_style?
101
127
  style == :grouped
102
128
  end
@@ -105,12 +131,12 @@ module RuboCop
105
131
  style == :separated
106
132
  end
107
133
 
108
- def sibling_accessors(send_node)
134
+ def groupable_sibling_accessors(send_node)
109
135
  send_node.parent.each_child_node(:send).select do |sibling|
110
- accessor?(sibling) &&
136
+ sibling.attribute_accessor? &&
111
137
  sibling.method?(send_node.method_name) &&
112
138
  node_visibility(sibling) == node_visibility(send_node) &&
113
- !previous_line_comment?(sibling)
139
+ groupable_accessor?(sibling) && !previous_line_comment?(sibling)
114
140
  end
115
141
  end
116
142
 
@@ -121,7 +147,7 @@ module RuboCop
121
147
 
122
148
  def preferred_accessors(node)
123
149
  if grouped_style?
124
- accessors = sibling_accessors(node)
150
+ accessors = groupable_sibling_accessors(node)
125
151
  group_accessors(node, accessors) if node.loc == accessors.first.loc
126
152
  else
127
153
  separate_accessors(node)
@@ -135,12 +161,16 @@ module RuboCop
135
161
  end
136
162
 
137
163
  def separate_accessors(node)
138
- node.arguments.map do |arg|
139
- if arg == node.arguments.first
164
+ node.arguments.flat_map do |arg|
165
+ lines = [
166
+ *processed_source.ast_with_comments[arg].map(&:text),
140
167
  "#{node.method_name} #{arg.source}"
168
+ ]
169
+ if arg == node.arguments.first
170
+ lines
141
171
  else
142
172
  indent = ' ' * node.loc.column
143
- "#{indent}#{node.method_name} #{arg.source}"
173
+ lines.map { |line| "#{indent}#{line}" }
144
174
  end
145
175
  end.join("\n")
146
176
  end
@@ -7,6 +7,11 @@ module RuboCop
7
7
  # depending on configuration.
8
8
  # It also flags uses of `alias :symbol` rather than `alias bareword`.
9
9
  #
10
+ # However, it will always enforce `method_alias` when used `alias`
11
+ # in an instance method definition and in a singleton method definition.
12
+ # If used in a block, always enforce `alias_method`
13
+ # unless it is an `instance_eval` block.
14
+ #
10
15
  # @example EnforcedStyle: prefer_alias (default)
11
16
  # # bad
12
17
  # alias_method :bar, :foo
@@ -22,6 +27,7 @@ module RuboCop
22
27
  #
23
28
  # # good
24
29
  # alias_method :bar, :foo
30
+ #
25
31
  class Alias < Base
26
32
  include ConfigurableEnforcedStyle
27
33
  extend AutoCorrector
@@ -71,7 +77,9 @@ module RuboCop
71
77
  end
72
78
 
73
79
  def alias_method_possible?(node)
74
- scope_type(node) != :instance_eval && node.children.none?(&:gvar_type?)
80
+ scope_type(node) != :instance_eval &&
81
+ node.children.none?(&:gvar_type?) &&
82
+ node&.parent&.type != :def
75
83
  end
76
84
 
77
85
  def add_offense_for_args(node, &block)
@@ -73,17 +73,18 @@ module RuboCop
73
73
  {
74
74
  (send _ _
75
75
  (splat (lvar %1))
76
- (block-pass (lvar %2)))
76
+ (block-pass {(lvar %2) nil?}))
77
77
  (send _ _
78
78
  (splat (lvar %1))
79
79
  (hash (kwsplat (lvar %3)))
80
- (block-pass (lvar %2)))
80
+ (block-pass {(lvar %2) nil?}))
81
81
  }
82
82
  PATTERN
83
83
 
84
84
  def on_def(node)
85
85
  return unless node.body
86
86
  return unless (rest_args_name, args = use_rest_arguments?(node.arguments))
87
+ return if args.any?(&:default?)
87
88
 
88
89
  node.each_descendant(:send) do |send_node|
89
90
  kwargs_name, block_name = extract_argument_names_from(args)
@@ -123,9 +124,9 @@ module RuboCop
123
124
 
124
125
  def register_offense_to_forwarding_method_arguments(forwarding_method)
125
126
  add_offense(arguments_range(forwarding_method)) do |corrector|
126
- range = range_between(
127
- forwarding_method.loc.selector.end_pos, forwarding_method.source_range.end_pos
128
- )
127
+ begin_pos = forwarding_method.loc.selector&.end_pos || forwarding_method.loc.dot.end_pos
128
+ range = range_between(begin_pos, forwarding_method.source_range.end_pos)
129
+
129
130
  corrector.replace(range, '(...)')
130
131
  end
131
132
  end
@@ -0,0 +1,111 @@
1
+ # frozen_string_literal: true
2
+
3
+ module RuboCop
4
+ module Cop
5
+ module Style
6
+ # In Ruby 3.1, `Array#intersect?` has been added.
7
+ #
8
+ # This cop identifies places where `(array1 & array2).any?`
9
+ # can be replaced by `array1.intersect?(array2)`.
10
+ #
11
+ # The `array1.intersect?(array2)` method is faster than
12
+ # `(array1 & array2).any?` and is more readable.
13
+ #
14
+ # @safety
15
+ # This cop cannot guarantee that `array1` and `array2` are
16
+ # actually arrays while method `intersect?` is for arrays only.
17
+ #
18
+ # @example
19
+ # # bad
20
+ # (array1 & array2).any?
21
+ # (array1 & array2).empty?
22
+ #
23
+ # # good
24
+ # array1.intersect?(array2)
25
+ # !array1.intersect?(array2)
26
+ #
27
+ # @example AllCops:ActiveSupportExtensionsEnabled: false (default)
28
+ # # good
29
+ # (array1 & array2).present?
30
+ # (array1 & array2).blank?
31
+ #
32
+ # @example AllCops:ActiveSupportExtensionsEnabled: true
33
+ # # bad
34
+ # (array1 & array2).present?
35
+ # (array1 & array2).blank?
36
+ #
37
+ # # good
38
+ # array1.intersect?(array2)
39
+ # !array1.intersect?(array2)
40
+ class ArrayIntersect < Base
41
+ extend AutoCorrector
42
+ extend TargetRubyVersion
43
+
44
+ minimum_target_ruby_version 3.1
45
+
46
+ # @!method regular_bad_intersection_check?(node)
47
+ def_node_matcher :regular_bad_intersection_check?, <<~PATTERN
48
+ (send
49
+ (begin
50
+ (send $(...) :& $(...))
51
+ ) ${:any? :empty?}
52
+ )
53
+ PATTERN
54
+
55
+ # @!method active_support_bad_intersection_check?(node)
56
+ def_node_matcher :active_support_bad_intersection_check?, <<~PATTERN
57
+ (send
58
+ (begin
59
+ (send $(...) :& $(...))
60
+ ) ${:present? :any? :blank? :empty?}
61
+ )
62
+ PATTERN
63
+
64
+ MSG = 'Use `%<negated>s%<receiver>s.intersect?(%<argument>s)` ' \
65
+ 'instead of `(%<receiver>s & %<argument>s).%<method_name>s`.'
66
+ STRAIGHT_METHODS = %i[present? any?].freeze
67
+ NEGATED_METHODS = %i[blank? empty?].freeze
68
+ RESTRICT_ON_SEND = (STRAIGHT_METHODS + NEGATED_METHODS).freeze
69
+
70
+ def on_send(node)
71
+ return unless (receiver, argument, method_name = bad_intersection_check?(node))
72
+
73
+ message = message(receiver.source, argument.source, method_name)
74
+
75
+ add_offense(node, message: message) do |corrector|
76
+ if straight?(method_name)
77
+ corrector.replace(node, "#{receiver.source}.intersect?(#{argument.source})")
78
+ else
79
+ corrector.replace(node, "!#{receiver.source}.intersect?(#{argument.source})")
80
+ end
81
+ end
82
+ end
83
+
84
+ private
85
+
86
+ def bad_intersection_check?(node)
87
+ if active_support_extensions_enabled?
88
+ active_support_bad_intersection_check?(node)
89
+ else
90
+ regular_bad_intersection_check?(node)
91
+ end
92
+ end
93
+
94
+ def straight?(method_name)
95
+ STRAIGHT_METHODS.include?(method_name.to_sym)
96
+ end
97
+
98
+ def message(receiver, argument, method_name)
99
+ negated = straight?(method_name) ? '' : '!'
100
+ format(
101
+ MSG,
102
+ negated: negated,
103
+ receiver: receiver,
104
+ argument: argument,
105
+ method_name: method_name
106
+ )
107
+ end
108
+ end
109
+ end
110
+ end
111
+ end
@@ -30,7 +30,7 @@ module RuboCop
30
30
  private
31
31
 
32
32
  def first_offense_range(comment)
33
- expression = comment.loc.expression
33
+ expression = comment.source_range
34
34
  first_offense = first_non_ascii_chars(comment.text)
35
35
 
36
36
  start_position = expression.begin_pos + comment.text.index(first_offense)
@@ -24,7 +24,7 @@ module RuboCop
24
24
  def on_send(node)
25
25
  return unless node.command?(:attr) && node.arguments?
26
26
  # check only for method definitions in class/module body
27
- return if node.parent && !node.parent.class_type? && !class_eval?(node.parent)
27
+ return if allowed_context?(node)
28
28
 
29
29
  message = message(node)
30
30
  add_offense(node.loc.selector, message: message) do |corrector|
@@ -34,6 +34,16 @@ module RuboCop
34
34
 
35
35
  private
36
36
 
37
+ def allowed_context?(node)
38
+ return false unless (class_node = node.each_ancestor(:class, :block).first)
39
+
40
+ (!class_node.class_type? && !class_eval?(class_node)) || define_attr_method?(class_node)
41
+ end
42
+
43
+ def define_attr_method?(node)
44
+ node.each_descendant(:def).any? { |def_node| def_node.method?(:attr) }
45
+ end
46
+
37
47
  def autocorrect(corrector, node)
38
48
  attr_name, setter = *node.arguments
39
49
 
@@ -3,8 +3,7 @@
3
3
  module RuboCop
4
4
  module Cop
5
5
  module Style
6
- #
7
- # This cop checks for BEGIN blocks.
6
+ # Checks for BEGIN blocks.
8
7
  #
9
8
  # @example
10
9
  # # bad
@@ -55,7 +55,7 @@ module RuboCop
55
55
  def after_class(class_node)
56
56
  @macros_to_rewrite[class_node].each do |macro|
57
57
  node = macro.node
58
- range = range_by_whole_lines(node.loc.expression, include_final_newline: true)
58
+ range = range_by_whole_lines(node.source_range, include_final_newline: true)
59
59
 
60
60
  correct(range) do |corrector|
61
61
  if macro.writer?
@@ -32,7 +32,7 @@ module RuboCop
32
32
  eq_begin, eq_end, contents = parts(comment)
33
33
 
34
34
  corrector.remove(eq_begin)
35
- unless contents.length.zero?
35
+ unless contents.empty?
36
36
  corrector.replace(
37
37
  contents,
38
38
  contents.source.gsub(/\A/, '# ').gsub(/\n\n/, "\n#\n").gsub(/\n(?=[^#])/, "\n# ")
@@ -46,7 +46,7 @@ module RuboCop
46
46
  private
47
47
 
48
48
  def parts(comment)
49
- expr = comment.loc.expression
49
+ expr = comment.source_range
50
50
  eq_begin = expr.resize(BEGIN_LENGTH)
51
51
  eq_end = eq_end_part(comment, expr)
52
52
  contents = range_between(eq_begin.end_pos, eq_end.begin_pos)
@@ -10,7 +10,7 @@ module RuboCop
10
10
  # Methods that can be either procedural or functional and cannot be
11
11
  # categorised from their usage alone is ignored.
12
12
  # `lambda`, `proc`, and `it` are their defaults.
13
- # Additional methods can be added to the `IgnoredMethods`.
13
+ # Additional methods can be added to the `AllowedMethods`.
14
14
  #
15
15
  # @example EnforcedStyle: line_count_based (default)
16
16
  # # bad - single line block
@@ -66,7 +66,7 @@ module RuboCop
66
66
  # x
67
67
  # }.inspect
68
68
  #
69
- # # The AllowBracesOnProceduralOneLiners option is ignored unless the
69
+ # # The AllowBracesOnProceduralOneLiners option is allowed unless the
70
70
  # # EnforcedStyle is set to `semantic`. If so:
71
71
  #
72
72
  # # If the AllowBracesOnProceduralOneLiners option is unspecified, or
@@ -116,7 +116,7 @@ module RuboCop
116
116
  #
117
117
  # # Methods listed in the BracesRequiredMethods list, such as 'sig'
118
118
  # # in this example, will require `{...}` braces. This option takes
119
- # # precedence over all other configurations except IgnoredMethods.
119
+ # # precedence over all other configurations except AllowedMethods.
120
120
  #
121
121
  # # bad
122
122
  # sig do
@@ -138,7 +138,7 @@ module RuboCop
138
138
  # puts foo
139
139
  # end
140
140
  #
141
- # @example IgnoredMethods: ['lambda', 'proc', 'it' ] (default)
141
+ # @example AllowedMethods: ['lambda', 'proc', 'it' ] (default)
142
142
  #
143
143
  # # good
144
144
  # foo = lambda do |x|
@@ -149,9 +149,26 @@ module RuboCop
149
149
  # x * 100
150
150
  # end
151
151
  #
152
+ # @example AllowedPatterns: [] (default)
153
+ #
154
+ # # bad
155
+ # things.map { |thing|
156
+ # something = thing.some_method
157
+ # process(something)
158
+ # }
159
+ #
160
+ # @example AllowedPatterns: ['map']
161
+ #
162
+ # # good
163
+ # things.map { |thing|
164
+ # something = thing.some_method
165
+ # process(something)
166
+ # }
167
+ #
152
168
  class BlockDelimiters < Base
153
169
  include ConfigurableEnforcedStyle
154
- include IgnoredMethods
170
+ include AllowedMethods
171
+ include AllowedPattern
155
172
  include RangeHelp
156
173
  extend AutoCorrector
157
174
 
@@ -282,8 +299,8 @@ module RuboCop
282
299
 
283
300
  def move_comment_before_block(corrector, comment, block_node, closing_brace)
284
301
  range = block_node.chained? ? end_of_chain(block_node.parent).source_range : closing_brace
285
- comment_range = range_between(range.end_pos, comment.loc.expression.end_pos)
286
- corrector.remove(range_with_surrounding_space(comment_range, side: :right))
302
+ corrector.remove(range_with_surrounding_space(comment.source_range, side: :right))
303
+ remove_trailing_whitespace(corrector, range, comment)
287
304
  corrector.insert_after(range, "\n")
288
305
 
289
306
  corrector.insert_before(block_node, "#{comment.text}\n")
@@ -296,6 +313,12 @@ module RuboCop
296
313
  end_of_chain(node.parent)
297
314
  end
298
315
 
316
+ def remove_trailing_whitespace(corrector, range, comment)
317
+ range_of_trailing = range.end.join(comment.source_range.begin)
318
+
319
+ corrector.remove(range_of_trailing) if range_of_trailing.source.match?(/\A\s+\z/)
320
+ end
321
+
299
322
  def with_block?(node)
300
323
  node.respond_to?(:block_node) && node.block_node
301
324
  end
@@ -319,6 +342,7 @@ module RuboCop
319
342
  end
320
343
 
321
344
  def proper_block_style?(node)
345
+ return true if require_braces?(node)
322
346
  return special_method_proper_block_style?(node) if special_method?(node.method_name)
323
347
 
324
348
  case style
@@ -329,13 +353,23 @@ module RuboCop
329
353
  end
330
354
  end
331
355
 
356
+ def require_braces?(node)
357
+ return false unless node.braces?
358
+
359
+ node.each_ancestor(:send).any? do |send|
360
+ send.arithmetic_operation? && node.source_range.end_pos < send.loc.selector.begin_pos
361
+ end
362
+ end
363
+
332
364
  def special_method?(method_name)
333
- ignored_method?(method_name) || braces_required_method?(method_name)
365
+ allowed_method?(method_name) ||
366
+ matches_allowed_pattern?(method_name) ||
367
+ braces_required_method?(method_name)
334
368
  end
335
369
 
336
370
  def special_method_proper_block_style?(node)
337
371
  method_name = node.method_name
338
- return true if ignored_method?(method_name)
372
+ return true if allowed_method?(method_name) || matches_allowed_pattern?(method_name)
339
373
  return node.braces? if braces_required_method?(method_name)
340
374
  end
341
375
 
@@ -406,7 +440,7 @@ module RuboCop
406
440
  if node.parent.begin_type?
407
441
  return_value_used?(node.parent)
408
442
  else
409
- node.parent.assignment? || node.parent.send_type?
443
+ node.parent.assignment? || node.parent.call_type?
410
444
  end
411
445
  end
412
446