rubocop 0.51.0 → 0.52.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 (360) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +1 -2
  3. data/config/default.yml +86 -10
  4. data/config/disabled.yml +9 -4
  5. data/config/enabled.yml +1105 -1006
  6. data/lib/rubocop.rb +30 -3
  7. data/lib/rubocop/ast/builder.rb +2 -0
  8. data/lib/rubocop/ast/node.rb +24 -2
  9. data/lib/rubocop/ast/node/args_node.rb +17 -0
  10. data/lib/rubocop/ast/node/array_node.rb +1 -1
  11. data/lib/rubocop/ast/node/mixin/basic_literal_node.rb +16 -0
  12. data/lib/rubocop/ast/node/send_node.rb +20 -0
  13. data/lib/rubocop/ast/node/str_node.rb +14 -0
  14. data/lib/rubocop/ast/node/symbol_node.rb +20 -0
  15. data/lib/rubocop/ast/traversal.rb +4 -4
  16. data/lib/rubocop/cli.rb +45 -4
  17. data/lib/rubocop/comment_config.rb +2 -5
  18. data/lib/rubocop/config.rb +42 -8
  19. data/lib/rubocop/config_loader.rb +39 -100
  20. data/lib/rubocop/config_loader_resolver.rb +99 -2
  21. data/lib/rubocop/cop/autocorrect_logic.rb +1 -1
  22. data/lib/rubocop/cop/bundler/duplicated_gem.rb +7 -7
  23. data/lib/rubocop/cop/bundler/insecure_protocol_source.rb +4 -3
  24. data/lib/rubocop/cop/bundler/ordered_gems.rb +2 -2
  25. data/lib/rubocop/cop/cop.rb +16 -46
  26. data/lib/rubocop/cop/gemspec/duplicated_assignment.rb +102 -0
  27. data/lib/rubocop/cop/gemspec/ordered_dependencies.rb +3 -2
  28. data/lib/rubocop/cop/gemspec/required_ruby_version.rb +87 -0
  29. data/lib/rubocop/cop/generator.rb +23 -4
  30. data/lib/rubocop/cop/internal_affairs.rb +1 -1
  31. data/lib/rubocop/cop/internal_affairs/node_destructuring.rb +46 -0
  32. data/lib/rubocop/cop/internal_affairs/node_type_predicate.rb +2 -2
  33. data/lib/rubocop/cop/internal_affairs/offense_location_keyword.rb +9 -8
  34. data/lib/rubocop/cop/internal_affairs/redundant_location_argument.rb +1 -1
  35. data/lib/rubocop/cop/internal_affairs/redundant_message_argument.rb +1 -1
  36. data/lib/rubocop/cop/layout/access_modifier_indentation.rb +4 -7
  37. data/lib/rubocop/cop/layout/align_hash.rb +16 -16
  38. data/lib/rubocop/cop/layout/align_parameters.rb +6 -12
  39. data/lib/rubocop/cop/layout/block_end_newline.rb +19 -5
  40. data/lib/rubocop/cop/layout/case_indentation.rb +14 -17
  41. data/lib/rubocop/cop/layout/class_structure.rb +306 -0
  42. data/lib/rubocop/cop/layout/closing_parenthesis_indentation.rb +1 -0
  43. data/lib/rubocop/cop/layout/comment_indentation.rb +39 -2
  44. data/lib/rubocop/cop/layout/dot_position.rb +22 -13
  45. data/lib/rubocop/cop/layout/else_alignment.rb +6 -6
  46. data/lib/rubocop/cop/layout/empty_line_between_defs.rb +17 -17
  47. data/lib/rubocop/cop/layout/empty_lines.rb +15 -1
  48. data/lib/rubocop/cop/layout/empty_lines_around_access_modifier.rb +3 -2
  49. data/lib/rubocop/cop/layout/empty_lines_around_arguments.rb +89 -0
  50. data/lib/rubocop/cop/layout/empty_lines_around_begin_body.rb +2 -2
  51. data/lib/rubocop/cop/layout/empty_lines_around_block_body.rb +4 -8
  52. data/lib/rubocop/cop/layout/empty_lines_around_class_body.rb +30 -5
  53. data/lib/rubocop/cop/layout/empty_lines_around_exception_handling_keywords.rb +7 -3
  54. data/lib/rubocop/cop/layout/empty_lines_around_method_body.rb +2 -2
  55. data/lib/rubocop/cop/layout/empty_lines_around_module_body.rb +22 -7
  56. data/lib/rubocop/cop/layout/end_of_line.rb +1 -1
  57. data/lib/rubocop/cop/layout/extra_spacing.rb +21 -24
  58. data/lib/rubocop/cop/layout/first_parameter_indentation.rb +4 -1
  59. data/lib/rubocop/cop/layout/indent_array.rb +67 -20
  60. data/lib/rubocop/cop/layout/indent_hash.rb +70 -25
  61. data/lib/rubocop/cop/layout/indent_heredoc.rb +51 -11
  62. data/lib/rubocop/cop/layout/indentation_width.rb +24 -17
  63. data/lib/rubocop/cop/layout/initial_indentation.rb +7 -5
  64. data/lib/rubocop/cop/layout/leading_comment_space.rb +2 -2
  65. data/lib/rubocop/cop/layout/multiline_array_brace_layout.rb +47 -14
  66. data/lib/rubocop/cop/layout/multiline_assignment_layout.rb +10 -9
  67. data/lib/rubocop/cop/layout/multiline_block_layout.rb +19 -16
  68. data/lib/rubocop/cop/layout/multiline_hash_brace_layout.rb +46 -13
  69. data/lib/rubocop/cop/layout/multiline_method_call_indentation.rb +9 -10
  70. data/lib/rubocop/cop/layout/multiline_method_definition_brace_layout.rb +4 -0
  71. data/lib/rubocop/cop/layout/rescue_ensure_alignment.rb +9 -3
  72. data/lib/rubocop/cop/layout/space_after_colon.rb +4 -4
  73. data/lib/rubocop/cop/layout/space_after_comma.rb +3 -3
  74. data/lib/rubocop/cop/layout/space_after_method_name.rb +4 -4
  75. data/lib/rubocop/cop/layout/space_after_semicolon.rb +8 -1
  76. data/lib/rubocop/cop/layout/space_around_block_parameters.rb +16 -19
  77. data/lib/rubocop/cop/layout/space_around_equals_in_parameter_default.rb +27 -16
  78. data/lib/rubocop/cop/layout/space_around_keyword.rb +13 -11
  79. data/lib/rubocop/cop/layout/space_around_operators.rb +26 -13
  80. data/lib/rubocop/cop/layout/space_before_block_braces.rb +10 -10
  81. data/lib/rubocop/cop/layout/space_before_comma.rb +12 -1
  82. data/lib/rubocop/cop/layout/space_before_comment.rb +2 -4
  83. data/lib/rubocop/cop/layout/space_before_first_arg.rb +4 -3
  84. data/lib/rubocop/cop/layout/space_before_semicolon.rb +1 -1
  85. data/lib/rubocop/cop/layout/space_in_lambda_literal.rb +6 -12
  86. data/lib/rubocop/cop/layout/space_inside_array_literal_brackets.rb +235 -0
  87. data/lib/rubocop/cop/layout/space_inside_array_percent_literal.rb +3 -3
  88. data/lib/rubocop/cop/layout/space_inside_block_braces.rb +87 -16
  89. data/lib/rubocop/cop/layout/space_inside_hash_literal_braces.rb +57 -34
  90. data/lib/rubocop/cop/layout/space_inside_parens.rb +31 -3
  91. data/lib/rubocop/cop/layout/space_inside_range_literal.rb +15 -15
  92. data/lib/rubocop/cop/layout/space_inside_reference_brackets.rb +81 -0
  93. data/lib/rubocop/cop/layout/space_inside_string_interpolation.rb +24 -13
  94. data/lib/rubocop/cop/layout/tab.rb +2 -2
  95. data/lib/rubocop/cop/layout/trailing_blank_lines.rb +7 -7
  96. data/lib/rubocop/cop/lint/ambiguous_block_association.rb +11 -20
  97. data/lib/rubocop/cop/lint/block_alignment.rb +26 -23
  98. data/lib/rubocop/cop/lint/boolean_symbol.rb +1 -1
  99. data/lib/rubocop/cop/lint/def_end_alignment.rb +5 -10
  100. data/lib/rubocop/cop/lint/else_layout.rb +2 -2
  101. data/lib/rubocop/cop/lint/end_alignment.rb +13 -14
  102. data/lib/rubocop/cop/lint/ineffective_access_modifier.rb +3 -4
  103. data/lib/rubocop/cop/lint/inherit_exception.rb +10 -14
  104. data/lib/rubocop/cop/lint/missing_cop_enable_directive.rb +81 -0
  105. data/lib/rubocop/cop/lint/nested_percent_literal.rb +58 -0
  106. data/lib/rubocop/cop/lint/non_local_exit_from_iterator.rb +2 -2
  107. data/lib/rubocop/cop/lint/parentheses_as_grouped_expression.rb +1 -1
  108. data/lib/rubocop/cop/lint/percent_string_array.rb +14 -14
  109. data/lib/rubocop/cop/lint/percent_symbol_array.rb +11 -11
  110. data/lib/rubocop/cop/lint/redundant_with_index.rb +6 -3
  111. data/lib/rubocop/cop/lint/redundant_with_object.rb +1 -1
  112. data/lib/rubocop/cop/lint/require_parentheses.rb +3 -1
  113. data/lib/rubocop/cop/lint/rescue_type.rb +3 -3
  114. data/lib/rubocop/cop/lint/script_permission.rb +1 -0
  115. data/lib/rubocop/cop/lint/shadowed_argument.rb +146 -0
  116. data/lib/rubocop/cop/lint/string_conversion_in_interpolation.rb +6 -6
  117. data/lib/rubocop/cop/lint/unneeded_disable.rb +29 -11
  118. data/lib/rubocop/cop/lint/unneeded_require_statement.rb +2 -1
  119. data/lib/rubocop/cop/lint/unneeded_splat_expansion.rb +43 -17
  120. data/lib/rubocop/cop/message_annotator.rb +4 -2
  121. data/lib/rubocop/cop/metrics/abc_size.rb +2 -2
  122. data/lib/rubocop/cop/metrics/class_length.rb +3 -1
  123. data/lib/rubocop/cop/metrics/cyclomatic_complexity.rb +2 -1
  124. data/lib/rubocop/cop/metrics/line_length.rb +2 -2
  125. data/lib/rubocop/cop/metrics/module_length.rb +3 -1
  126. data/lib/rubocop/cop/metrics/parameter_lists.rb +9 -2
  127. data/lib/rubocop/cop/metrics/perceived_complexity.rb +2 -1
  128. data/lib/rubocop/cop/mixin/documentation_comment.rb +1 -1
  129. data/lib/rubocop/cop/mixin/empty_lines_around_body.rb +7 -5
  130. data/lib/rubocop/cop/mixin/empty_parameter.rb +23 -0
  131. data/lib/rubocop/cop/mixin/end_keyword_alignment.rb +7 -3
  132. data/lib/rubocop/cop/mixin/heredoc.rb +19 -19
  133. data/lib/rubocop/cop/mixin/method_complexity.rb +32 -8
  134. data/lib/rubocop/cop/mixin/multiline_expression_indentation.rb +7 -3
  135. data/lib/rubocop/cop/mixin/multiline_literal_brace_layout.rb +6 -4
  136. data/lib/rubocop/cop/mixin/negative_conditional.rb +3 -0
  137. data/lib/rubocop/cop/mixin/ordered_gem_node.rb +16 -12
  138. data/lib/rubocop/cop/mixin/parentheses.rb +12 -0
  139. data/lib/rubocop/cop/mixin/space_after_punctuation.rb +8 -8
  140. data/lib/rubocop/cop/mixin/space_before_punctuation.rb +10 -10
  141. data/lib/rubocop/cop/mixin/statement_modifier.rb +7 -17
  142. data/lib/rubocop/cop/mixin/surrounding_space.rb +95 -8
  143. data/lib/rubocop/cop/mixin/too_many_lines.rb +2 -2
  144. data/lib/rubocop/cop/mixin/trailing_comma.rb +22 -14
  145. data/lib/rubocop/cop/mixin/unused_argument.rb +3 -40
  146. data/lib/rubocop/cop/naming/accessor_method_name.rb +20 -10
  147. data/lib/rubocop/cop/naming/ascii_identifiers.rb +33 -0
  148. data/lib/rubocop/cop/naming/binary_operator_parameter_name.rb +5 -4
  149. data/lib/rubocop/cop/naming/class_and_module_camel_case.rb +16 -12
  150. data/lib/rubocop/cop/naming/constant_name.rb +32 -3
  151. data/lib/rubocop/cop/naming/file_name.rb +19 -8
  152. data/lib/rubocop/cop/naming/heredoc_delimiter_case.rb +10 -16
  153. data/lib/rubocop/cop/naming/method_name.rb +20 -14
  154. data/lib/rubocop/cop/naming/predicate_name.rb +7 -3
  155. data/lib/rubocop/cop/naming/variable_name.rb +17 -2
  156. data/lib/rubocop/cop/naming/variable_number.rb +10 -27
  157. data/lib/rubocop/cop/offense.rb +6 -1
  158. data/lib/rubocop/cop/performance/case_when_splat.rb +2 -6
  159. data/lib/rubocop/cop/performance/casecmp.rb +5 -4
  160. data/lib/rubocop/cop/performance/compare_with_block.rb +13 -7
  161. data/lib/rubocop/cop/performance/count.rb +5 -4
  162. data/lib/rubocop/cop/performance/detect.rb +7 -4
  163. data/lib/rubocop/cop/performance/double_start_end_with.rb +2 -7
  164. data/lib/rubocop/cop/performance/end_with.rb +2 -2
  165. data/lib/rubocop/cop/performance/flat_map.rb +3 -2
  166. data/lib/rubocop/cop/performance/hash_each_methods.rb +41 -40
  167. data/lib/rubocop/cop/performance/lstrip_rstrip.rb +5 -4
  168. data/lib/rubocop/cop/performance/redundant_block_call.rb +22 -22
  169. data/lib/rubocop/cop/performance/redundant_match.rb +2 -2
  170. data/lib/rubocop/cop/performance/redundant_merge.rb +6 -4
  171. data/lib/rubocop/cop/performance/redundant_sort_by.rb +4 -4
  172. data/lib/rubocop/cop/performance/regexp_match.rb +3 -2
  173. data/lib/rubocop/cop/performance/size.rb +2 -2
  174. data/lib/rubocop/cop/performance/start_with.rb +2 -2
  175. data/lib/rubocop/cop/performance/string_replacement.rb +4 -4
  176. data/lib/rubocop/cop/performance/times_map.rb +14 -15
  177. data/lib/rubocop/cop/performance/uri_default_parser.rb +3 -3
  178. data/lib/rubocop/cop/rails/action_filter.rb +22 -0
  179. data/lib/rubocop/cop/rails/active_support_aliases.rb +2 -2
  180. data/lib/rubocop/cop/rails/application_job.rb +4 -2
  181. data/lib/rubocop/cop/rails/application_record.rb +4 -2
  182. data/lib/rubocop/cop/rails/create_table_with_timestamps.rb +82 -0
  183. data/lib/rubocop/cop/rails/delegate.rb +20 -25
  184. data/lib/rubocop/cop/rails/delegate_allow_blank.rb +2 -2
  185. data/lib/rubocop/cop/rails/environment_comparison.rb +66 -0
  186. data/lib/rubocop/cop/rails/exit.rb +7 -0
  187. data/lib/rubocop/cop/rails/has_and_belongs_to_many.rb +7 -0
  188. data/lib/rubocop/cop/rails/has_many_or_has_one_dependent.rb +6 -2
  189. data/lib/rubocop/cop/rails/http_positional_arguments.rb +36 -41
  190. data/lib/rubocop/cop/rails/inverse_of.rb +96 -0
  191. data/lib/rubocop/cop/rails/lexically_scoped_action_filter.rb +112 -0
  192. data/lib/rubocop/cop/rails/output.rb +9 -0
  193. data/lib/rubocop/cop/rails/output_safety.rb +14 -20
  194. data/lib/rubocop/cop/rails/pluralization_grammar.rb +8 -8
  195. data/lib/rubocop/cop/rails/presence.rb +105 -0
  196. data/lib/rubocop/cop/rails/read_write_attribute.rb +10 -10
  197. data/lib/rubocop/cop/rails/redundant_receiver_in_with_options.rb +91 -0
  198. data/lib/rubocop/cop/rails/relative_date_constant.rb +9 -9
  199. data/lib/rubocop/cop/rails/reversible_migration.rb +3 -4
  200. data/lib/rubocop/cop/rails/safe_navigation.rb +5 -6
  201. data/lib/rubocop/cop/rails/save_bang.rb +2 -2
  202. data/lib/rubocop/cop/rails/uniq_before_pluck.rb +1 -1
  203. data/lib/rubocop/cop/rails/validation.rb +7 -7
  204. data/lib/rubocop/cop/security/json_load.rb +4 -2
  205. data/lib/rubocop/cop/security/marshal_load.rb +4 -2
  206. data/lib/rubocop/cop/style/alias.rb +24 -26
  207. data/lib/rubocop/cop/style/and_or.rb +34 -28
  208. data/lib/rubocop/cop/style/array_join.rb +9 -0
  209. data/lib/rubocop/cop/style/ascii_comments.rb +24 -4
  210. data/lib/rubocop/cop/style/attr.rb +14 -4
  211. data/lib/rubocop/cop/style/auto_resource_cleanup.rb +5 -3
  212. data/lib/rubocop/cop/style/bare_percent_literals.rb +31 -10
  213. data/lib/rubocop/cop/style/block_comments.rb +14 -2
  214. data/lib/rubocop/cop/style/block_delimiters.rb +80 -15
  215. data/lib/rubocop/cop/style/braces_around_hash_parameters.rb +81 -48
  216. data/lib/rubocop/cop/style/case_equality.rb +12 -0
  217. data/lib/rubocop/cop/style/character_literal.rb +10 -0
  218. data/lib/rubocop/cop/style/class_and_module_children.rb +6 -2
  219. data/lib/rubocop/cop/style/class_check.rb +28 -9
  220. data/lib/rubocop/cop/style/class_methods.rb +8 -8
  221. data/lib/rubocop/cop/style/class_vars.rb +4 -3
  222. data/lib/rubocop/cop/style/collection_methods.rb +4 -2
  223. data/lib/rubocop/cop/style/colon_method_call.rb +16 -0
  224. data/lib/rubocop/cop/style/colon_method_definition.rb +36 -0
  225. data/lib/rubocop/cop/style/command_literal.rb +70 -21
  226. data/lib/rubocop/cop/style/comment_annotation.rb +35 -10
  227. data/lib/rubocop/cop/style/commented_keyword.rb +12 -9
  228. data/lib/rubocop/cop/style/conditional_assignment.rb +10 -12
  229. data/lib/rubocop/cop/style/copyright.rb +19 -20
  230. data/lib/rubocop/cop/style/date_time.rb +2 -2
  231. data/lib/rubocop/cop/style/def_with_parentheses.rb +27 -2
  232. data/lib/rubocop/cop/style/dir.rb +2 -2
  233. data/lib/rubocop/cop/style/documentation.rb +17 -2
  234. data/lib/rubocop/cop/style/each_for_simple_loop.rb +7 -7
  235. data/lib/rubocop/cop/style/each_with_object.rb +5 -5
  236. data/lib/rubocop/cop/style/empty_block_parameter.rb +47 -0
  237. data/lib/rubocop/cop/style/empty_case_condition.rb +2 -2
  238. data/lib/rubocop/cop/style/empty_else.rb +52 -22
  239. data/lib/rubocop/cop/style/empty_lambda_parameter.rb +43 -0
  240. data/lib/rubocop/cop/style/empty_literal.rb +17 -5
  241. data/lib/rubocop/cop/style/empty_method.rb +4 -10
  242. data/lib/rubocop/cop/style/encoding.rb +2 -1
  243. data/lib/rubocop/cop/style/eval_with_location.rb +146 -0
  244. data/lib/rubocop/cop/style/even_odd.rb +4 -2
  245. data/lib/rubocop/cop/style/extend_self.rb +92 -0
  246. data/lib/rubocop/cop/style/flip_flop.rb +11 -0
  247. data/lib/rubocop/cop/style/format_string.rb +29 -2
  248. data/lib/rubocop/cop/style/format_string_token.rb +15 -14
  249. data/lib/rubocop/cop/style/frozen_string_literal_comment.rb +4 -3
  250. data/lib/rubocop/cop/style/global_vars.rb +11 -1
  251. data/lib/rubocop/cop/style/hash_syntax.rb +44 -43
  252. data/lib/rubocop/cop/style/identical_conditional_branches.rb +8 -8
  253. data/lib/rubocop/cop/style/if_inside_else.rb +10 -10
  254. data/lib/rubocop/cop/style/if_unless_modifier.rb +7 -7
  255. data/lib/rubocop/cop/style/if_unless_modifier_of_if_unless.rb +2 -2
  256. data/lib/rubocop/cop/style/if_with_semicolon.rb +9 -0
  257. data/lib/rubocop/cop/style/implicit_runtime_error.rb +5 -5
  258. data/lib/rubocop/cop/style/infinite_loop.rb +2 -2
  259. data/lib/rubocop/cop/style/lambda.rb +23 -31
  260. data/lib/rubocop/cop/style/lambda_call.rb +15 -9
  261. data/lib/rubocop/cop/style/line_end_concatenation.rb +4 -4
  262. data/lib/rubocop/cop/style/method_call_with_args_parentheses.rb +2 -2
  263. data/lib/rubocop/cop/style/method_call_without_args_parentheses.rb +2 -2
  264. data/lib/rubocop/cop/style/method_def_parentheses.rb +4 -3
  265. data/lib/rubocop/cop/style/method_missing.rb +8 -8
  266. data/lib/rubocop/cop/style/min_max.rb +12 -12
  267. data/lib/rubocop/cop/style/missing_else.rb +5 -4
  268. data/lib/rubocop/cop/style/mixin_grouping.rb +29 -19
  269. data/lib/rubocop/cop/style/mixin_usage.rb +8 -10
  270. data/lib/rubocop/cop/style/module_function.rb +17 -5
  271. data/lib/rubocop/cop/style/multiline_if_modifier.rb +4 -4
  272. data/lib/rubocop/cop/style/multiline_if_then.rb +14 -13
  273. data/lib/rubocop/cop/style/multiline_memoization.rb +8 -14
  274. data/lib/rubocop/cop/style/mutable_constant.rb +12 -12
  275. data/lib/rubocop/cop/style/negated_if.rb +22 -30
  276. data/lib/rubocop/cop/style/negated_while.rb +1 -5
  277. data/lib/rubocop/cop/style/nested_parenthesized_calls.rb +18 -17
  278. data/lib/rubocop/cop/style/next.rb +39 -11
  279. data/lib/rubocop/cop/style/nil_comparison.rb +6 -6
  280. data/lib/rubocop/cop/style/non_nil_check.rb +25 -22
  281. data/lib/rubocop/cop/style/not.rb +14 -4
  282. data/lib/rubocop/cop/style/numeric_literal_prefix.rb +6 -6
  283. data/lib/rubocop/cop/style/numeric_literals.rb +7 -7
  284. data/lib/rubocop/cop/style/numeric_predicate.rb +14 -18
  285. data/lib/rubocop/cop/style/one_line_conditional.rb +4 -4
  286. data/lib/rubocop/cop/style/option_hash.rb +11 -14
  287. data/lib/rubocop/cop/style/or_assignment.rb +2 -2
  288. data/lib/rubocop/cop/style/parallel_assignment.rb +13 -13
  289. data/lib/rubocop/cop/style/parentheses_around_condition.rb +19 -3
  290. data/lib/rubocop/cop/style/percent_literal_delimiters.rb +24 -3
  291. data/lib/rubocop/cop/style/percent_q_literals.rb +27 -6
  292. data/lib/rubocop/cop/style/perl_backrefs.rb +7 -0
  293. data/lib/rubocop/cop/style/preferred_hash_methods.rb +6 -10
  294. data/lib/rubocop/cop/style/proc.rb +8 -0
  295. data/lib/rubocop/cop/style/raise_args.rb +8 -14
  296. data/lib/rubocop/cop/style/random_with_offset.rb +160 -0
  297. data/lib/rubocop/cop/style/redundant_begin.rb +14 -4
  298. data/lib/rubocop/cop/style/redundant_conditional.rb +9 -8
  299. data/lib/rubocop/cop/style/redundant_return.rb +5 -4
  300. data/lib/rubocop/cop/style/redundant_self.rb +25 -26
  301. data/lib/rubocop/cop/style/regexp_literal.rb +74 -21
  302. data/lib/rubocop/cop/style/rescue_modifier.rb +11 -0
  303. data/lib/rubocop/cop/style/rescue_standard_error.rb +122 -0
  304. data/lib/rubocop/cop/style/return_nil.rb +4 -8
  305. data/lib/rubocop/cop/style/safe_navigation.rb +20 -2
  306. data/lib/rubocop/cop/style/self_assignment.rb +13 -13
  307. data/lib/rubocop/cop/style/semicolon.rb +18 -8
  308. data/lib/rubocop/cop/style/send.rb +9 -0
  309. data/lib/rubocop/cop/style/signal_exception.rb +100 -0
  310. data/lib/rubocop/cop/style/single_line_block_params.rb +2 -2
  311. data/lib/rubocop/cop/style/single_line_methods.rb +20 -8
  312. data/lib/rubocop/cop/style/special_global_vars.rb +16 -11
  313. data/lib/rubocop/cop/style/stabby_lambda_parentheses.rb +7 -12
  314. data/lib/rubocop/cop/style/stderr_puts.rb +5 -3
  315. data/lib/rubocop/cop/style/string_hash_keys.rb +36 -0
  316. data/lib/rubocop/cop/style/string_literals.rb +22 -0
  317. data/lib/rubocop/cop/style/string_literals_in_interpolation.rb +2 -8
  318. data/lib/rubocop/cop/style/string_methods.rb +18 -7
  319. data/lib/rubocop/cop/style/symbol_array.rb +5 -9
  320. data/lib/rubocop/cop/style/symbol_proc.rb +5 -4
  321. data/lib/rubocop/cop/style/ternary_parentheses.rb +31 -40
  322. data/lib/rubocop/cop/style/trailing_body_on_method_definition.rb +101 -0
  323. data/lib/rubocop/cop/style/trailing_comma_in_arguments.rb +20 -6
  324. data/lib/rubocop/cop/style/trailing_comma_in_literal.rb +22 -7
  325. data/lib/rubocop/cop/style/trailing_method_end_statement.rb +95 -0
  326. data/lib/rubocop/cop/style/trailing_underscore_variable.rb +8 -4
  327. data/lib/rubocop/cop/style/trivial_accessors.rb +32 -10
  328. data/lib/rubocop/cop/style/unless_else.rb +15 -0
  329. data/lib/rubocop/cop/style/unneeded_capital_w.rb +17 -7
  330. data/lib/rubocop/cop/style/unneeded_interpolation.rb +14 -18
  331. data/lib/rubocop/cop/style/unneeded_percent_q.rb +13 -12
  332. data/lib/rubocop/cop/style/variable_interpolation.rb +20 -9
  333. data/lib/rubocop/cop/style/when_then.rb +13 -0
  334. data/lib/rubocop/cop/style/while_until_do.rb +26 -4
  335. data/lib/rubocop/cop/style/while_until_modifier.rb +25 -6
  336. data/lib/rubocop/cop/style/word_array.rb +4 -8
  337. data/lib/rubocop/cop/style/yoda_condition.rb +10 -16
  338. data/lib/rubocop/cop/style/zero_length_predicate.rb +23 -15
  339. data/lib/rubocop/cop/util.rb +42 -33
  340. data/lib/rubocop/cop/variable_force.rb +1 -1
  341. data/lib/rubocop/cop/variable_force/assignment.rb +4 -2
  342. data/lib/rubocop/cop/variable_force/scope.rb +1 -5
  343. data/lib/rubocop/cop/variable_force/variable.rb +1 -1
  344. data/lib/rubocop/formatter/disabled_config_formatter.rb +2 -3
  345. data/lib/rubocop/formatter/formatter_set.rb +2 -1
  346. data/lib/rubocop/formatter/json_formatter.rb +9 -3
  347. data/lib/rubocop/formatter/quiet_formatter.rb +13 -0
  348. data/lib/rubocop/node_pattern.rb +2 -3
  349. data/lib/rubocop/options.rb +8 -8
  350. data/lib/rubocop/path_util.rb +15 -3
  351. data/lib/rubocop/processed_source.rb +5 -2
  352. data/lib/rubocop/rspec/shared_contexts.rb +4 -0
  353. data/lib/rubocop/runner.rb +1 -1
  354. data/lib/rubocop/token.rb +74 -0
  355. data/lib/rubocop/version.rb +1 -1
  356. metadata +37 -10
  357. data/lib/rubocop/cop/internal_affairs/deprecated_positional_arguments.rb +0 -81
  358. data/lib/rubocop/cop/layout/space_inside_brackets.rb +0 -20
  359. data/lib/rubocop/cop/lint/rescue_without_error_class.rb +0 -41
  360. data/lib/rubocop/cop/mixin/space_inside.rb +0 -76
