rubocop 1.27.0 → 1.51.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (680) hide show
  1. checksums.yaml +4 -4
  2. data/LICENSE.txt +1 -1
  3. data/README.md +8 -6
  4. data/config/default.yml +462 -69
  5. data/config/obsoletion.yml +35 -2
  6. data/exe/rubocop +15 -7
  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} +27 -5
  11. data/lib/rubocop/cli/command/execute_runner.rb +15 -10
  12. data/lib/rubocop/cli/command/init_dotfile.rb +1 -1
  13. data/lib/rubocop/cli/command/show_cops.rb +1 -1
  14. data/lib/rubocop/cli/command/suggest_extensions.rb +62 -17
  15. data/lib/rubocop/cli.rb +57 -9
  16. data/lib/rubocop/comment_config.rb +60 -1
  17. data/lib/rubocop/config.rb +52 -20
  18. data/lib/rubocop/config_finder.rb +68 -0
  19. data/lib/rubocop/config_loader.rb +49 -69
  20. data/lib/rubocop/config_loader_resolver.rb +11 -12
  21. data/lib/rubocop/config_obsoletion/changed_parameter.rb +5 -0
  22. data/lib/rubocop/config_obsoletion/parameter_rule.rb +4 -0
  23. data/lib/rubocop/config_obsoletion.rb +9 -4
  24. data/lib/rubocop/config_validator.rb +22 -5
  25. data/lib/rubocop/cop/autocorrect_logic.rb +32 -14
  26. data/lib/rubocop/cop/badge.rb +10 -5
  27. data/lib/rubocop/cop/base.rb +119 -83
  28. data/lib/rubocop/cop/bundler/duplicated_gem.rb +2 -2
  29. data/lib/rubocop/cop/bundler/gem_comment.rb +2 -2
  30. data/lib/rubocop/cop/bundler/gem_filename.rb +5 -5
  31. data/lib/rubocop/cop/bundler/ordered_gems.rb +2 -2
  32. data/lib/rubocop/cop/commissioner.rb +19 -6
  33. data/lib/rubocop/cop/cop.rb +54 -34
  34. data/lib/rubocop/cop/corrector.rb +33 -13
  35. data/lib/rubocop/cop/correctors/alignment_corrector.rb +4 -4
  36. data/lib/rubocop/cop/correctors/condition_corrector.rb +1 -1
  37. data/lib/rubocop/cop/correctors/each_to_for_corrector.rb +4 -4
  38. data/lib/rubocop/cop/correctors/empty_line_corrector.rb +1 -1
  39. data/lib/rubocop/cop/correctors/for_to_each_corrector.rb +7 -5
  40. data/lib/rubocop/cop/correctors/if_then_corrector.rb +1 -1
  41. data/lib/rubocop/cop/correctors/lambda_literal_to_method_corrector.rb +1 -1
  42. data/lib/rubocop/cop/correctors/line_break_corrector.rb +8 -2
  43. data/lib/rubocop/cop/correctors/multiline_literal_brace_corrector.rb +26 -10
  44. data/lib/rubocop/cop/correctors/ordered_gem_corrector.rb +3 -8
  45. data/lib/rubocop/cop/correctors/parentheses_corrector.rb +59 -1
  46. data/lib/rubocop/cop/correctors/percent_literal_corrector.rb +3 -3
  47. data/lib/rubocop/cop/correctors/punctuation_corrector.rb +1 -1
  48. data/lib/rubocop/cop/correctors/space_corrector.rb +1 -1
  49. data/lib/rubocop/cop/correctors/string_literal_corrector.rb +1 -1
  50. data/lib/rubocop/cop/correctors/unused_arg_corrector.rb +2 -2
  51. data/lib/rubocop/cop/gemspec/dependency_version.rb +154 -0
  52. data/lib/rubocop/cop/gemspec/deprecated_attribute_assignment.rb +92 -0
  53. data/lib/rubocop/cop/gemspec/development_dependencies.rb +107 -0
  54. data/lib/rubocop/cop/gemspec/duplicated_assignment.rb +4 -7
  55. data/lib/rubocop/cop/gemspec/ordered_dependencies.rb +1 -1
  56. data/lib/rubocop/cop/gemspec/require_mfa.rb +21 -21
  57. data/lib/rubocop/cop/gemspec/ruby_version_globals_usage.rb +1 -1
  58. data/lib/rubocop/cop/generator/require_file_injector.rb +2 -2
  59. data/lib/rubocop/cop/generator.rb +6 -3
  60. data/lib/rubocop/cop/internal_affairs/cop_description.rb +98 -0
  61. data/lib/rubocop/cop/internal_affairs/create_empty_file.rb +37 -0
  62. data/lib/rubocop/cop/internal_affairs/empty_line_between_expect_offense_and_correction.rb +1 -1
  63. data/lib/rubocop/cop/internal_affairs/example_heredoc_delimiter.rb +111 -0
  64. data/lib/rubocop/cop/internal_affairs/inherit_deprecated_cop_class.rb +1 -1
  65. data/lib/rubocop/cop/internal_affairs/lambda_or_proc.rb +46 -0
  66. data/lib/rubocop/cop/internal_affairs/location_expression.rb +37 -0
  67. data/lib/rubocop/cop/internal_affairs/location_line_equality_comparison.rb +1 -1
  68. data/lib/rubocop/cop/internal_affairs/method_name_end_with.rb +80 -0
  69. data/lib/rubocop/cop/internal_affairs/node_matcher_directive.rb +3 -7
  70. data/lib/rubocop/cop/internal_affairs/node_type_predicate.rb +1 -1
  71. data/lib/rubocop/cop/internal_affairs/numblock_handler.rb +69 -0
  72. data/lib/rubocop/cop/internal_affairs/processed_source_buffer_name.rb +42 -0
  73. data/lib/rubocop/cop/internal_affairs/redundant_described_class_as_subject.rb +1 -1
  74. data/lib/rubocop/cop/internal_affairs/redundant_let_rubocop_config_new.rb +12 -4
  75. data/lib/rubocop/cop/internal_affairs/redundant_location_argument.rb +1 -1
  76. data/lib/rubocop/cop/internal_affairs/redundant_message_argument.rb +1 -1
  77. data/lib/rubocop/cop/internal_affairs/redundant_source_range.rb +66 -0
  78. data/lib/rubocop/cop/internal_affairs/single_line_comparison.rb +62 -0
  79. data/lib/rubocop/cop/internal_affairs/useless_restrict_on_send.rb +60 -0
  80. data/lib/rubocop/cop/internal_affairs.rb +11 -0
  81. data/lib/rubocop/cop/layout/argument_alignment.rb +22 -1
  82. data/lib/rubocop/cop/layout/array_alignment.rb +1 -1
  83. data/lib/rubocop/cop/layout/assignment_indentation.rb +1 -1
  84. data/lib/rubocop/cop/layout/begin_end_alignment.rb +1 -1
  85. data/lib/rubocop/cop/layout/block_alignment.rb +17 -13
  86. data/lib/rubocop/cop/layout/block_end_newline.rb +32 -10
  87. data/lib/rubocop/cop/layout/case_indentation.rb +17 -1
  88. data/lib/rubocop/cop/layout/class_structure.rb +37 -27
  89. data/lib/rubocop/cop/layout/closing_heredoc_indentation.rb +1 -1
  90. data/lib/rubocop/cop/layout/closing_parenthesis_indentation.rb +3 -7
  91. data/lib/rubocop/cop/layout/comment_indentation.rb +5 -3
  92. data/lib/rubocop/cop/layout/condition_position.rb +1 -1
  93. data/lib/rubocop/cop/layout/def_end_alignment.rb +1 -1
  94. data/lib/rubocop/cop/layout/dot_position.rb +1 -1
  95. data/lib/rubocop/cop/layout/else_alignment.rb +1 -1
  96. data/lib/rubocop/cop/layout/empty_comment.rb +4 -4
  97. data/lib/rubocop/cop/layout/empty_line_after_guard_clause.rb +1 -1
  98. data/lib/rubocop/cop/layout/empty_line_after_multiline_condition.rb +1 -1
  99. data/lib/rubocop/cop/layout/empty_line_between_defs.rb +2 -2
  100. data/lib/rubocop/cop/layout/empty_lines.rb +4 -2
  101. data/lib/rubocop/cop/layout/empty_lines_around_access_modifier.rb +7 -2
  102. data/lib/rubocop/cop/layout/empty_lines_around_arguments.rb +1 -1
  103. data/lib/rubocop/cop/layout/empty_lines_around_attribute_accessor.rb +25 -4
  104. data/lib/rubocop/cop/layout/empty_lines_around_begin_body.rb +1 -1
  105. data/lib/rubocop/cop/layout/empty_lines_around_block_body.rb +7 -5
  106. data/lib/rubocop/cop/layout/empty_lines_around_class_body.rb +10 -10
  107. data/lib/rubocop/cop/layout/empty_lines_around_exception_handling_keywords.rb +1 -1
  108. data/lib/rubocop/cop/layout/empty_lines_around_method_body.rb +1 -1
  109. data/lib/rubocop/cop/layout/empty_lines_around_module_body.rb +10 -10
  110. data/lib/rubocop/cop/layout/end_alignment.rb +10 -2
  111. data/lib/rubocop/cop/layout/end_of_line.rb +5 -5
  112. data/lib/rubocop/cop/layout/extra_spacing.rb +16 -7
  113. data/lib/rubocop/cop/layout/first_argument_indentation.rb +43 -32
  114. data/lib/rubocop/cop/layout/first_array_element_indentation.rb +21 -14
  115. data/lib/rubocop/cop/layout/first_array_element_line_break.rb +36 -9
  116. data/lib/rubocop/cop/layout/first_hash_element_indentation.rb +52 -13
  117. data/lib/rubocop/cop/layout/first_hash_element_line_break.rb +37 -2
  118. data/lib/rubocop/cop/layout/first_method_argument_line_break.rb +58 -9
  119. data/lib/rubocop/cop/layout/first_method_parameter_line_break.rb +53 -20
  120. data/lib/rubocop/cop/layout/first_parameter_indentation.rb +1 -1
  121. data/lib/rubocop/cop/layout/hash_alignment.rb +2 -0
  122. data/lib/rubocop/cop/layout/heredoc_argument_closing_parenthesis.rb +11 -5
  123. data/lib/rubocop/cop/layout/heredoc_indentation.rb +9 -12
  124. data/lib/rubocop/cop/layout/indentation_consistency.rb +1 -1
  125. data/lib/rubocop/cop/layout/indentation_style.rb +8 -3
  126. data/lib/rubocop/cop/layout/indentation_width.rb +16 -9
  127. data/lib/rubocop/cop/layout/initial_indentation.rb +3 -3
  128. data/lib/rubocop/cop/layout/leading_comment_space.rb +2 -2
  129. data/lib/rubocop/cop/layout/leading_empty_lines.rb +1 -1
  130. data/lib/rubocop/cop/layout/line_continuation_leading_space.rb +136 -0
  131. data/lib/rubocop/cop/layout/line_continuation_spacing.rb +140 -0
  132. data/lib/rubocop/cop/layout/line_end_string_concatenation_indentation.rb +2 -2
  133. data/lib/rubocop/cop/layout/line_length.rb +13 -6
  134. data/lib/rubocop/cop/layout/multiline_array_brace_layout.rb +1 -1
  135. data/lib/rubocop/cop/layout/multiline_array_line_breaks.rb +32 -2
  136. data/lib/rubocop/cop/layout/multiline_assignment_layout.rb +2 -2
  137. data/lib/rubocop/cop/layout/multiline_block_layout.rb +5 -3
  138. data/lib/rubocop/cop/layout/multiline_hash_brace_layout.rb +1 -1
  139. data/lib/rubocop/cop/layout/multiline_hash_key_line_breaks.rb +30 -2
  140. data/lib/rubocop/cop/layout/multiline_method_argument_line_breaks.rb +40 -3
  141. data/lib/rubocop/cop/layout/multiline_method_call_brace_layout.rb +1 -1
  142. data/lib/rubocop/cop/layout/multiline_method_call_indentation.rb +22 -5
  143. data/lib/rubocop/cop/layout/multiline_method_definition_brace_layout.rb +1 -1
  144. data/lib/rubocop/cop/layout/multiline_method_parameter_line_breaks.rb +77 -0
  145. data/lib/rubocop/cop/layout/multiline_operation_indentation.rb +3 -3
  146. data/lib/rubocop/cop/layout/redundant_line_break.rb +10 -11
  147. data/lib/rubocop/cop/layout/rescue_ensure_alignment.rb +3 -3
  148. data/lib/rubocop/cop/layout/single_line_block_chain.rb +1 -1
  149. data/lib/rubocop/cop/layout/space_after_not.rb +1 -1
  150. data/lib/rubocop/cop/layout/space_around_block_parameters.rb +3 -3
  151. data/lib/rubocop/cop/layout/space_around_keyword.rb +3 -3
  152. data/lib/rubocop/cop/layout/space_around_operators.rb +2 -2
  153. data/lib/rubocop/cop/layout/space_before_block_braces.rb +5 -3
  154. data/lib/rubocop/cop/layout/space_before_brackets.rb +7 -0
  155. data/lib/rubocop/cop/layout/space_before_comment.rb +1 -1
  156. data/lib/rubocop/cop/layout/space_before_first_arg.rb +2 -2
  157. data/lib/rubocop/cop/layout/space_in_lambda_literal.rb +3 -3
  158. data/lib/rubocop/cop/layout/space_inside_array_literal_brackets.rb +32 -30
  159. data/lib/rubocop/cop/layout/space_inside_array_percent_literal.rb +3 -0
  160. data/lib/rubocop/cop/layout/space_inside_block_braces.rb +35 -15
  161. data/lib/rubocop/cop/layout/space_inside_hash_literal_braces.rb +30 -3
  162. data/lib/rubocop/cop/layout/space_inside_parens.rb +2 -2
  163. data/lib/rubocop/cop/layout/space_inside_percent_literal_delimiters.rb +34 -0
  164. data/lib/rubocop/cop/layout/space_inside_reference_brackets.rb +11 -7
  165. data/lib/rubocop/cop/layout/space_inside_string_interpolation.rb +6 -5
  166. data/lib/rubocop/cop/layout/trailing_empty_lines.rb +10 -10
  167. data/lib/rubocop/cop/layout/trailing_whitespace.rb +15 -8
  168. data/lib/rubocop/cop/legacy/corrections_proxy.rb +1 -1
  169. data/lib/rubocop/cop/legacy/corrector.rb +1 -1
  170. data/lib/rubocop/cop/lint/ambiguous_assignment.rb +1 -1
  171. data/lib/rubocop/cop/lint/ambiguous_block_association.rb +40 -8
  172. data/lib/rubocop/cop/lint/ambiguous_operator.rb +5 -1
  173. data/lib/rubocop/cop/lint/ambiguous_operator_precedence.rb +1 -1
  174. data/lib/rubocop/cop/lint/ambiguous_range.rb +5 -5
  175. data/lib/rubocop/cop/lint/ambiguous_regexp_literal.rb +1 -1
  176. data/lib/rubocop/cop/lint/assignment_in_condition.rb +12 -2
  177. data/lib/rubocop/cop/lint/binary_operator_with_identical_operands.rb +1 -1
  178. data/lib/rubocop/cop/lint/boolean_symbol.rb +1 -1
  179. data/lib/rubocop/cop/lint/circular_argument_reference.rb +1 -1
  180. data/lib/rubocop/cop/lint/constant_overwritten_in_rescue.rb +51 -0
  181. data/lib/rubocop/cop/lint/constant_resolution.rb +5 -1
  182. data/lib/rubocop/cop/lint/debugger.rb +28 -32
  183. data/lib/rubocop/cop/lint/deprecated_class_methods.rb +67 -111
  184. data/lib/rubocop/cop/lint/deprecated_constants.rb +9 -2
  185. data/lib/rubocop/cop/lint/deprecated_open_ssl_constant.rb +1 -1
  186. data/lib/rubocop/cop/lint/disjunctive_assignment_in_constructor.rb +1 -1
  187. data/lib/rubocop/cop/lint/duplicate_branch.rb +1 -3
  188. data/lib/rubocop/cop/lint/duplicate_case_condition.rb +1 -1
  189. data/lib/rubocop/cop/lint/duplicate_elsif_condition.rb +1 -1
  190. data/lib/rubocop/cop/lint/duplicate_hash_key.rb +1 -1
  191. data/lib/rubocop/cop/lint/duplicate_magic_comment.rb +73 -0
  192. data/lib/rubocop/cop/lint/duplicate_match_pattern.rb +122 -0
  193. data/lib/rubocop/cop/lint/duplicate_methods.rb +49 -19
  194. data/lib/rubocop/cop/lint/duplicate_regexp_character_class_element.rb +27 -10
  195. data/lib/rubocop/cop/lint/duplicate_require.rb +11 -2
  196. data/lib/rubocop/cop/lint/duplicate_rescue_exception.rb +1 -1
  197. data/lib/rubocop/cop/lint/each_with_object_argument.rb +1 -1
  198. data/lib/rubocop/cop/lint/else_layout.rb +6 -10
  199. data/lib/rubocop/cop/lint/empty_block.rb +4 -8
  200. data/lib/rubocop/cop/lint/empty_class.rb +4 -2
  201. data/lib/rubocop/cop/lint/empty_conditional_body.rb +111 -3
  202. data/lib/rubocop/cop/lint/empty_ensure.rb +1 -1
  203. data/lib/rubocop/cop/lint/empty_expression.rb +1 -1
  204. data/lib/rubocop/cop/lint/empty_file.rb +1 -1
  205. data/lib/rubocop/cop/lint/empty_in_pattern.rb +1 -1
  206. data/lib/rubocop/cop/lint/empty_interpolation.rb +2 -2
  207. data/lib/rubocop/cop/lint/empty_when.rb +1 -1
  208. data/lib/rubocop/cop/lint/ensure_return.rb +1 -1
  209. data/lib/rubocop/cop/lint/erb_new_arguments.rb +12 -12
  210. data/lib/rubocop/cop/lint/flip_flop.rb +1 -1
  211. data/lib/rubocop/cop/lint/float_comparison.rb +1 -1
  212. data/lib/rubocop/cop/lint/float_out_of_range.rb +1 -1
  213. data/lib/rubocop/cop/lint/format_parameter_mismatch.rb +14 -7
  214. data/lib/rubocop/cop/lint/heredoc_method_call_position.rb +16 -18
  215. data/lib/rubocop/cop/lint/implicit_string_concatenation.rb +2 -2
  216. data/lib/rubocop/cop/lint/incompatible_io_select_with_fiber_scheduler.rb +6 -3
  217. data/lib/rubocop/cop/lint/ineffective_access_modifier.rb +2 -2
  218. data/lib/rubocop/cop/lint/inherit_exception.rb +1 -1
  219. data/lib/rubocop/cop/lint/interpolation_check.rb +6 -5
  220. data/lib/rubocop/cop/lint/lambda_without_literal_block.rb +3 -3
  221. data/lib/rubocop/cop/lint/literal_as_condition.rb +6 -1
  222. data/lib/rubocop/cop/lint/literal_in_interpolation.rb +49 -3
  223. data/lib/rubocop/cop/lint/loop.rb +2 -2
  224. data/lib/rubocop/cop/lint/missing_cop_enable_directive.rb +19 -4
  225. data/lib/rubocop/cop/lint/missing_super.rb +32 -3
  226. data/lib/rubocop/cop/lint/mixed_regexp_capture_types.rb +1 -0
  227. data/lib/rubocop/cop/lint/nested_method_definition.rb +54 -10
  228. data/lib/rubocop/cop/lint/nested_percent_literal.rb +1 -1
  229. data/lib/rubocop/cop/lint/next_without_accumulator.rb +25 -6
  230. data/lib/rubocop/cop/lint/non_atomic_file_operation.rb +162 -0
  231. data/lib/rubocop/cop/lint/non_deterministic_require_order.rb +17 -5
  232. data/lib/rubocop/cop/lint/non_local_exit_from_iterator.rb +1 -1
  233. data/lib/rubocop/cop/lint/number_conversion.rb +32 -10
  234. data/lib/rubocop/cop/lint/numbered_parameter_assignment.rb +3 -3
  235. data/lib/rubocop/cop/lint/or_assignment_to_constant.rb +4 -3
  236. data/lib/rubocop/cop/lint/ordered_magic_comments.rb +4 -5
  237. data/lib/rubocop/cop/lint/out_of_range_regexp_ref.rb +17 -2
  238. data/lib/rubocop/cop/lint/parentheses_as_grouped_expression.rb +7 -2
  239. data/lib/rubocop/cop/lint/percent_string_array.rb +2 -2
  240. data/lib/rubocop/cop/lint/percent_symbol_array.rb +2 -2
  241. data/lib/rubocop/cop/lint/raise_exception.rb +2 -2
  242. data/lib/rubocop/cop/lint/rand_one.rb +1 -1
  243. data/lib/rubocop/cop/lint/redundant_cop_disable_directive.rb +55 -15
  244. data/lib/rubocop/cop/lint/redundant_cop_enable_directive.rb +8 -8
  245. data/lib/rubocop/cop/lint/redundant_dir_glob_sort.rb +7 -0
  246. data/lib/rubocop/cop/lint/redundant_require_statement.rb +48 -7
  247. data/lib/rubocop/cop/lint/redundant_safe_navigation.rb +16 -3
  248. data/lib/rubocop/cop/lint/redundant_splat_expansion.rb +2 -2
  249. data/lib/rubocop/cop/lint/redundant_string_coercion.rb +35 -15
  250. data/lib/rubocop/cop/lint/redundant_with_index.rb +15 -12
  251. data/lib/rubocop/cop/lint/redundant_with_object.rb +14 -13
  252. data/lib/rubocop/cop/lint/refinement_import_methods.rb +3 -2
  253. data/lib/rubocop/cop/lint/regexp_as_condition.rb +9 -3
  254. data/lib/rubocop/cop/lint/require_parentheses.rb +4 -2
  255. data/lib/rubocop/cop/lint/require_range_parentheses.rb +57 -0
  256. data/lib/rubocop/cop/lint/rescue_exception.rb +1 -1
  257. data/lib/rubocop/cop/lint/rescue_type.rb +3 -3
  258. data/lib/rubocop/cop/lint/return_in_void_context.rb +6 -18
  259. data/lib/rubocop/cop/lint/safe_navigation_chain.rb +44 -8
  260. data/lib/rubocop/cop/lint/safe_navigation_consistency.rb +2 -2
  261. data/lib/rubocop/cop/lint/safe_navigation_with_empty.rb +1 -1
  262. data/lib/rubocop/cop/lint/script_permission.rb +2 -2
  263. data/lib/rubocop/cop/lint/self_assignment.rb +1 -1
  264. data/lib/rubocop/cop/lint/send_with_mixin_argument.rb +5 -4
  265. data/lib/rubocop/cop/lint/shadowed_argument.rb +1 -1
  266. data/lib/rubocop/cop/lint/shadowed_exception.rb +17 -12
  267. data/lib/rubocop/cop/lint/shadowing_outer_local_variable.rb +29 -4
  268. data/lib/rubocop/cop/lint/struct_new_override.rb +3 -3
  269. data/lib/rubocop/cop/lint/suppressed_exception.rb +2 -2
  270. data/lib/rubocop/cop/lint/symbol_conversion.rb +1 -1
  271. data/lib/rubocop/cop/lint/syntax.rb +5 -1
  272. data/lib/rubocop/cop/lint/to_enum_arguments.rb +14 -4
  273. data/lib/rubocop/cop/lint/to_json.rb +1 -1
  274. data/lib/rubocop/cop/lint/top_level_return_with_argument.rb +24 -10
  275. data/lib/rubocop/cop/lint/trailing_comma_in_attribute_declaration.rb +2 -2
  276. data/lib/rubocop/cop/lint/triple_quotes.rb +1 -1
  277. data/lib/rubocop/cop/lint/underscore_prefixed_variable_name.rb +1 -1
  278. data/lib/rubocop/cop/lint/unexpected_block_arity.rb +1 -1
  279. data/lib/rubocop/cop/lint/unified_integer.rb +3 -1
  280. data/lib/rubocop/cop/lint/unreachable_code.rb +1 -1
  281. data/lib/rubocop/cop/lint/unreachable_loop.rb +15 -9
  282. data/lib/rubocop/cop/lint/unused_block_argument.rb +1 -1
  283. data/lib/rubocop/cop/lint/unused_method_argument.rb +7 -2
  284. data/lib/rubocop/cop/lint/uri_escape_unescape.rb +1 -1
  285. data/lib/rubocop/cop/lint/uri_regexp.rb +1 -1
  286. data/lib/rubocop/cop/lint/useless_access_modifier.rb +18 -13
  287. data/lib/rubocop/cop/lint/useless_assignment.rb +57 -2
  288. data/lib/rubocop/cop/lint/useless_else_without_rescue.rb +2 -3
  289. data/lib/rubocop/cop/lint/useless_method_definition.rb +13 -5
  290. data/lib/rubocop/cop/lint/useless_rescue.rb +89 -0
  291. data/lib/rubocop/cop/lint/useless_ruby2_keywords.rb +16 -6
  292. data/lib/rubocop/cop/lint/useless_setter_call.rb +2 -2
  293. data/lib/rubocop/cop/lint/useless_times.rb +3 -3
  294. data/lib/rubocop/cop/lint/void.rb +92 -21
  295. data/lib/rubocop/cop/metrics/abc_size.rb +5 -3
  296. data/lib/rubocop/cop/metrics/block_length.rb +17 -12
  297. data/lib/rubocop/cop/metrics/block_nesting.rb +3 -3
  298. data/lib/rubocop/cop/metrics/class_length.rb +11 -5
  299. data/lib/rubocop/cop/metrics/collection_literal_length.rb +76 -0
  300. data/lib/rubocop/cop/metrics/cyclomatic_complexity.rb +2 -2
  301. data/lib/rubocop/cop/metrics/method_length.rb +18 -12
  302. data/lib/rubocop/cop/metrics/module_length.rb +10 -5
  303. data/lib/rubocop/cop/metrics/parameter_lists.rb +28 -1
  304. data/lib/rubocop/cop/metrics/perceived_complexity.rb +2 -2
  305. data/lib/rubocop/cop/metrics/utils/abc_size_calculator.rb +4 -7
  306. data/lib/rubocop/cop/metrics/utils/code_length_calculator.rb +29 -7
  307. data/lib/rubocop/cop/migration/department_name.rb +1 -1
  308. data/lib/rubocop/cop/mixin/alignment.rb +2 -2
  309. data/lib/rubocop/cop/mixin/allowed_identifiers.rb +2 -2
  310. data/lib/rubocop/cop/mixin/allowed_methods.rb +23 -2
  311. data/lib/rubocop/cop/mixin/allowed_pattern.rb +56 -0
  312. data/lib/rubocop/cop/mixin/annotation_comment.rb +14 -7
  313. data/lib/rubocop/cop/mixin/check_line_breakable.rb +5 -1
  314. data/lib/rubocop/cop/mixin/code_length.rb +1 -1
  315. data/lib/rubocop/cop/mixin/comments_help.rb +29 -5
  316. data/lib/rubocop/cop/mixin/configurable_enforced_style.rb +21 -9
  317. data/lib/rubocop/cop/mixin/def_node.rb +2 -7
  318. data/lib/rubocop/cop/mixin/documentation_comment.rb +1 -1
  319. data/lib/rubocop/cop/mixin/duplication.rb +1 -1
  320. data/lib/rubocop/cop/mixin/enforce_superclass.rb +2 -1
  321. data/lib/rubocop/cop/mixin/first_element_line_break.rb +11 -7
  322. data/lib/rubocop/cop/mixin/frozen_string_literal.rb +4 -0
  323. data/lib/rubocop/cop/mixin/hash_alignment_styles.rb +1 -1
  324. data/lib/rubocop/cop/mixin/hash_shorthand_syntax.rb +157 -12
  325. data/lib/rubocop/cop/mixin/hash_transform_method.rb +13 -9
  326. data/lib/rubocop/cop/mixin/line_length_help.rb +11 -2
  327. data/lib/rubocop/cop/mixin/method_complexity.rb +13 -16
  328. data/lib/rubocop/cop/mixin/min_branches_count.rb +40 -0
  329. data/lib/rubocop/cop/mixin/multiline_element_indentation.rb +34 -12
  330. data/lib/rubocop/cop/mixin/multiline_element_line_breaks.rb +5 -6
  331. data/lib/rubocop/cop/mixin/ordered_gem_node.rb +1 -1
  332. data/lib/rubocop/cop/mixin/percent_array.rb +58 -1
  333. data/lib/rubocop/cop/mixin/preceding_following_alignment.rb +1 -1
  334. data/lib/rubocop/cop/mixin/preferred_delimiters.rb +2 -2
  335. data/lib/rubocop/cop/mixin/range_help.rb +28 -7
  336. data/lib/rubocop/cop/mixin/require_library.rb +2 -0
  337. data/lib/rubocop/cop/mixin/rescue_node.rb +5 -3
  338. data/lib/rubocop/cop/mixin/space_after_punctuation.rb +1 -1
  339. data/lib/rubocop/cop/mixin/statement_modifier.rb +19 -4
  340. data/lib/rubocop/cop/mixin/string_help.rb +1 -1
  341. data/lib/rubocop/cop/mixin/surrounding_space.rb +13 -11
  342. data/lib/rubocop/cop/mixin/trailing_comma.rb +3 -3
  343. data/lib/rubocop/cop/mixin/visibility_help.rb +40 -5
  344. data/lib/rubocop/cop/naming/accessor_method_name.rb +4 -2
  345. data/lib/rubocop/cop/naming/ascii_identifiers.rb +2 -2
  346. data/lib/rubocop/cop/naming/binary_operator_parameter_name.rb +1 -1
  347. data/lib/rubocop/cop/naming/block_forwarding.rb +8 -4
  348. data/lib/rubocop/cop/naming/block_parameter_name.rb +2 -2
  349. data/lib/rubocop/cop/naming/class_and_module_camel_case.rb +4 -2
  350. data/lib/rubocop/cop/naming/constant_name.rb +4 -4
  351. data/lib/rubocop/cop/naming/file_name.rb +2 -2
  352. data/lib/rubocop/cop/naming/heredoc_delimiter_case.rb +2 -2
  353. data/lib/rubocop/cop/naming/heredoc_delimiter_naming.rb +1 -1
  354. data/lib/rubocop/cop/naming/inclusive_language.rb +31 -8
  355. data/lib/rubocop/cop/naming/memoized_instance_variable_name.rb +23 -8
  356. data/lib/rubocop/cop/naming/method_name.rb +9 -9
  357. data/lib/rubocop/cop/naming/method_parameter_name.rb +1 -1
  358. data/lib/rubocop/cop/naming/predicate_name.rb +33 -4
  359. data/lib/rubocop/cop/naming/rescued_exceptions_variable_name.rb +13 -5
  360. data/lib/rubocop/cop/naming/variable_name.rb +10 -1
  361. data/lib/rubocop/cop/naming/variable_number.rb +28 -18
  362. data/lib/rubocop/cop/offense.rb +1 -1
  363. data/lib/rubocop/cop/registry.rb +73 -45
  364. data/lib/rubocop/cop/security/compound_hash.rb +106 -0
  365. data/lib/rubocop/cop/security/eval.rb +1 -1
  366. data/lib/rubocop/cop/security/json_load.rb +1 -1
  367. data/lib/rubocop/cop/security/marshal_load.rb +1 -1
  368. data/lib/rubocop/cop/security/open.rb +1 -1
  369. data/lib/rubocop/cop/security/yaml_load.rb +2 -2
  370. data/lib/rubocop/cop/style/access_modifier_declarations.rb +92 -3
  371. data/lib/rubocop/cop/style/accessor_grouping.rb +49 -23
  372. data/lib/rubocop/cop/style/alias.rb +13 -5
  373. data/lib/rubocop/cop/style/and_or.rb +12 -12
  374. data/lib/rubocop/cop/style/arguments_forwarding.rb +7 -6
  375. data/lib/rubocop/cop/style/array_coercion.rb +1 -1
  376. data/lib/rubocop/cop/style/array_intersect.rb +111 -0
  377. data/lib/rubocop/cop/style/array_join.rb +1 -1
  378. data/lib/rubocop/cop/style/ascii_comments.rb +2 -2
  379. data/lib/rubocop/cop/style/attr.rb +12 -2
  380. data/lib/rubocop/cop/style/auto_resource_cleanup.rb +1 -1
  381. data/lib/rubocop/cop/style/bare_percent_literals.rb +1 -1
  382. data/lib/rubocop/cop/style/bisected_attr_accessor/macro.rb +1 -1
  383. data/lib/rubocop/cop/style/bisected_attr_accessor.rb +2 -2
  384. data/lib/rubocop/cop/style/block_comments.rb +3 -3
  385. data/lib/rubocop/cop/style/block_delimiters.rb +52 -11
  386. data/lib/rubocop/cop/style/case_equality.rb +41 -11
  387. data/lib/rubocop/cop/style/case_like_if.rb +22 -5
  388. data/lib/rubocop/cop/style/character_literal.rb +2 -2
  389. data/lib/rubocop/cop/style/class_and_module_children.rb +9 -16
  390. data/lib/rubocop/cop/style/class_check.rb +1 -1
  391. data/lib/rubocop/cop/style/class_equality_comparison.rb +95 -13
  392. data/lib/rubocop/cop/style/class_methods.rb +1 -1
  393. data/lib/rubocop/cop/style/class_methods_definitions.rb +3 -2
  394. data/lib/rubocop/cop/style/class_vars.rb +1 -1
  395. data/lib/rubocop/cop/style/collection_compact.rb +25 -9
  396. data/lib/rubocop/cop/style/collection_methods.rb +3 -1
  397. data/lib/rubocop/cop/style/colon_method_call.rb +2 -2
  398. data/lib/rubocop/cop/style/colon_method_definition.rb +1 -1
  399. data/lib/rubocop/cop/style/combinable_loops.rb +30 -8
  400. data/lib/rubocop/cop/style/command_literal.rb +2 -2
  401. data/lib/rubocop/cop/style/comment_annotation.rb +2 -2
  402. data/lib/rubocop/cop/style/commented_keyword.rb +5 -5
  403. data/lib/rubocop/cop/style/comparable_clamp.rb +125 -0
  404. data/lib/rubocop/cop/style/concat_array_literals.rb +94 -0
  405. data/lib/rubocop/cop/style/conditional_assignment.rb +10 -15
  406. data/lib/rubocop/cop/style/constant_visibility.rb +1 -1
  407. data/lib/rubocop/cop/style/copyright.rb +6 -3
  408. data/lib/rubocop/cop/style/data_inheritance.rb +75 -0
  409. data/lib/rubocop/cop/style/date_time.rb +2 -2
  410. data/lib/rubocop/cop/style/def_with_parentheses.rb +1 -1
  411. data/lib/rubocop/cop/style/dir.rb +4 -1
  412. data/lib/rubocop/cop/style/dir_empty.rb +60 -0
  413. data/lib/rubocop/cop/style/disable_cops_within_source_code_directive.rb +2 -2
  414. data/lib/rubocop/cop/style/document_dynamic_eval_definition.rb +2 -2
  415. data/lib/rubocop/cop/style/documentation.rb +23 -11
  416. data/lib/rubocop/cop/style/documentation_method.rb +11 -5
  417. data/lib/rubocop/cop/style/double_negation.rb +31 -3
  418. data/lib/rubocop/cop/style/each_for_simple_loop.rb +42 -7
  419. data/lib/rubocop/cop/style/each_with_object.rb +41 -10
  420. data/lib/rubocop/cop/style/empty_block_parameter.rb +3 -3
  421. data/lib/rubocop/cop/style/empty_case_condition.rb +2 -2
  422. data/lib/rubocop/cop/style/empty_else.rb +40 -3
  423. data/lib/rubocop/cop/style/empty_heredoc.rb +73 -0
  424. data/lib/rubocop/cop/style/empty_lambda_parameter.rb +3 -3
  425. data/lib/rubocop/cop/style/empty_literal.rb +2 -2
  426. data/lib/rubocop/cop/style/empty_method.rb +18 -3
  427. data/lib/rubocop/cop/style/encoding.rb +2 -2
  428. data/lib/rubocop/cop/style/end_block.rb +1 -1
  429. data/lib/rubocop/cop/style/endless_method.rb +2 -2
  430. data/lib/rubocop/cop/style/env_home.rb +56 -0
  431. data/lib/rubocop/cop/style/eval_with_location.rb +5 -5
  432. data/lib/rubocop/cop/style/even_odd.rb +1 -1
  433. data/lib/rubocop/cop/style/exact_regexp_match.rb +62 -0
  434. data/lib/rubocop/cop/style/expand_path_arguments.rb +1 -1
  435. data/lib/rubocop/cop/style/explicit_block_argument.rb +7 -3
  436. data/lib/rubocop/cop/style/exponential_notation.rb +1 -1
  437. data/lib/rubocop/cop/style/fetch_env_var.rb +132 -0
  438. data/lib/rubocop/cop/style/file_empty.rb +71 -0
  439. data/lib/rubocop/cop/style/file_read.rb +1 -1
  440. data/lib/rubocop/cop/style/file_write.rb +1 -1
  441. data/lib/rubocop/cop/style/float_division.rb +1 -1
  442. data/lib/rubocop/cop/style/for.rb +3 -1
  443. data/lib/rubocop/cop/style/format_string.rb +1 -1
  444. data/lib/rubocop/cop/style/format_string_token.rb +73 -23
  445. data/lib/rubocop/cop/style/frozen_string_literal_comment.rb +7 -4
  446. data/lib/rubocop/cop/style/global_std_stream.rb +1 -1
  447. data/lib/rubocop/cop/style/global_vars.rb +1 -1
  448. data/lib/rubocop/cop/style/guard_clause.rb +161 -25
  449. data/lib/rubocop/cop/style/hash_as_last_array_item.rb +2 -1
  450. data/lib/rubocop/cop/style/hash_conversion.rb +1 -1
  451. data/lib/rubocop/cop/style/hash_each_methods.rb +49 -13
  452. data/lib/rubocop/cop/style/hash_except.rb +101 -10
  453. data/lib/rubocop/cop/style/hash_like_case.rb +4 -10
  454. data/lib/rubocop/cop/style/hash_syntax.rb +29 -5
  455. data/lib/rubocop/cop/style/hash_transform_keys.rb +6 -1
  456. data/lib/rubocop/cop/style/hash_transform_values.rb +4 -1
  457. data/lib/rubocop/cop/style/identical_conditional_branches.rb +19 -4
  458. data/lib/rubocop/cop/style/if_inside_else.rb +6 -0
  459. data/lib/rubocop/cop/style/if_unless_modifier.rb +117 -20
  460. data/lib/rubocop/cop/style/if_with_boolean_literal_branches.rb +31 -4
  461. data/lib/rubocop/cop/style/if_with_semicolon.rb +4 -4
  462. data/lib/rubocop/cop/style/implicit_runtime_error.rb +3 -3
  463. data/lib/rubocop/cop/style/in_pattern_then.rb +1 -1
  464. data/lib/rubocop/cop/style/infinite_loop.rb +2 -5
  465. data/lib/rubocop/cop/style/inline_comment.rb +1 -1
  466. data/lib/rubocop/cop/style/inverse_methods.rb +17 -13
  467. data/lib/rubocop/cop/style/invertible_unless_condition.rb +118 -0
  468. data/lib/rubocop/cop/style/ip_addresses.rb +1 -1
  469. data/lib/rubocop/cop/style/keyword_parameters_order.rb +2 -2
  470. data/lib/rubocop/cop/style/lambda.rb +1 -1
  471. data/lib/rubocop/cop/style/lambda_call.rb +1 -1
  472. data/lib/rubocop/cop/style/line_end_concatenation.rb +6 -3
  473. data/lib/rubocop/cop/style/magic_comment_format.rb +307 -0
  474. data/lib/rubocop/cop/style/map_compact_with_conditional_block.rb +136 -0
  475. data/lib/rubocop/cop/style/map_to_hash.rb +7 -4
  476. data/lib/rubocop/cop/style/map_to_set.rb +64 -0
  477. data/lib/rubocop/cop/style/method_call_with_args_parentheses/omit_parentheses.rb +42 -26
  478. data/lib/rubocop/cop/style/method_call_with_args_parentheses/require_parentheses.rb +6 -2
  479. data/lib/rubocop/cop/style/method_call_with_args_parentheses.rb +52 -45
  480. data/lib/rubocop/cop/style/method_call_without_args_parentheses.rb +22 -3
  481. data/lib/rubocop/cop/style/method_called_on_do_end_block.rb +5 -2
  482. data/lib/rubocop/cop/style/method_def_parentheses.rb +12 -5
  483. data/lib/rubocop/cop/style/min_max.rb +4 -4
  484. data/lib/rubocop/cop/style/min_max_comparison.rb +83 -0
  485. data/lib/rubocop/cop/style/missing_else.rb +37 -25
  486. data/lib/rubocop/cop/style/missing_respond_to_missing.rb +1 -1
  487. data/lib/rubocop/cop/style/mixin_grouping.rb +6 -6
  488. data/lib/rubocop/cop/style/mixin_usage.rb +1 -1
  489. data/lib/rubocop/cop/style/module_function.rb +30 -8
  490. data/lib/rubocop/cop/style/multiline_block_chain.rb +4 -2
  491. data/lib/rubocop/cop/style/multiline_if_modifier.rb +2 -6
  492. data/lib/rubocop/cop/style/multiline_if_then.rb +1 -1
  493. data/lib/rubocop/cop/style/multiline_in_pattern_then.rb +3 -5
  494. data/lib/rubocop/cop/style/multiline_memoization.rb +3 -3
  495. data/lib/rubocop/cop/style/multiline_method_signature.rb +9 -6
  496. data/lib/rubocop/cop/style/multiline_ternary_operator.rb +52 -11
  497. data/lib/rubocop/cop/style/multiline_when_then.rb +2 -4
  498. data/lib/rubocop/cop/style/multiple_comparison.rb +1 -1
  499. data/lib/rubocop/cop/style/mutable_constant.rb +1 -1
  500. data/lib/rubocop/cop/style/negated_if_else_condition.rb +18 -11
  501. data/lib/rubocop/cop/style/nested_file_dirname.rb +1 -1
  502. data/lib/rubocop/cop/style/nested_modifier.rb +1 -1
  503. data/lib/rubocop/cop/style/nested_parenthesized_calls.rb +11 -2
  504. data/lib/rubocop/cop/style/nested_ternary_operator.rb +20 -8
  505. data/lib/rubocop/cop/style/next.rb +4 -6
  506. data/lib/rubocop/cop/style/nil_comparison.rb +1 -1
  507. data/lib/rubocop/cop/style/nil_lambda.rb +5 -5
  508. data/lib/rubocop/cop/style/non_nil_check.rb +1 -1
  509. data/lib/rubocop/cop/style/not.rb +2 -2
  510. data/lib/rubocop/cop/style/numbered_parameters.rb +1 -1
  511. data/lib/rubocop/cop/style/numbered_parameters_limit.rb +12 -4
  512. data/lib/rubocop/cop/style/numeric_literal_prefix.rb +1 -1
  513. data/lib/rubocop/cop/style/numeric_literals.rb +16 -1
  514. data/lib/rubocop/cop/style/numeric_predicate.rb +53 -11
  515. data/lib/rubocop/cop/style/object_then.rb +74 -0
  516. data/lib/rubocop/cop/style/one_line_conditional.rb +4 -7
  517. data/lib/rubocop/cop/style/open_struct_use.rb +1 -1
  518. data/lib/rubocop/cop/style/operator_method_call.rb +67 -0
  519. data/lib/rubocop/cop/style/option_hash.rb +1 -1
  520. data/lib/rubocop/cop/style/optional_arguments.rb +2 -2
  521. data/lib/rubocop/cop/style/optional_boolean_parameter.rb +2 -2
  522. data/lib/rubocop/cop/style/or_assignment.rb +1 -1
  523. data/lib/rubocop/cop/style/parallel_assignment.rb +29 -19
  524. data/lib/rubocop/cop/style/parentheses_around_condition.rb +1 -1
  525. data/lib/rubocop/cop/style/percent_literal_delimiters.rb +3 -4
  526. data/lib/rubocop/cop/style/percent_q_literals.rb +2 -2
  527. data/lib/rubocop/cop/style/perl_backrefs.rb +23 -2
  528. data/lib/rubocop/cop/style/preferred_hash_methods.rb +1 -1
  529. data/lib/rubocop/cop/style/proc.rb +5 -2
  530. data/lib/rubocop/cop/style/quoted_symbols.rb +2 -2
  531. data/lib/rubocop/cop/style/raise_args.rb +5 -2
  532. data/lib/rubocop/cop/style/random_with_offset.rb +1 -1
  533. data/lib/rubocop/cop/style/redundant_argument.rb +5 -2
  534. data/lib/rubocop/cop/style/redundant_assignment.rb +1 -1
  535. data/lib/rubocop/cop/style/redundant_begin.rb +20 -6
  536. data/lib/rubocop/cop/style/redundant_capital_w.rb +1 -1
  537. data/lib/rubocop/cop/style/redundant_condition.rb +148 -14
  538. data/lib/rubocop/cop/style/redundant_conditional.rb +1 -5
  539. data/lib/rubocop/cop/style/redundant_constant_base.rb +85 -0
  540. data/lib/rubocop/cop/style/redundant_double_splat_hash_braces.rb +45 -0
  541. data/lib/rubocop/cop/style/redundant_each.rb +116 -0
  542. data/lib/rubocop/cop/style/redundant_exception.rb +1 -1
  543. data/lib/rubocop/cop/style/redundant_fetch_block.rb +7 -5
  544. data/lib/rubocop/cop/style/redundant_file_extension_in_require.rb +1 -1
  545. data/lib/rubocop/cop/style/redundant_freeze.rb +1 -1
  546. data/lib/rubocop/cop/style/redundant_heredoc_delimiter_quotes.rb +58 -0
  547. data/lib/rubocop/cop/style/redundant_initialize.rb +41 -4
  548. data/lib/rubocop/cop/style/redundant_interpolation.rb +24 -3
  549. data/lib/rubocop/cop/style/redundant_line_continuation.rb +183 -0
  550. data/lib/rubocop/cop/style/redundant_parentheses.rb +23 -25
  551. data/lib/rubocop/cop/style/redundant_percent_q.rb +2 -2
  552. data/lib/rubocop/cop/style/redundant_regexp_character_class.rb +15 -4
  553. data/lib/rubocop/cop/style/redundant_regexp_escape.rb +23 -6
  554. data/lib/rubocop/cop/style/redundant_return.rb +9 -2
  555. data/lib/rubocop/cop/style/redundant_self.rb +3 -1
  556. data/lib/rubocop/cop/style/redundant_self_assignment.rb +3 -4
  557. data/lib/rubocop/cop/style/redundant_self_assignment_branch.rb +1 -1
  558. data/lib/rubocop/cop/style/redundant_sort.rb +25 -10
  559. data/lib/rubocop/cop/style/redundant_sort_by.rb +25 -9
  560. data/lib/rubocop/cop/style/redundant_string_escape.rb +183 -0
  561. data/lib/rubocop/cop/style/regexp_literal.rb +11 -2
  562. data/lib/rubocop/cop/style/require_order.rb +138 -0
  563. data/lib/rubocop/cop/style/rescue_modifier.rb +2 -2
  564. data/lib/rubocop/cop/style/rescue_standard_error.rb +15 -15
  565. data/lib/rubocop/cop/style/return_nil.rb +1 -1
  566. data/lib/rubocop/cop/style/safe_navigation.rb +46 -12
  567. data/lib/rubocop/cop/style/sample.rb +1 -1
  568. data/lib/rubocop/cop/style/select_by_regexp.rb +14 -6
  569. data/lib/rubocop/cop/style/self_assignment.rb +3 -3
  570. data/lib/rubocop/cop/style/semicolon.rb +64 -6
  571. data/lib/rubocop/cop/style/send.rb +1 -1
  572. data/lib/rubocop/cop/style/signal_exception.rb +9 -7
  573. data/lib/rubocop/cop/style/single_argument_dig.rb +5 -0
  574. data/lib/rubocop/cop/style/single_line_block_params.rb +2 -2
  575. data/lib/rubocop/cop/style/single_line_methods.rb +2 -2
  576. data/lib/rubocop/cop/style/slicing_with_range.rb +2 -2
  577. data/lib/rubocop/cop/style/sole_nested_conditional.rb +52 -24
  578. data/lib/rubocop/cop/style/special_global_vars.rb +66 -8
  579. data/lib/rubocop/cop/style/static_class.rb +33 -2
  580. data/lib/rubocop/cop/style/stderr_puts.rb +2 -2
  581. data/lib/rubocop/cop/style/string_chars.rb +1 -1
  582. data/lib/rubocop/cop/style/string_concatenation.rb +6 -7
  583. data/lib/rubocop/cop/style/string_hash_keys.rb +5 -2
  584. data/lib/rubocop/cop/style/string_literals.rb +1 -5
  585. data/lib/rubocop/cop/style/string_literals_in_interpolation.rb +1 -1
  586. data/lib/rubocop/cop/style/string_methods.rb +1 -1
  587. data/lib/rubocop/cop/style/strip.rb +1 -1
  588. data/lib/rubocop/cop/style/struct_inheritance.rb +5 -5
  589. data/lib/rubocop/cop/style/swap_values.rb +2 -2
  590. data/lib/rubocop/cop/style/symbol_array.rb +12 -7
  591. data/lib/rubocop/cop/style/symbol_literal.rb +1 -1
  592. data/lib/rubocop/cop/style/symbol_proc.rb +68 -12
  593. data/lib/rubocop/cop/style/ternary_parentheses.rb +2 -14
  594. data/lib/rubocop/cop/style/top_level_method_definition.rb +3 -1
  595. data/lib/rubocop/cop/style/trailing_body_on_class.rb +2 -1
  596. data/lib/rubocop/cop/style/trailing_body_on_method_definition.rb +1 -1
  597. data/lib/rubocop/cop/style/trailing_body_on_module.rb +1 -1
  598. data/lib/rubocop/cop/style/trailing_comma_in_arguments.rb +5 -5
  599. data/lib/rubocop/cop/style/trailing_comma_in_array_literal.rb +1 -1
  600. data/lib/rubocop/cop/style/trailing_comma_in_block_args.rb +2 -2
  601. data/lib/rubocop/cop/style/trailing_comma_in_hash_literal.rb +1 -1
  602. data/lib/rubocop/cop/style/trailing_method_end_statement.rb +1 -1
  603. data/lib/rubocop/cop/style/trailing_underscore_variable.rb +2 -2
  604. data/lib/rubocop/cop/style/trivial_accessors.rb +12 -10
  605. data/lib/rubocop/cop/style/unless_else.rb +1 -1
  606. data/lib/rubocop/cop/style/unless_logical_operators.rb +2 -1
  607. data/lib/rubocop/cop/style/unpack_first.rb +8 -5
  608. data/lib/rubocop/cop/style/variable_interpolation.rb +1 -1
  609. data/lib/rubocop/cop/style/when_then.rb +1 -1
  610. data/lib/rubocop/cop/style/word_array.rb +60 -6
  611. data/lib/rubocop/cop/style/yoda_condition.rb +14 -7
  612. data/lib/rubocop/cop/style/yoda_expression.rb +90 -0
  613. data/lib/rubocop/cop/style/zero_length_predicate.rb +41 -20
  614. data/lib/rubocop/cop/team.rb +65 -58
  615. data/lib/rubocop/cop/util.rb +44 -8
  616. data/lib/rubocop/cop/variable_force/assignment.rb +5 -1
  617. data/lib/rubocop/cop/variable_force/branch.rb +1 -1
  618. data/lib/rubocop/cop/variable_force/scope.rb +3 -3
  619. data/lib/rubocop/cop/variable_force/variable.rb +5 -3
  620. data/lib/rubocop/cop/variable_force/variable_table.rb +6 -4
  621. data/lib/rubocop/cop/variable_force.rb +18 -30
  622. data/lib/rubocop/cops_documentation_generator.rb +64 -17
  623. data/lib/rubocop/directive_comment.rb +4 -4
  624. data/lib/rubocop/ext/comment.rb +18 -0
  625. data/lib/rubocop/ext/processed_source.rb +2 -0
  626. data/lib/rubocop/ext/range.rb +15 -0
  627. data/lib/rubocop/ext/regexp_node.rb +1 -1
  628. data/lib/rubocop/ext/regexp_parser.rb +1 -1
  629. data/lib/rubocop/feature_loader.rb +94 -0
  630. data/lib/rubocop/file_patterns.rb +43 -0
  631. data/lib/rubocop/formatter/clang_style_formatter.rb +1 -1
  632. data/lib/rubocop/formatter/disabled_config_formatter.rb +36 -16
  633. data/lib/rubocop/formatter/formatter_set.rb +20 -18
  634. data/lib/rubocop/formatter/git_hub_actions_formatter.rb +15 -2
  635. data/lib/rubocop/formatter/html_formatter.rb +6 -14
  636. data/lib/rubocop/formatter/junit_formatter.rb +4 -1
  637. data/lib/rubocop/formatter/markdown_formatter.rb +78 -0
  638. data/lib/rubocop/formatter/offense_count_formatter.rb +10 -5
  639. data/lib/rubocop/formatter/simple_text_formatter.rb +9 -8
  640. data/lib/rubocop/formatter/tap_formatter.rb +1 -1
  641. data/lib/rubocop/formatter/worst_offenders_formatter.rb +6 -3
  642. data/lib/rubocop/formatter.rb +34 -0
  643. data/lib/rubocop/magic_comment.rb +31 -5
  644. data/lib/rubocop/options.rb +154 -49
  645. data/lib/rubocop/path_util.rb +50 -22
  646. data/lib/rubocop/rake_task.rb +34 -9
  647. data/lib/rubocop/result_cache.rb +28 -25
  648. data/lib/rubocop/rspec/cop_helper.rb +27 -4
  649. data/lib/rubocop/rspec/expect_offense.rb +9 -7
  650. data/lib/rubocop/rspec/parallel_formatter.rb +1 -1
  651. data/lib/rubocop/rspec/shared_contexts.rb +48 -11
  652. data/lib/rubocop/rspec/support.rb +17 -2
  653. data/lib/rubocop/runner.rb +106 -25
  654. data/lib/rubocop/server/cache.rb +155 -0
  655. data/lib/rubocop/server/cli.rb +147 -0
  656. data/lib/rubocop/server/client_command/base.rb +44 -0
  657. data/lib/rubocop/server/client_command/exec.rb +64 -0
  658. data/lib/rubocop/server/client_command/restart.rb +25 -0
  659. data/lib/rubocop/server/client_command/start.rb +48 -0
  660. data/lib/rubocop/server/client_command/status.rb +28 -0
  661. data/lib/rubocop/server/client_command/stop.rb +31 -0
  662. data/lib/rubocop/server/client_command.rb +26 -0
  663. data/lib/rubocop/server/core.rb +111 -0
  664. data/lib/rubocop/server/errors.rb +23 -0
  665. data/lib/rubocop/server/helper.rb +34 -0
  666. data/lib/rubocop/server/server_command/base.rb +50 -0
  667. data/lib/rubocop/server/server_command/exec.rb +34 -0
  668. data/lib/rubocop/server/server_command/stop.rb +24 -0
  669. data/lib/rubocop/server/server_command.rb +21 -0
  670. data/lib/rubocop/server/socket_reader.rb +69 -0
  671. data/lib/rubocop/server.rb +53 -0
  672. data/lib/rubocop/string_interpreter.rb +4 -4
  673. data/lib/rubocop/target_finder.rb +1 -1
  674. data/lib/rubocop/target_ruby.rb +16 -8
  675. data/lib/rubocop/version.rb +24 -11
  676. data/lib/rubocop.rb +59 -35
  677. metadata +114 -37
  678. data/lib/rubocop/cop/gemspec/date_assignment.rb +0 -49
  679. data/lib/rubocop/cop/mixin/ignored_methods.rb +0 -52
  680. data/lib/rubocop/cop/mixin/ignored_pattern.rb +0 -29
@@ -9,8 +9,8 @@ module RuboCop
9
9
  extend NodePattern::Macros
10
10
  include Util
11
11
 
12
- FOLDABLE_TYPES = %i[array hash heredoc].freeze
13
- CLASSLIKE_TYPES = %i[class module].freeze
12
+ FOLDABLE_TYPES = %i[array hash heredoc send csend].freeze
13
+ CLASSLIKE_TYPES = %i[class module sclass].freeze
14
14
  private_constant :FOLDABLE_TYPES, :CLASSLIKE_TYPES
15
15
 
16
16
  def initialize(node, processed_source, count_comments: false, foldable_types: [])
@@ -30,8 +30,8 @@ module RuboCop
30
30
 
31
31
  descendant_length = code_length(descendant)
32
32
  length = length - descendant_length + 1
33
- # Subtract 2 length of opening and closing brace if method argument omits hash braces.
34
- length -= 2 if descendant.hash_type? && !descendant.braces?
33
+ # Subtract length of opening and closing brace if method argument omits hash braces.
34
+ length -= omit_length(descendant) if descendant.hash_type? && !descendant.braces?
35
35
  end
36
36
 
37
37
  length
@@ -39,7 +39,7 @@ module RuboCop
39
39
 
40
40
  private
41
41
 