@@ -10,18 +10,18 @@ module RuboCop
10
10
  # # bad
11
11
  # class SomeClass
12
12
  # def SomeClass.class_method
13
- # ...
13
+ # # ...
14
14
  # end
15
15
  # end
16
16
  #
17
17
  # # good
18
18
  # class SomeClass
19
19
  # def self.class_method
20
- # ...
20
+ # # ...
21
21
  # end
22
22
  # end
23
23
  class ClassMethods < Cop
24
- MSG = 'Use `self.%s` instead of `%s.%s`.'.freeze
24
+ MSG = 'Use `self.%<method>s` instead of `%<class>s.%<method>s`.'.freeze
25
25
 
26
26
  def on_class(node)
27
27
  name, _superclass, body = *node
@@ -33,6 +33,10 @@ module RuboCop
33
33
  check(name, body)
34
34
  end
35
35
 
36
+ def autocorrect(node)
37
+ ->(corrector) { corrector.replace(node.loc.name, 'self') }
38
+ end
39
+
36
40
  private
37
41
 
38
42
  def check(name, node)
@@ -56,11 +60,7 @@ module RuboCop
56
60
  end
57
61
 
58
62
  def message(class_name, method_name)
59
- format(MSG, method_name, class_name, method_name)
60
- end
61
-
62
- def autocorrect(node)
63
- ->(corrector) { corrector.replace(node.loc.name, 'self') }
63
+ format(MSG, method: method_name, class: class_name)
64
64
  end
65
65
  end
66
66
  end
@@ -5,9 +5,10 @@ module RuboCop
5
5
  module Style
6
6
  # This cop checks for uses of class variables. Offenses
7
7
  # are signaled only on assignment to class variables to
8
- # reduced the number of offenses that would be reported.
8
+ # reduce the number of offenses that would be reported.
9
9
  class ClassVars < Cop
10
- MSG = 'Replace class var %s with a class instance var.'.freeze
10
+ MSG = 'Replace class var %<class_var>s with a class ' \
11
+ 'instance var.'.freeze
11
12
 
12
13
  def on_cvasgn(node)
13
14
  add_offense(node, location: :name)
@@ -15,7 +16,7 @@ module RuboCop
15
16
 
16
17
  def message(node)
17
18
  class_var, = *node
18
- format(MSG, class_var)
19
+ format(MSG, class_var: class_var)
19
20
  end
20
21
  end
21
22
  end
@@ -12,7 +12,7 @@ module RuboCop
12
12
  class CollectionMethods < Cop
13
13
  include MethodPreference
14
14
 
15
- MSG = 'Prefer `%s` over `%s`.'.freeze
15
+ MSG = 'Prefer `%<prefer>s` over `%<current>s`.'.freeze
16
16
 
17
17
  def on_block(node)