42
- def build_foldable_checks(types)
42
+ def build_foldable_checks(types) # rubocop:disable Metrics/MethodLength
43
43
  types.map do |type|
44
44
  case type
45
45
  when :array
@@ -48,15 +48,18 @@ module RuboCop
48
48
  ->(node) { node.hash_type? }
49
49
  when :heredoc
50
50
  ->(node) { heredoc_node?(node) }
51
+ when :method_call
52
+ ->(node) { node.call_type? }
51
53
  else
52
- raise ArgumentError, "Unknown foldable type: #{type.inspect}. "\
54
+ raise ArgumentError, "Unknown foldable type: #{type.inspect}. " \
53
55
  "Valid foldable types are: #{FOLDABLE_TYPES.join(', ')}."
54
56
  end
55
57
  end
56
58
  end
57
59
 
58
60
  def normalize_foldable_types(types)
59
- types.concat(%i[str dstr]) if types.delete(:heredoc)
61
+ types.push(:str, :dstr) if types.delete(:heredoc)
62
+ types.push(:send, :csend) if types.delete(:method_call)
60
63
  types
61
64
  end
62
65
 
@@ -153,6 +156,25 @@ module RuboCop
153
156
  def count_comments?
154
157
  @count_comments
155
158
  end
159
+
160
+ def omit_length(descendant)
161
+ parent = descendant.parent
162
+ return 0 if another_args?(parent)
163
+ return 0 unless parenthesized?(parent)
164
+
165
+ [
166
+ parent.loc.begin.end_pos != descendant.source_range.begin_pos,
167
+ parent.loc.end.begin_pos != descendant.source_range.end_pos
168
+ ].count(true)
169
+ end
170
+
171
+ def parenthesized?(node)
172
+ node.call_type? && node.parenthesized?
173
+ end
174
+
175
+ def another_args?(node)
176
+ node.call_type? && node.arguments.count > 1
177
+ end
156
178
  end