18
18
  check_method_node(node.send_node)
@@ -35,7 +35,9 @@ module RuboCop
35
35
  private
36
36
 
37
37
  def message(node)
38
- format(MSG, preferred_method(node.method_name), node.method_name)
38
+ format(MSG,
39
+ prefer: preferred_method(node.method_name),
40
+ current: node.method_name)
39
41
  end
40
42
 
41
43
  def check_method_node(node)
@@ -5,6 +5,18 @@ module RuboCop
5
5
  module Style
6
6
  # This cop checks for methods invoked via the :: operator instead
7
7
  # of the . operator (like FileUtils::rmdir instead of FileUtils.rmdir).
8
+ #
9
+ # @example
10
+ # # bad
11
+ # Timeout::timeout(500) { do_something }
12
+ # FileUtils::rmdir(dir)
13
+ # Marshal::dump(obj)
14
+ #
15
+ # # good
16
+ # Timeout.timeout(500) { do_something }
17
+ # FileUtils.rmdir(dir)
18
+ # Marshal.dump(obj)
19
+ #
8
20
  class ColonMethodCall < Cop
9
21
  MSG = 'Do not use `::` for method calls.'.freeze
10
22
 
@@ -14,6 +26,10 @@ module RuboCop
14
26
  {:boolean :byte :char :double :float :int :long :short})