157
179
  end
158
180
  end
@@ -45,7 +45,7 @@ module RuboCop
45
45
  end
46
46
 
47
47
  def check_cop_name(name, comment, offset)
48
- start = comment.location.expression.begin_pos + offset
48
+ start = comment.source_range.begin_pos + offset
49
49
  range = range_between(start, start + name.length)
50
50
 
51
51
  add_offense(range) do |corrector|
@@ -12,7 +12,7 @@ module RuboCop
12
12
  attr_reader :column_delta
13
13
 
14
14
  def configured_indentation_width
15
- cop_config['IndentationWidth'] || config.for_cop('Layout/IndentationWidth')['Width']
15
+ cop_config['IndentationWidth'] || config.for_cop('Layout/IndentationWidth')['Width'] || 2
16
16
  end
17
17
 
18
18
  def indentation(node)
@@ -28,7 +28,7 @@ module RuboCop
28
28
 
29
29
  each_bad_alignment(items, base_column) do |current|
30
30
  expr = current.source_range
31
- if @current_offenses.any? { |o| within?(expr, o.location) }
31
+ if @current_offenses&.any? { |o| within?(expr, o.location) }
32
32
  # If this offense is within a line range that is already being
33
33
  # realigned by autocorrect, we report the offense without
34
34
  # autocorrecting it. Two rewrites in the same area by the same