15
27
  PATTERN
16
28
 
29
+ def self.autocorrect_incompatible_with
30
+ [RedundantSelf]
31
+ end
32
+
17
33
  def on_send(node)
18
34
  # ignore Java interop code like Java::int
19
35
  return if java_type_node?(node)
@@ -0,0 +1,36 @@
1
+ # frozen_string_literal: true
2
+
3
+ module RuboCop
4
+ module Cop
5
+ module Style
6
+ # This cop checks for class methods that are defined using the `::`
7
+ # operator instead of the `.` operator.
8
+ #
9
+ # @example
10
+ # # bad
11
+ # class Foo
12
+ # def self::bar
13
+ # end
14
+ # end
15
+ #
16
+ # # good
17
+ # class Foo
18
+ # def self.bar
19
+ # end
20
+ # end
21
+ #
22
+ class ColonMethodDefinition < Cop
23
+ MSG = 'Do not use `::` for defining class methods.'.freeze
24
+
25
+ def on_defs(node)
26
+ return unless node.loc.operator.source == '::'
27
+ add_offense(node, location: :operator)
28
+ end
29
+
30
+ def autocorrect(node)
31
+ ->(corrector) { corrector.replace(node.loc.operator, '.') }
32
+ end
33
+ end
34
+ end
35
+ end
36
+ end
@@ -5,26 +5,75 @@ module RuboCop
5
5
  module Style
6
6
  # This cop enforces using `` or %x around command literals.
7
7
  #
8
- # @example
9
- # # Good if EnforcedStyle is backticks or mixed, bad if percent_x.
8
+ # @example EnforcedStyle: backticks (default)
9
+ # # bad
10
+ # folders = %x(find . -type d).split
11
+ #
12
+ # # bad
13
+ # %x(
14
+ # ln -s foo.example.yml foo.example
15
+ # ln -s bar.example.yml bar.example
16
+ # )
17
+ #
18
+ # # good
10
19
  # folders = `find . -type d`.split
11
20
  #
12
- # # Good if EnforcedStyle is percent_x, bad if backticks or mixed.
21
+ # # good
22
+ # `
23
+ # ln -s foo.example.yml foo.example
24
+ # ln -s bar.example.yml bar.example
25
+ # `
26
+ #
27
+ # @example EnforcedStyle: mixed
28
+ # # bad
13
29
  # folders = %x(find . -type d).split
14
30
  #
15
- # # Good if EnforcedStyle is backticks, bad if percent_x or mixed.
31
+ # # bad
16
32
  # `
17
33
  # ln -s foo.example.yml foo.example
18
34
  # ln -s bar.example.yml bar.example
19
35
  # `
20
36
  #
21
- # # Good if EnforcedStyle is percent_x or mixed, bad if backticks.
37
+ # # good
38
+ # folders = `find . -type d`.split
39
+ #
40
+ # # good
22
41
  # %x(