@@ -7,11 +7,11 @@ module RuboCop
7
7
  SIGILS = '@$' # if a variable starts with a sigil it will be removed
8
8
 
9
9
  def allowed_identifier?(name)
10
- allowed_identifiers.include?(name.to_s.delete(SIGILS))
10
+ !allowed_identifiers.empty? && allowed_identifiers.include?(name.to_s.delete(SIGILS))
11
11
  end
12
12
 
13
13
  def allowed_identifiers
14
- cop_config.fetch('AllowedIdentifiers', [])
14
+ cop_config.fetch('AllowedIdentifiers') { [] }
15
15
  end
16
16
  end
17
17
  end
@@ -3,7 +3,9 @@
3
3
  module RuboCop
4
4
  module Cop
5
5
  # This module encapsulates the ability to allow certain methods when
6
- # parsing.
6
+ # parsing. Even if the code is in offense, if it contains methods
7
+ # that are allowed. This module is equivalent to the IgnoredMethods module,
8
+ # which will be deprecated in RuboCop 2.0.
7
9
  module AllowedMethods
8
10
  private
9
11
 
@@ -12,10 +14,29 @@ module RuboCop
12
14
  allowed_methods.include?(name.to_s)
13
15
  end
14
16
 
17
+ # @deprecated Use allowed_method? instead
18
+ alias ignored_method? allowed_method?
19
+
15
20
  # @api public