23
42
  # ln -s foo.example.yml foo.example
24
43
  # ln -s bar.example.yml bar.example
25
44
  # )
26
45
  #
27
- # # Bad unless AllowInnerBackticks is true.
46
+ # @example EnforcedStyle: percent_x
47
+ # # bad
48
+ # folders = `find . -type d`.split
49
+ #
50
+ # # bad
51
+ # `
52
+ # ln -s foo.example.yml foo.example
53
+ # ln -s bar.example.yml bar.example
54
+ # `
55
+ #
56
+ # # good
57
+ # folders = %x(find . -type d).split
58
+ #
59
+ # # good
60
+ # %x(
61
+ # ln -s foo.example.yml foo.example
62
+ # ln -s bar.example.yml bar.example
63
+ # )
64
+ #
65
+ # @example AllowInnerBackticks: false (default)
66
+ # # If `false`, the cop will always recommend using `%x` if one or more
67
+ # # backticks are found in the command string.
68
+ #
69
+ # # bad
70
+ # `echo \`ls\``
71
+ #
72
+ # # good
73
+ # %x(echo `ls`)
74
+ #
75
+ # @example AllowInnerBackticks: true
76
+ # # good
28
77
  # `echo \`ls\``
29
78
  class CommandLiteral < Cop
30
79
  include ConfigurableEnforcedStyle
@@ -42,6 +91,21 @@ module RuboCop
42
91
  end
43
92
  end
44
93
 
94
+ def autocorrect(node)
95
+ return if contains_backtick?(node)
96
+
97
+ replacement = if backtick_literal?(node)
98
+ ['%x', ''].zip(preferred_delimiters).map(&:join)
99
+ else
100
+ %w[` `]
101
+ end
102
+
103
+ lambda do |corrector|
104
+ corrector.replace(node.loc.begin, replacement.first)
105
+ corrector.replace(node.loc.end, replacement.last)
106
+ end
107
+ end
108
+
45
109
  private
46
110
 
47
111
  def check_backtick_literal(node)
@@ -109,21 +173,6 @@ module RuboCop
109
173
  config.for_cop('Style/PercentLiteralDelimiters') \
110
174
  ['PreferredDelimiters']['%x'].split(//)
111
175
  end
112
-
113
- def autocorrect(node)
114
- return if contains_backtick?(node)
115
-
116
- replacement = if backtick_literal?(node)
117
- ['%x', ''].zip(preferred_delimiters).map(&:join)
118
- else
119
- %w[` `]
120
- end
121
-
122
- lambda do |corrector|
123
- corrector.replace(node.loc.begin, replacement.first)
124
- corrector.replace(node.loc.end, replacement.last)
125
- end
126
- end
127
176
  end
128
177
  end
129
178
  end
@@ -5,13 +5,38 @@ module RuboCop
5
5
  module Style
6
6
  # This cop checks that comment annotation keywords are written according
7
7
  # to guidelines.
8
+ #
9
+ # @example
10
+ # # bad
11
+ # # TODO make better
12
+ #
13
+ # # good
14
+ # # TODO: make better
15
+ #
16
+ # # bad
17
+ # # TODO:make better
18
+ #
19
+ # # good
20
+ # # TODO: make better
21
+ #
22
+ # # bad
23
+ # # fixme: does not work
24
+ #
25
+ # # good
26
+ # # FIXME: does not work
27
+ #
28
+ # # bad
29
+ # # Optimize does not work
30
+ #
31
+ # # good
32
+ # # OPTIMIZE: does not work
8
33
  class CommentAnnotation < Cop
9
34
  include AnnotationComment
10
35
 
11
- MSG = 'Annotation keywords like `%s` should be all upper case, ' \
12
- 'followed by a colon, and a space, ' \
36
+ MSG = 'Annotation keywords like `%<keyword>s` should be all ' \
37
+ 'upper case, followed by a colon, and a space, ' \
13
38
  'then a note describing the problem.'.freeze
14
- MISSING_NOTE = 'Annotation comment, with keyword `%s`, ' \
39
+ MISSING_NOTE = 'Annotation comment, with keyword `%<keyword>s`, ' \
15
40
  'is missing a note.'.freeze
16
41
 
17
42
  def investigate(processed_source)
@@ -26,17 +51,11 @@ module RuboCop
26
51
  add_offense(
27
52
  comment,
28
53
  location: annotation_range(comment, margin, length),
29
- message: format(note ? MSG : MISSING_NOTE, first_word)
54
+ message: format(note ? MSG : MISSING_NOTE, keyword: first_word)
30
55
  )
31
56
  end
32
57
  end
33
58
 
34
- private
35
-
36
- def first_comment_line?(comments, ix)
37
- ix.zero? || comments[ix - 1].loc.line < comments[ix].loc.line - 1
38
- end
39
-
40
59
  def autocorrect(comment)
41
60
  margin, first_word, colon, space, note = split_comment(comment)
42
61
  return if note.nil?
@@ -47,6 +66,12 @@ module RuboCop
47
66
  ->(corrector) { corrector.replace(range, "#{first_word.upcase}: ") }
48
67
  end
49
68
 
69
+ private
70
+
71
+ def first_comment_line?(comments, ix)
72
+ ix.zero? || comments[ix - 1].loc.line < comments[ix].loc.line - 1
73
+ end
74
+
50
75
  def annotation_range(comment, margin, length)
51
76
  start = comment.loc.expression.begin_pos + margin.length
52
77
  range_between(start, start + length)
@@ -29,23 +29,25 @@ module RuboCop
29
29
  # end
30
30
  #
31
31
  # # good
32
- # class x # :nodoc:
32
+ # class X # :nodoc:
33
33
  # y
34
34
  # end
35
35
  class CommentedKeyword < Cop
36
36
  MSG = 'Do not place comments on the same line as the ' \
37
- '`%s` keyword.'.freeze
37
+ '`%<keyword>s` keyword.'.freeze
38
38
 
39
39
  def investigate(processed_source)
40
40
  heredoc_lines = extract_heredoc_lines(processed_source.ast)
41
41
 
42
- processed_source.lines.each_with_index do |line, index|
43
- next if heredoc_lines.any? { |r| r.include?(index + 1) }
42
+ processed_source.comments.each do |comment|
43
+ location = comment.location
44
+ line_position = location.line
45
+ line = processed_source.lines[line_position - 1]
46
+ next if heredoc_lines.any? { |r| r.include?(line_position) }
44
47
  next unless offensive?(line)
45
-
46
48
  range = source_range(processed_source.buffer,
47
- index + 1,
48
- (line.index('#'))...(line.length))
49
+ line_position,
50
+ (location.column)...(location.last_column))
49
51
 
50
52
  add_offense(range, location: range)
51
53
  end
@@ -57,14 +59,15 @@ module RuboCop
57
59
  ALLOWED_COMMENTS = %w[:nodoc: rubocop:disable].freeze
58
60
 
59
61
  def offensive?(line)
60
- KEYWORDS.any? { |k| line =~ /^\s*#{k}\s+.*#/ } &&
62
+ line = line.lstrip
63
+ line.start_with?(*KEYWORDS) &&
61
64
  ALLOWED_COMMENTS.none? { |c| line =~ /#\s*#{c}/ }
62
65
  end
63
66
 
64
67
  def message(node)
65
68
  line = node.source_line
66
69
  keyword = /^\s*(\S+).*#/.match(line)[1]
67
- format(MSG, keyword)
70
+ format(MSG, keyword: keyword)
68
71
  end
69
72
 
70
73
  def extract_heredoc_lines(ast)
@@ -108,9 +108,7 @@ module RuboCop
108
108
  # assignment to the same variable when using the return of the
109
109
  # condition can be used instead.
110
110
  #
111
- # @example
112
- # EnforcedStyle: assign_to_condition
113
- #
111
+ # @example EnforcedStyle: assign_to_condition (default)
114
112
  # # bad
115
113
  # if foo
116
114
  # bar = 1
@@ -155,7 +153,7 @@ module RuboCop
155
153
  # 2
156
154
  # end
157
155
  #
158
- # EnforcedStyle: assign_inside_condition
156
+ # @example EnforcedStyle: assign_inside_condition
159
157
  # # bad
160
158
  # bar = if foo
161
159
  # 1
@@ -268,6 +266,14 @@ module RuboCop
268
266
  check_node(node, branches)
269
267
  end
270
268
 
269
+ def autocorrect(node)
270
+ if assignment_type?(node)
271
+ move_assignment_inside_condition(node)
272
+ else
273
+ move_assignment_outside_condition(node)
274
+ end
275
+ end
276
+
271
277
  private
272
278
 
273
279
  def check_assignment_to_condition(node)
@@ -300,14 +306,6 @@ module RuboCop
300
306
  single_line_conditions_only? && branches.any?(&:begin_type?)
301
307
  end
302
308
 
303
- def autocorrect(node)
304
- if assignment_type?(node)
305
- move_assignment_inside_condition(node)
306
- else
307
- move_assignment_outside_condition(node)
308
- end
309
- end
310
-
311
309
  def assignment_node(node)
312
310
  *_variable, assignment = *node
313
311