16
21
  def allowed_methods
17
- cop_config.fetch('AllowedMethods', [])
22
+ if cop_config_deprecated_values.any?(Regexp)
23
+ cop_config_allowed_methods
24
+ else
25
+ cop_config_allowed_methods + cop_config_deprecated_values
26
+ end
27
+ end
28
+
29
+ def cop_config_allowed_methods
30
+ @cop_config_allowed_methods ||= Array(cop_config.fetch('AllowedMethods', []))
31
+ end
32
+
33
+ def cop_config_deprecated_values
34
+ @cop_config_deprecated_values ||=
35
+ Array(cop_config.fetch('IgnoredMethods', [])) +
36
+ Array(cop_config.fetch('ExcludedMethods', []))
18
37
  end
19
38
  end
39
+ # @deprecated IgnoredMethods class has been replaced with AllowedMethods.
40
+ IgnoredMethods = AllowedMethods
20
41
  end
21
42
  end
@@ -0,0 +1,56 @@
1
+ # frozen_string_literal: true
2
+
3
+ module RuboCop
4
+ module Cop
5
+ # This module encapsulates the ability to ignore certain lines when
6
+ # parsing.
7
+ module AllowedPattern
8
+ private
9
+
10
+ def allowed_line?(line)
11
+ line = if line.respond_to?(:source_line)
12
+ line.source_line
13
+ elsif line.respond_to?(:node)
14
+ line.node.source_range.source_line
15
+ end
16
+
17
+ matches_allowed_pattern?(line)
18
+ end
19
+
20
+ # @deprecated Use allowed_line? instead
21
+ alias ignored_line? allowed_line?
22
+
23
+ def matches_allowed_pattern?(line)
24
+ allowed_patterns.any? { |pattern| Regexp.new(pattern).match?(line) }
25
+ end
26
+
27
+ # @deprecated Use matches_allowed_pattern?? instead
28
+ alias matches_ignored_pattern? matches_allowed_pattern?
29
+
30
+ def allowed_patterns
31
+ # Since there could be a pattern specified in the default config, merge the two
32
+ # arrays together.
33
+ if cop_config_deprecated_methods_values.any?(Regexp)
34
+ cop_config_patterns_values + cop_config_deprecated_methods_values
35
+ else
36
+ cop_config_patterns_values
37
+ end
38
+ end
39
+
40
+ def cop_config_patterns_values
41
+ @cop_config_patterns_values ||=
42
+ Array(cop_config.fetch('AllowedPatterns', [])) +
43
+ Array(cop_config.fetch('IgnoredPatterns', []))
44
+ end
45
+
46
+ def cop_config_deprecated_methods_values
47
+ @cop_config_deprecated_methods_values ||=
48
+ Array(cop_config.fetch('IgnoredMethods', [])) +
49
+ Array(cop_config.fetch('ExcludedMethods', []))
50
+ end
51
+ end
52
+
53
+ # @deprecated IgnoredPattern class has been replaced with AllowedPattern.
54
+ IgnoredPattern = AllowedPattern
55
+ end
56
+ end
@@ -29,7 +29,7 @@ module RuboCop
29
29
 
30
30
  # Returns the range bounds for just the annotation
31
31
  def bounds
32
- start = comment.loc.expression.begin_pos + margin.length
32
+ start = comment.source_range.begin_pos + margin.length
33
33
  length = [keyword, colon, space].reduce(0) { |len, elem| len + elem.to_s.length }
34
34
  [start, start + length]
35
35
  end
@@ -41,18 +41,25 @@ module RuboCop
41
41
  def split_comment(comment)
42
42
  # Sort keywords by reverse length so that if a keyword is in a phrase
43
43
  # but also on its own, both will match properly.
44
- keywords_regex = Regexp.new(
45
- Regexp.union(keywords.sort_by { |w| -w.length }).source,
46
- Regexp::IGNORECASE
47
- )
48
- regex = /^(# ?)(\b#{keywords_regex}\b)(\s*:)?(\s+)?(\S+)?/i
49
-
50
44
  match = comment.text.match(regex)
51
45
  return false unless match
52
46
 
53
47
  match.captures
54
48
  end
55
49
 
50
+ KEYWORDS_REGEX_CACHE = {} # rubocop:disable Style/MutableConstant
51
+ private_constant :KEYWORDS_REGEX_CACHE
52
+
53
+ def regex
54
+ KEYWORDS_REGEX_CACHE[keywords] ||= begin
55
+ keywords_regex = Regexp.new(
56
+ Regexp.union(keywords.sort_by { |w| -w.length }).source,
57
+ Regexp::IGNORECASE
58
+ )
59
+ /^(# ?)(\b#{keywords_regex}\b)(\s*:)?(\s+)?(\S+)?/i
60
+ end
61
+ end
62
+
56
63
  def keyword_appearance?
57
64
  keyword && (colon || space)
58
65
  end
@@ -46,6 +46,8 @@ module RuboCop
46
46
  if node.send_type?
47
47
  args = process_args(node.arguments)
48
48
  return extract_breakable_node_from_elements(node, args, max)
49
+ elsif node.def_type?
50
+ return extract_breakable_node_from_elements(node, node.arguments, max)
49
51
  elsif node.array_type? || node.hash_type?
50
52
  return extract_breakable_node_from_elements(node, node.children, max)
51
53
  end
@@ -216,7 +218,9 @@ module RuboCop
216
218
 
217
219
  # @api private
218
220
  def already_on_multiple_lines?(node)
219
- node.first_line != node.last_line
221
+ return node.first_line != node.arguments.last.last_line if node.def_type?
222
+
223
+ !node.single_line?
220
224
  end
221
225
  end
222
226
  end
@@ -36,7 +36,7 @@ module RuboCop
36
36
  length = calculator.calculate
37
37
  return if length <= max_length
38
38
 
39
- location = node.casgn_type? ? node.loc.name : node.loc.expression
39
+ location = node.casgn_type? ? node.loc.name : node.source_range
40
40
 
41
41
  add_offense(location, message: message(length, max_length)) { self.max = length }
42
42
  end
@@ -12,16 +12,32 @@ module RuboCop
12
12
  end
13
13
 
14
14
  def contains_comments?(node)
15
+ comments_in_range(node).any?
16
+ end
17
+
18
+ def comments_in_range(node)
15
19
  start_line = node.source_range.line
16
20
  end_line = find_end_line(node)
17
21
 
18
- processed_source.each_comment_in_lines(start_line...end_line).any?
22
+ processed_source.each_comment_in_lines(start_line...end_line)
23
+ end
24
+
25
+ def comments_contain_disables?(node, cop_name)
26
+ disabled_ranges = processed_source.disabled_line_ranges[cop_name]
27
+
28
+ return unless disabled_ranges
29
+
30
+ node_range = node.source_range.line...find_end_line(node)
31
+
32
+ disabled_ranges.any? do |disable_range|
33
+ disable_range.cover?(node_range) || node_range.cover?(disable_range)
34
+ end
19
35
  end
20
36
 
21
37
  private
22
38
 
23
39
  def end_position_for(node)
24
- end_line = buffer.line_for_position(node.loc.expression.end_pos)
40
+ end_line = buffer.line_for_position(node.source_range.end_pos)
25
41
  buffer.line_range(end_line).end_pos
26
42
  end
27
43
 
@@ -46,17 +62,25 @@ module RuboCop
46
62
  # Returns the end line of a node, which might be a comment and not part of the AST
47
63
  # End line is considered either the line at which another node starts, or
48
64
  # the line at which the parent node ends.
65
+ # rubocop:disable Metrics/AbcSize, Metrics/CyclomaticComplexity, Metrics/MethodLength, Metrics/PerceivedComplexity, Lint/DuplicateBranch
49
66
  def find_end_line(node)
50
- if node.if_type? && node.loc.else
67
+ if node.if_type? && node.else?
51
68
  node.loc.else.line
52
- elsif (next_sibling = node.right_sibling)
69
+ elsif node.if_type? && node.ternary?
70
+ node.else_branch.loc.line
71
+ elsif node.if_type? && node.elsif?
72
+ node.each_ancestor(:if).find(&:if?).loc.end.line
73
+ elsif node.block_type? || node.numblock_type?
74
+ node.loc.end.line
75
+ elsif (next_sibling = node.right_sibling) && next_sibling.is_a?(AST::Node)
53
76
  next_sibling.loc.line
54
77
  elsif (parent = node.parent)
55
- parent.loc.end.line
78
+ parent.loc.respond_to?(:end) && parent.loc.end ? parent.loc.end.line : parent.loc.line
56
79
  else
57
80
  node.loc.end.line
58
81
  end
59
82
  end
83
+ # rubocop:enable Metrics/AbcSize, Metrics/CyclomaticComplexity, Metrics/MethodLength, Metrics/PerceivedComplexity, Lint/DuplicateBranch
60
84
  end
61
85
  end
62
86
  end
@@ -20,19 +20,30 @@ module RuboCop
20
20
  style_detected(possibilities)
21
21
  end
22
22
 
23
+ SYMBOL_TO_STRING_CACHE = Hash.new do |hash, key|
24
+ hash[key] = key.to_s if key.is_a?(Symbol)
25
+ end
26
+ private_constant :SYMBOL_TO_STRING_CACHE
27
+
28
+ # rubocop:disable Metrics
23
29
  def style_detected(detected)
24
30
  return if no_acceptable_style?
25
31
 
26
- # `detected` can be a single style or an Array of possible styles
27
- # (if there is more than one which matches the observed code)
28
- detected_as_strings = Array(detected).map(&:to_s)
32
+ # This logic is more complex than it needs to be
33
+ # to avoid allocating Arrays in the hot code path.
34
+ updated_list =
35
+ if detected_style
36
+ if detected_style.size == 1 && detected_style.include?(SYMBOL_TO_STRING_CACHE[detected])
37
+ detected_style
38
+ else
39
+ detected_as_strings = SYMBOL_TO_STRING_CACHE.values_at(*detected)
40
+ detected_style & detected_as_strings
41
+ end
42
+ else
43
+ # We haven't observed any specific style yet.
44
+ SYMBOL_TO_STRING_CACHE.values_at(*detected)
45
+ end
29
46
 
30
- updated_list = if detected_style
31
- detected_style & detected_as_strings
32
- else
33
- # We haven't observed any specific style yet.
34
- detected_as_strings
35
- end
36
47
  if updated_list.empty?
37
48
  no_acceptable_style!
38
49
  else
@@ -40,6 +51,7 @@ module RuboCop
40
51
  config_to_allow_offenses[style_parameter_name] = updated_list.first
41
52
  end
42
53
  end
54
+ # rubocop:enable Metrics
43
55
 
44
56
  def no_acceptable_style?
45
57
  config_to_allow_offenses['Enabled'] == false
@@ -5,8 +5,7 @@ module RuboCop
5
5
  # Common functionality for checking def nodes.
6
6
  module DefNode
7
7
  extend NodePattern::Macros
8
-
9
- NON_PUBLIC_MODIFIERS = %w[private protected].freeze
8
+ include VisibilityHelp
10
9
 
11
10
  private
12
11
 
@@ -15,11 +14,7 @@ module RuboCop
15
14
  end
16
15
 
17
16
  def preceding_non_public_modifier?(node)
18
- stripped_source_upto(node.first_line).any? { |line| NON_PUBLIC_MODIFIERS.include?(line) }
19
- end
20
-
21
- def stripped_source_upto(index)
22
- processed_source[0..index].map(&:strip)
17
+ node_visibility(node) != :public
23
18
  end
24
19
 
25
20
  # @!method non_public_modifier?(node)
@@ -23,7 +23,7 @@ module RuboCop
23
23
  # The args node1 & node2 may represent a RuboCop::AST::Node
24
24
  # or a Parser::Source::Comment. Both respond to #loc.
25
25
  def preceding_comment?(node1, node2)
26
- node1 && node2 && precede?(node2, node1) && comment_line?(node2.loc.expression.source)
26
+ node1 && node2 && precede?(node2, node1) && comment_line?(node2.source)
27
27
  end
28
28
 
29
29
  # The args node1 & node2 may represent a RuboCop::AST::Node
@@ -29,7 +29,7 @@ module RuboCop
29
29
  # @param [Array] collection an array to return consecutive duplicates for
30
30
  # @return [Array] the consecutive duplicates
31
31
  def consecutive_duplicates(collection)
32
- grouped_duplicates(collection).flat_map { |items| items[1..-1] }
32
+ grouped_duplicates(collection).flat_map { |items| items[1..] }
33
33
  end
34
34
 
35
35
  # Returns a hash of grouped duplicates. The key will be the first
@@ -6,7 +6,8 @@ module RuboCop
6
6
  #
7
7
  # IMPORTANT: RuboCop core depended on this module when it supported Rails department.
8
8
  # Rails department has been extracted to RuboCop Rails gem.
9
- # This module is deprecated and will be removed by RuboCop 2.0.
9
+ #
10
+ # @deprecated This module is deprecated and will be removed by RuboCop 2.0.
10
11
  # It will not be updated to `RuboCop::Cop::Base` v1 API to maintain compatibility
11
12
  # with existing RuboCop Rails 2.8 or lower.
12
13
  #
@@ -7,12 +7,12 @@ module RuboCop
7
7
  module FirstElementLineBreak
8
8
  private
9
9
 
10
- def check_method_line_break(node, children)
10
+ def check_method_line_break(node, children, ignore_last: false)
11
11
  return if children.empty?
12
12
 
13
13
  return unless method_uses_parens?(node, children.first)
14
14
 
15
- check_children_line_break(node, children)
15
+ check_children_line_break(node, children, ignore_last: ignore_last)
16
16
  end
17
17
 
18
18
  def method_uses_parens?(node, limit)
@@ -20,7 +20,7 @@ module RuboCop
20
20
  /\s*\(\s*$/.match?(source)
21
21
  end
22
22
 
23
- def check_children_line_break(node, children, start = node)
23
+ def check_children_line_break(node, children, start = node, ignore_last: false)
24
24
  return if children.empty?
25
25
 
26
26
  line = start.first_line
@@ -28,8 +28,8 @@ module RuboCop
28
28
  min = first_by_line(children)
29
29
  return if line != min.first_line
30
30
 
31
- max = last_by_line(children)
32
- return if line == max.last_line
31
+ max_line = last_line(children, ignore_last: ignore_last)
32
+ return if line == max_line
33
33
 
34
34
  add_offense(min) { |corrector| EmptyLineCorrector.insert_before(corrector, min) }
35
35
  end
@@ -38,8 +38,12 @@ module RuboCop
38
38
  nodes.min_by(&:first_line)
39
39
  end
40
40
 
41
- def last_by_line(nodes)
42
- nodes.max_by(&:last_line)
41
+ def last_line(nodes, ignore_last:)
42
+ if ignore_last
43
+ nodes.map(&:first_line)
44
+ else
45
+ nodes.map(&:last_line)
46
+ end.max
43
47
  end
44
48
  end
45
49
  end
@@ -69,6 +69,10 @@ module RuboCop
69
69
  end
70
70
  end
71
71
 
72
+ def leading_magic_comments
73
+ leading_comment_lines.map { |line| MagicComment.parse(line) }
74
+ end
75
+
72
76
  def leading_comment_lines
73
77
  first_non_comment_token = processed_source.tokens.find { |token| !token.comment? }
74
78
 
@@ -33,7 +33,7 @@ module RuboCop
33
33
 
34
34
  def separator_delta(pair)
35
35
  if pair.hash_rocket?
36
- correct_separator_column = pair.key.loc.expression.end.column + 1
36
+ correct_separator_column = pair.key.source_range.end.column + 1
37
37
  actual_separator_column = pair.loc.operator.column
38
38
 
39
39
  correct_separator_column - actual_separator_column