rubocop 0.49.1 → 0.52.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (506) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +6 -9
  3. data/bin/rubocop +1 -1
  4. data/config/default.yml +264 -118
  5. data/config/disabled.yml +13 -9
  6. data/config/enabled.yml +1156 -918
  7. data/lib/rubocop.rb +555 -489
  8. data/lib/rubocop/ast/builder.rb +6 -1
  9. data/lib/rubocop/ast/node.rb +68 -52
  10. data/lib/rubocop/ast/node/args_node.rb +15 -10
  11. data/lib/rubocop/ast/node/array_node.rb +10 -1
  12. data/lib/rubocop/ast/node/block_node.rb +9 -0
  13. data/lib/rubocop/ast/node/def_node.rb +71 -0
  14. data/lib/rubocop/ast/node/for_node.rb +8 -0
  15. data/lib/rubocop/ast/node/if_node.rb +10 -2
  16. data/lib/rubocop/ast/node/mixin/basic_literal_node.rb +16 -0
  17. data/lib/rubocop/ast/node/mixin/collection_node.rb +15 -0
  18. data/lib/rubocop/ast/node/mixin/method_dispatch_node.rb +174 -0
  19. data/lib/rubocop/ast/node/mixin/method_identifier_predicates.rb +89 -0
  20. data/lib/rubocop/ast/node/mixin/parameterized_node.rb +18 -31
  21. data/lib/rubocop/ast/node/regexp_node.rb +35 -0
  22. data/lib/rubocop/ast/node/send_node.rb +21 -150
  23. data/lib/rubocop/ast/node/str_node.rb +14 -0
  24. data/lib/rubocop/ast/node/super_node.rb +3 -24
  25. data/lib/rubocop/ast/node/symbol_node.rb +20 -0
  26. data/lib/rubocop/ast/node/yield_node.rb +21 -0
  27. data/lib/rubocop/ast/traversal.rb +7 -7
  28. data/lib/rubocop/cached_data.rb +1 -6
  29. data/lib/rubocop/cli.rb +59 -13
  30. data/lib/rubocop/comment_config.rb +2 -5
  31. data/lib/rubocop/config.rb +136 -29
  32. data/lib/rubocop/config_loader.rb +61 -104
  33. data/lib/rubocop/config_loader_resolver.rb +102 -4
  34. data/lib/rubocop/cop/autocorrect_logic.rb +1 -1
  35. data/lib/rubocop/cop/bundler/duplicated_gem.rb +13 -11
  36. data/lib/rubocop/cop/bundler/insecure_protocol_source.rb +67 -0
  37. data/lib/rubocop/cop/bundler/ordered_gems.rb +7 -58
  38. data/lib/rubocop/cop/commissioner.rb +6 -3
  39. data/lib/rubocop/cop/cop.rb +11 -6
  40. data/lib/rubocop/cop/gemspec/duplicated_assignment.rb +102 -0
  41. data/lib/rubocop/cop/gemspec/ordered_dependencies.rb +97 -0
  42. data/lib/rubocop/cop/gemspec/required_ruby_version.rb +87 -0
  43. data/lib/rubocop/cop/generator.rb +122 -25
  44. data/lib/rubocop/cop/internal_affairs.rb +6 -2
  45. data/lib/rubocop/cop/internal_affairs/node_destructuring.rb +46 -0
  46. data/lib/rubocop/cop/internal_affairs/node_type_predicate.rb +16 -5
  47. data/lib/rubocop/cop/internal_affairs/offense_location_keyword.rb +54 -0
  48. data/lib/rubocop/cop/internal_affairs/redundant_location_argument.rb +59 -0
  49. data/lib/rubocop/cop/internal_affairs/redundant_message_argument.rb +71 -0
  50. data/lib/rubocop/cop/internal_affairs/useless_message_assertion.rb +3 -3
  51. data/lib/rubocop/cop/layout/access_modifier_indentation.rb +6 -10
  52. data/lib/rubocop/cop/layout/align_array.rb +2 -2
  53. data/lib/rubocop/cop/layout/align_hash.rb +18 -18
  54. data/lib/rubocop/cop/layout/align_parameters.rb +11 -23
  55. data/lib/rubocop/cop/layout/block_end_newline.rb +20 -6
  56. data/lib/rubocop/cop/layout/case_indentation.rb +15 -18
  57. data/lib/rubocop/cop/layout/class_structure.rb +306 -0
  58. data/lib/rubocop/cop/layout/closing_parenthesis_indentation.rb +7 -6
  59. data/lib/rubocop/cop/layout/comment_indentation.rb +42 -3
  60. data/lib/rubocop/cop/layout/dot_position.rb +31 -13
  61. data/lib/rubocop/cop/layout/else_alignment.rb +37 -17
  62. data/lib/rubocop/cop/layout/empty_line_after_magic_comment.rb +1 -1
  63. data/lib/rubocop/cop/layout/empty_line_between_defs.rb +22 -18
  64. data/lib/rubocop/cop/layout/empty_lines.rb +16 -2
  65. data/lib/rubocop/cop/layout/empty_lines_around_access_modifier.rb +23 -6
  66. data/lib/rubocop/cop/layout/empty_lines_around_arguments.rb +89 -0
  67. data/lib/rubocop/cop/layout/empty_lines_around_begin_body.rb +2 -2
  68. data/lib/rubocop/cop/layout/empty_lines_around_block_body.rb +4 -8
  69. data/lib/rubocop/cop/layout/empty_lines_around_class_body.rb +30 -5
  70. data/lib/rubocop/cop/layout/empty_lines_around_exception_handling_keywords.rb +10 -6
  71. data/lib/rubocop/cop/layout/empty_lines_around_method_body.rb +5 -5
  72. data/lib/rubocop/cop/layout/empty_lines_around_module_body.rb +22 -7
  73. data/lib/rubocop/cop/layout/end_of_line.rb +2 -2
  74. data/lib/rubocop/cop/layout/extra_spacing.rb +23 -26
  75. data/lib/rubocop/cop/layout/first_method_parameter_line_break.rb +3 -3
  76. data/lib/rubocop/cop/layout/first_parameter_indentation.rb +9 -3
  77. data/lib/rubocop/cop/layout/indent_array.rb +68 -21
  78. data/lib/rubocop/cop/layout/indent_hash.rb +71 -26
  79. data/lib/rubocop/cop/layout/indent_heredoc.rb +70 -35
  80. data/lib/rubocop/cop/layout/indentation_consistency.rb +1 -2
  81. data/lib/rubocop/cop/layout/indentation_width.rb +40 -27
  82. data/lib/rubocop/cop/layout/initial_indentation.rb +10 -7
  83. data/lib/rubocop/cop/layout/leading_comment_space.rb +32 -17
  84. data/lib/rubocop/cop/layout/multiline_array_brace_layout.rb +47 -14
  85. data/lib/rubocop/cop/layout/multiline_assignment_layout.rb +12 -11
  86. data/lib/rubocop/cop/layout/multiline_block_layout.rb +19 -16
  87. data/lib/rubocop/cop/layout/multiline_hash_brace_layout.rb +46 -13
  88. data/lib/rubocop/cop/layout/multiline_method_call_indentation.rb +29 -27
  89. data/lib/rubocop/cop/layout/multiline_method_definition_brace_layout.rb +7 -3
  90. data/lib/rubocop/cop/layout/multiline_operation_indentation.rb +6 -0
  91. data/lib/rubocop/cop/layout/rescue_ensure_alignment.rb +12 -4
  92. data/lib/rubocop/cop/layout/space_after_colon.rb +13 -6
  93. data/lib/rubocop/cop/layout/space_after_comma.rb +11 -1
  94. data/lib/rubocop/cop/layout/space_after_method_name.rb +8 -6
  95. data/lib/rubocop/cop/layout/space_after_not.rb +1 -1
  96. data/lib/rubocop/cop/layout/space_after_semicolon.rb +8 -1
  97. data/lib/rubocop/cop/layout/space_around_block_parameters.rb +32 -25
  98. data/lib/rubocop/cop/layout/space_around_equals_in_parameter_default.rb +28 -17
  99. data/lib/rubocop/cop/layout/space_around_keyword.rb +22 -16
  100. data/lib/rubocop/cop/layout/space_around_operators.rb +27 -14
  101. data/lib/rubocop/cop/layout/space_before_block_braces.rb +61 -12
  102. data/lib/rubocop/cop/layout/space_before_comma.rb +12 -1
  103. data/lib/rubocop/cop/layout/space_before_comment.rb +10 -5
  104. data/lib/rubocop/cop/layout/space_before_first_arg.rb +5 -4
  105. data/lib/rubocop/cop/layout/space_before_semicolon.rb +8 -1
  106. data/lib/rubocop/cop/layout/space_in_lambda_literal.rb +12 -14
  107. data/lib/rubocop/cop/layout/space_inside_array_literal_brackets.rb +235 -0
  108. data/lib/rubocop/cop/layout/space_inside_array_percent_literal.rb +4 -4
  109. data/lib/rubocop/cop/layout/space_inside_block_braces.rb +89 -18
  110. data/lib/rubocop/cop/layout/space_inside_hash_literal_braces.rb +62 -36
  111. data/lib/rubocop/cop/layout/space_inside_parens.rb +40 -3
  112. data/lib/rubocop/cop/layout/space_inside_percent_literal_delimiters.rb +1 -1
  113. data/lib/rubocop/cop/layout/space_inside_range_literal.rb +15 -15
  114. data/lib/rubocop/cop/layout/space_inside_reference_brackets.rb +81 -0
  115. data/lib/rubocop/cop/layout/space_inside_string_interpolation.rb +32 -17
  116. data/lib/rubocop/cop/layout/tab.rb +7 -4
  117. data/lib/rubocop/cop/layout/trailing_blank_lines.rb +11 -9
  118. data/lib/rubocop/cop/layout/trailing_whitespace.rb +1 -1
  119. data/lib/rubocop/cop/lint/ambiguous_block_association.rb +12 -19
  120. data/lib/rubocop/cop/lint/assignment_in_condition.rb +16 -2
  121. data/lib/rubocop/cop/lint/block_alignment.rb +42 -30
  122. data/lib/rubocop/cop/lint/boolean_symbol.rb +38 -0
  123. data/lib/rubocop/cop/lint/circular_argument_reference.rb +3 -14
  124. data/lib/rubocop/cop/lint/condition_position.rb +5 -1
  125. data/lib/rubocop/cop/lint/debugger.rb +18 -11
  126. data/lib/rubocop/cop/lint/def_end_alignment.rb +9 -14
  127. data/lib/rubocop/cop/lint/deprecated_class_methods.rb +4 -4
  128. data/lib/rubocop/cop/lint/duplicate_case_condition.rb +3 -3
  129. data/lib/rubocop/cop/lint/duplicate_methods.rb +75 -5
  130. data/lib/rubocop/cop/lint/duplicated_key.rb +1 -1
  131. data/lib/rubocop/cop/lint/each_with_object_argument.rb +1 -1
  132. data/lib/rubocop/cop/lint/else_layout.rb +3 -3
  133. data/lib/rubocop/cop/lint/empty_ensure.rb +1 -1
  134. data/lib/rubocop/cop/lint/empty_expression.rb +1 -1
  135. data/lib/rubocop/cop/lint/empty_interpolation.rb +1 -1
  136. data/lib/rubocop/cop/lint/empty_when.rb +1 -1
  137. data/lib/rubocop/cop/lint/end_alignment.rb +13 -14
  138. data/lib/rubocop/cop/lint/end_in_method.rb +1 -1
  139. data/lib/rubocop/cop/lint/ensure_return.rb +1 -1
  140. data/lib/rubocop/cop/lint/float_out_of_range.rb +5 -5
  141. data/lib/rubocop/cop/lint/format_parameter_mismatch.rb +36 -41
  142. data/lib/rubocop/cop/lint/handle_exceptions.rb +1 -1
  143. data/lib/rubocop/cop/lint/implicit_string_concatenation.rb +1 -1
  144. data/lib/rubocop/cop/lint/ineffective_access_modifier.rb +25 -20
  145. data/lib/rubocop/cop/lint/inherit_exception.rb +16 -19
  146. data/lib/rubocop/cop/lint/interpolation_check.rb +37 -0
  147. data/lib/rubocop/cop/lint/{literal_in_condition.rb → literal_as_condition.rb} +21 -7
  148. data/lib/rubocop/cop/lint/literal_in_interpolation.rb +1 -1
  149. data/lib/rubocop/cop/lint/loop.rb +1 -1
  150. data/lib/rubocop/cop/lint/missing_cop_enable_directive.rb +81 -0
  151. data/lib/rubocop/cop/lint/multiple_compare.rb +1 -1
  152. data/lib/rubocop/cop/lint/nested_method_definition.rb +6 -8
  153. data/lib/rubocop/cop/lint/nested_percent_literal.rb +58 -0
  154. data/lib/rubocop/cop/lint/next_without_accumulator.rb +1 -1
  155. data/lib/rubocop/cop/lint/non_local_exit_from_iterator.rb +4 -4
  156. data/lib/rubocop/cop/lint/parentheses_as_grouped_expression.rb +4 -3
  157. data/lib/rubocop/cop/lint/percent_string_array.rb +13 -22
  158. data/lib/rubocop/cop/lint/percent_symbol_array.rb +12 -12
  159. data/lib/rubocop/cop/lint/rand_one.rb +8 -2
  160. data/lib/rubocop/cop/lint/redundant_with_index.rb +80 -0
  161. data/lib/rubocop/cop/lint/redundant_with_object.rb +81 -0
  162. data/lib/rubocop/cop/lint/regexp_as_condition.rb +29 -0
  163. data/lib/rubocop/cop/lint/require_parentheses.rb +5 -3
  164. data/lib/rubocop/cop/lint/rescue_exception.rb +1 -1
  165. data/lib/rubocop/cop/lint/rescue_type.rb +18 -9
  166. data/lib/rubocop/cop/lint/return_in_void_context.rb +74 -0
  167. data/lib/rubocop/cop/lint/safe_navigation_chain.rb +1 -1
  168. data/lib/rubocop/cop/lint/script_permission.rb +8 -1
  169. data/lib/rubocop/cop/lint/shadowed_argument.rb +146 -0
  170. data/lib/rubocop/cop/lint/shadowed_exception.rb +37 -10
  171. data/lib/rubocop/cop/lint/shadowing_outer_local_variable.rb +1 -1
  172. data/lib/rubocop/cop/lint/string_conversion_in_interpolation.rb +7 -7
  173. data/lib/rubocop/cop/lint/syntax.rb +23 -20
  174. data/lib/rubocop/cop/lint/underscore_prefixed_variable_name.rb +1 -1
  175. data/lib/rubocop/cop/lint/unified_integer.rb +5 -4
  176. data/lib/rubocop/cop/lint/unneeded_disable.rb +41 -16
  177. data/lib/rubocop/cop/lint/unneeded_require_statement.rb +51 -0
  178. data/lib/rubocop/cop/lint/unneeded_splat_expansion.rb +45 -19
  179. data/lib/rubocop/cop/lint/unreachable_code.rb +53 -8
  180. data/lib/rubocop/cop/lint/unused_method_argument.rb +2 -1
  181. data/lib/rubocop/cop/lint/uri_escape_unescape.rb +74 -0
  182. data/lib/rubocop/cop/lint/uri_regexp.rb +73 -0
  183. data/lib/rubocop/cop/lint/useless_access_modifier.rb +12 -16
  184. data/lib/rubocop/cop/lint/useless_assignment.rb +1 -1
  185. data/lib/rubocop/cop/lint/useless_comparison.rb +1 -1
  186. data/lib/rubocop/cop/lint/useless_setter_call.rb +15 -12
  187. data/lib/rubocop/cop/lint/void.rb +38 -27
  188. data/lib/rubocop/cop/message_annotator.rb +4 -2
  189. data/lib/rubocop/cop/metrics/abc_size.rb +2 -2
  190. data/lib/rubocop/cop/metrics/block_nesting.rb +1 -1
  191. data/lib/rubocop/cop/metrics/class_length.rb +3 -1
  192. data/lib/rubocop/cop/metrics/cyclomatic_complexity.rb +2 -1
  193. data/lib/rubocop/cop/metrics/line_length.rb +8 -5
  194. data/lib/rubocop/cop/metrics/method_length.rb +8 -3
  195. data/lib/rubocop/cop/metrics/module_length.rb +3 -1
  196. data/lib/rubocop/cop/metrics/parameter_lists.rb +14 -5
  197. data/lib/rubocop/cop/metrics/perceived_complexity.rb +2 -1
  198. data/lib/rubocop/cop/mixin/array_hash_indentation.rb +3 -2
  199. data/lib/rubocop/cop/mixin/autocorrect_alignment.rb +2 -2
  200. data/lib/rubocop/cop/mixin/code_length.rb +1 -1
  201. data/lib/rubocop/cop/mixin/configurable_formatting.rb +1 -1
  202. data/lib/rubocop/cop/mixin/def_node.rb +1 -1
  203. data/lib/rubocop/cop/mixin/documentation_comment.rb +1 -1
  204. data/lib/rubocop/cop/mixin/empty_lines_around_body.rb +14 -7
  205. data/lib/rubocop/cop/mixin/empty_parameter.rb +23 -0
  206. data/lib/rubocop/cop/mixin/end_keyword_alignment.rb +8 -4
  207. data/lib/rubocop/cop/mixin/enforce_superclass.rb +3 -3
  208. data/lib/rubocop/cop/mixin/first_element_line_break.rb +12 -3
  209. data/lib/rubocop/cop/mixin/heredoc.rb +28 -0
  210. data/lib/rubocop/cop/mixin/method_complexity.rb +33 -7
  211. data/lib/rubocop/cop/mixin/multiline_expression_indentation.rb +74 -33
  212. data/lib/rubocop/cop/mixin/multiline_literal_brace_layout.rb +34 -8
  213. data/lib/rubocop/cop/mixin/negative_conditional.rb +4 -1
  214. data/lib/rubocop/cop/mixin/ordered_gem_node.rb +67 -0
  215. data/lib/rubocop/cop/mixin/parentheses.rb +12 -0
  216. data/lib/rubocop/cop/mixin/parser_diagnostic.rb +4 -1
  217. data/lib/rubocop/cop/mixin/percent_array.rb +52 -0
  218. data/lib/rubocop/cop/mixin/space_after_punctuation.rb +9 -8
  219. data/lib/rubocop/cop/mixin/space_before_punctuation.rb +11 -10
  220. data/lib/rubocop/cop/mixin/statement_modifier.rb +7 -17
  221. data/lib/rubocop/cop/mixin/string_help.rb +1 -1
  222. data/lib/rubocop/cop/mixin/string_literals_help.rb +1 -1
  223. data/lib/rubocop/cop/mixin/surrounding_space.rb +95 -8
  224. data/lib/rubocop/cop/mixin/too_many_lines.rb +2 -2
  225. data/lib/rubocop/cop/mixin/trailing_comma.rb +25 -17
  226. data/lib/rubocop/cop/mixin/unused_argument.rb +6 -2
  227. data/lib/rubocop/cop/naming/accessor_method_name.rb +55 -0
  228. data/lib/rubocop/cop/{style → naming}/ascii_identifiers.rb +35 -2
  229. data/lib/rubocop/cop/{style/op_method.rb → naming/binary_operator_parameter_name.rb} +7 -6
  230. data/lib/rubocop/cop/naming/class_and_module_camel_case.rb +33 -0
  231. data/lib/rubocop/cop/naming/constant_name.rb +58 -0
  232. data/lib/rubocop/cop/{style → naming}/file_name.rb +28 -13
  233. data/lib/rubocop/cop/naming/heredoc_delimiter_case.rb +62 -0
  234. data/lib/rubocop/cop/naming/heredoc_delimiter_naming.rb +59 -0
  235. data/lib/rubocop/cop/naming/method_name.rb +40 -0
  236. data/lib/rubocop/cop/naming/predicate_name.rb +101 -0
  237. data/lib/rubocop/cop/naming/variable_name.rb +50 -0
  238. data/lib/rubocop/cop/{style → naming}/variable_number.rb +11 -28
  239. data/lib/rubocop/cop/offense.rb +6 -1
  240. data/lib/rubocop/cop/performance/caller.rb +39 -11
  241. data/lib/rubocop/cop/performance/case_when_splat.rb +3 -7
  242. data/lib/rubocop/cop/performance/casecmp.rb +9 -8
  243. data/lib/rubocop/cop/performance/compare_with_block.rb +23 -13
  244. data/lib/rubocop/cop/performance/count.rb +7 -4
  245. data/lib/rubocop/cop/performance/detect.rb +9 -6
  246. data/lib/rubocop/cop/performance/double_start_end_with.rb +12 -20
  247. data/lib/rubocop/cop/performance/end_with.rb +6 -6
  248. data/lib/rubocop/cop/performance/fixed_size.rb +1 -1
  249. data/lib/rubocop/cop/performance/flat_map.rb +5 -2
  250. data/lib/rubocop/cop/performance/hash_each_methods.rb +85 -40
  251. data/lib/rubocop/cop/performance/lstrip_rstrip.rb +9 -6
  252. data/lib/rubocop/cop/performance/range_include.rb +3 -3
  253. data/lib/rubocop/cop/performance/redundant_block_call.rb +28 -28
  254. data/lib/rubocop/cop/performance/redundant_match.rb +13 -12
  255. data/lib/rubocop/cop/performance/redundant_merge.rb +44 -26
  256. data/lib/rubocop/cop/performance/redundant_sort_by.rb +9 -6
  257. data/lib/rubocop/cop/performance/regexp_match.rb +19 -10
  258. data/lib/rubocop/cop/performance/reverse_each.rb +1 -1
  259. data/lib/rubocop/cop/performance/sample.rb +1 -1
  260. data/lib/rubocop/cop/performance/size.rb +3 -3
  261. data/lib/rubocop/cop/performance/start_with.rb +6 -6
  262. data/lib/rubocop/cop/performance/string_replacement.rb +6 -6
  263. data/lib/rubocop/cop/performance/times_map.rb +32 -22
  264. data/lib/rubocop/cop/performance/unfreeze_string.rb +50 -0
  265. data/lib/rubocop/cop/performance/uri_default_parser.rb +47 -0
  266. data/lib/rubocop/cop/rails/action_filter.rb +23 -1
  267. data/lib/rubocop/cop/rails/active_support_aliases.rb +4 -5
  268. data/lib/rubocop/cop/rails/application_job.rb +5 -3
  269. data/lib/rubocop/cop/rails/application_record.rb +5 -3
  270. data/lib/rubocop/cop/rails/blank.rb +20 -17
  271. data/lib/rubocop/cop/rails/create_table_with_timestamps.rb +82 -0
  272. data/lib/rubocop/cop/rails/date.rb +7 -6
  273. data/lib/rubocop/cop/rails/delegate.rb +53 -29
  274. data/lib/rubocop/cop/rails/delegate_allow_blank.rb +4 -4
  275. data/lib/rubocop/cop/rails/dynamic_find_by.rb +2 -2
  276. data/lib/rubocop/cop/rails/enum_uniqueness.rb +4 -4
  277. data/lib/rubocop/cop/rails/environment_comparison.rb +66 -0
  278. data/lib/rubocop/cop/rails/exit.rb +8 -1
  279. data/lib/rubocop/cop/rails/file_path.rb +8 -11
  280. data/lib/rubocop/cop/rails/find_by.rb +2 -1
  281. data/lib/rubocop/cop/rails/find_each.rb +1 -1
  282. data/lib/rubocop/cop/rails/has_and_belongs_to_many.rb +8 -1
  283. data/lib/rubocop/cop/rails/has_many_or_has_one_dependent.rb +76 -0
  284. data/lib/rubocop/cop/rails/http_positional_arguments.rb +40 -44
  285. data/lib/rubocop/cop/rails/inverse_of.rb +96 -0
  286. data/lib/rubocop/cop/rails/lexically_scoped_action_filter.rb +112 -0
  287. data/lib/rubocop/cop/rails/not_null_column.rb +6 -6
  288. data/lib/rubocop/cop/rails/output.rb +11 -2
  289. data/lib/rubocop/cop/rails/output_safety.rb +16 -21
  290. data/lib/rubocop/cop/rails/pluralization_grammar.rb +10 -10
  291. data/lib/rubocop/cop/rails/presence.rb +105 -0
  292. data/lib/rubocop/cop/rails/present.rb +14 -17
  293. data/lib/rubocop/cop/rails/read_write_attribute.rb +13 -13
  294. data/lib/rubocop/cop/rails/redundant_receiver_in_with_options.rb +91 -0
  295. data/lib/rubocop/cop/rails/relative_date_constant.rb +11 -11
  296. data/lib/rubocop/cop/rails/request_referer.rb +3 -3
  297. data/lib/rubocop/cop/rails/reversible_migration.rb +36 -35
  298. data/lib/rubocop/cop/rails/safe_navigation.rb +7 -8
  299. data/lib/rubocop/cop/rails/save_bang.rb +19 -17
  300. data/lib/rubocop/cop/rails/scope_args.rb +2 -2
  301. data/lib/rubocop/cop/rails/skips_model_validations.rb +2 -2
  302. data/lib/rubocop/cop/rails/time_zone.rb +3 -2
  303. data/lib/rubocop/cop/rails/uniq_before_pluck.rb +4 -2
  304. data/lib/rubocop/cop/rails/unknown_env.rb +63 -0
  305. data/lib/rubocop/cop/rails/validation.rb +8 -8
  306. data/lib/rubocop/cop/registry.rb +2 -1
  307. data/lib/rubocop/cop/security/eval.rb +4 -4
  308. data/lib/rubocop/cop/security/json_load.rb +7 -5
  309. data/lib/rubocop/cop/security/marshal_load.rb +8 -6
  310. data/lib/rubocop/cop/security/yaml_load.rb +4 -4
  311. data/lib/rubocop/cop/style/alias.rb +49 -27
  312. data/lib/rubocop/cop/style/and_or.rb +65 -45
  313. data/lib/rubocop/cop/style/array_join.rb +10 -1
  314. data/lib/rubocop/cop/style/ascii_comments.rb +24 -4
  315. data/lib/rubocop/cop/style/attr.rb +15 -5
  316. data/lib/rubocop/cop/style/auto_resource_cleanup.rb +7 -5
  317. data/lib/rubocop/cop/style/bare_percent_literals.rb +31 -10
  318. data/lib/rubocop/cop/style/begin_block.rb +1 -1
  319. data/lib/rubocop/cop/style/block_comments.rb +17 -3
  320. data/lib/rubocop/cop/style/block_delimiters.rb +82 -16
  321. data/lib/rubocop/cop/style/braces_around_hash_parameters.rb +68 -32
  322. data/lib/rubocop/cop/style/case_equality.rb +13 -1
  323. data/lib/rubocop/cop/style/character_literal.rb +10 -0
  324. data/lib/rubocop/cop/style/class_and_module_children.rb +8 -4
  325. data/lib/rubocop/cop/style/class_check.rb +29 -10
  326. data/lib/rubocop/cop/style/class_methods.rb +10 -9
  327. data/lib/rubocop/cop/style/class_vars.rb +5 -4
  328. data/lib/rubocop/cop/style/collection_methods.rb +5 -3
  329. data/lib/rubocop/cop/style/colon_method_call.rb +18 -2
  330. data/lib/rubocop/cop/style/colon_method_definition.rb +36 -0
  331. data/lib/rubocop/cop/style/command_literal.rb +90 -30
  332. data/lib/rubocop/cop/style/comment_annotation.rb +39 -11
  333. data/lib/rubocop/cop/style/commented_keyword.rb +84 -0
  334. data/lib/rubocop/cop/style/conditional_assignment.rb +41 -41
  335. data/lib/rubocop/cop/style/copyright.rb +27 -28
  336. data/lib/rubocop/cop/style/date_time.rb +44 -0
  337. data/lib/rubocop/cop/style/def_with_parentheses.rb +31 -5
  338. data/lib/rubocop/cop/style/dir.rb +48 -0
  339. data/lib/rubocop/cop/style/documentation.rb +17 -2
  340. data/lib/rubocop/cop/style/documentation_method.rb +2 -6
  341. data/lib/rubocop/cop/style/double_negation.rb +1 -1
  342. data/lib/rubocop/cop/style/each_for_simple_loop.rb +8 -8
  343. data/lib/rubocop/cop/style/each_with_object.rb +6 -5
  344. data/lib/rubocop/cop/style/empty_block_parameter.rb +47 -0
  345. data/lib/rubocop/cop/style/empty_case_condition.rb +3 -3
  346. data/lib/rubocop/cop/style/empty_else.rb +55 -24
  347. data/lib/rubocop/cop/style/empty_lambda_parameter.rb +43 -0
  348. data/lib/rubocop/cop/style/empty_literal.rb +25 -14
  349. data/lib/rubocop/cop/style/empty_method.rb +29 -25
  350. data/lib/rubocop/cop/style/encoding.rb +8 -51
  351. data/lib/rubocop/cop/style/end_block.rb +1 -1
  352. data/lib/rubocop/cop/style/eval_with_location.rb +146 -0
  353. data/lib/rubocop/cop/style/even_odd.rb +4 -2
  354. data/lib/rubocop/cop/style/extend_self.rb +92 -0
  355. data/lib/rubocop/cop/style/flip_flop.rb +13 -2
  356. data/lib/rubocop/cop/style/for.rb +6 -2
  357. data/lib/rubocop/cop/style/format_string.rb +33 -5
  358. data/lib/rubocop/cop/style/format_string_token.rb +17 -15
  359. data/lib/rubocop/cop/style/frozen_string_literal_comment.rb +7 -6
  360. data/lib/rubocop/cop/style/global_vars.rb +12 -2
  361. data/lib/rubocop/cop/style/guard_clause.rb +6 -4
  362. data/lib/rubocop/cop/style/hash_syntax.rb +56 -56
  363. data/lib/rubocop/cop/style/identical_conditional_branches.rb +12 -8
  364. data/lib/rubocop/cop/style/if_inside_else.rb +11 -11
  365. data/lib/rubocop/cop/style/if_unless_modifier.rb +8 -7
  366. data/lib/rubocop/cop/style/if_unless_modifier_of_if_unless.rb +3 -2
  367. data/lib/rubocop/cop/style/if_with_semicolon.rb +10 -1
  368. data/lib/rubocop/cop/style/implicit_runtime_error.rb +7 -6
  369. data/lib/rubocop/cop/style/infinite_loop.rb +4 -4
  370. data/lib/rubocop/cop/style/inline_comment.rb +1 -1
  371. data/lib/rubocop/cop/style/inverse_methods.rb +24 -14
  372. data/lib/rubocop/cop/style/lambda.rb +45 -43
  373. data/lib/rubocop/cop/style/lambda_call.rb +37 -10
  374. data/lib/rubocop/cop/style/line_end_concatenation.rb +5 -5
  375. data/lib/rubocop/cop/style/method_call_with_args_parentheses.rb +3 -19
  376. data/lib/rubocop/cop/style/method_call_without_args_parentheses.rb +6 -4
  377. data/lib/rubocop/cop/style/method_called_on_do_end_block.rb +1 -1
  378. data/lib/rubocop/cop/style/method_def_parentheses.rb +20 -25
  379. data/lib/rubocop/cop/style/method_missing.rb +13 -26
  380. data/lib/rubocop/cop/style/min_max.rb +68 -0
  381. data/lib/rubocop/cop/style/missing_else.rb +20 -6
  382. data/lib/rubocop/cop/style/mixin_grouping.rb +31 -21
  383. data/lib/rubocop/cop/style/mixin_usage.rb +71 -0
  384. data/lib/rubocop/cop/style/module_function.rb +27 -11
  385. data/lib/rubocop/cop/style/multiline_block_chain.rb +1 -1
  386. data/lib/rubocop/cop/style/multiline_if_modifier.rb +8 -4
  387. data/lib/rubocop/cop/style/multiline_if_then.rb +15 -13
  388. data/lib/rubocop/cop/style/multiline_memoization.rb +33 -17
  389. data/lib/rubocop/cop/style/multiline_ternary_operator.rb +1 -1
  390. data/lib/rubocop/cop/style/multiple_comparison.rb +1 -1
  391. data/lib/rubocop/cop/style/mutable_constant.rb +11 -15
  392. data/lib/rubocop/cop/style/negated_if.rb +27 -31
  393. data/lib/rubocop/cop/style/negated_while.rb +1 -5
  394. data/lib/rubocop/cop/style/nested_modifier.rb +1 -1
  395. data/lib/rubocop/cop/style/nested_parenthesized_calls.rb +26 -23
  396. data/lib/rubocop/cop/style/nested_ternary_operator.rb +1 -1
  397. data/lib/rubocop/cop/style/next.rb +41 -12
  398. data/lib/rubocop/cop/style/nil_comparison.rb +8 -8
  399. data/lib/rubocop/cop/style/non_nil_check.rb +41 -38
  400. data/lib/rubocop/cop/style/not.rb +15 -5
  401. data/lib/rubocop/cop/style/numeric_literal_prefix.rb +8 -4
  402. data/lib/rubocop/cop/style/numeric_literals.rb +9 -9
  403. data/lib/rubocop/cop/style/numeric_predicate.rb +21 -21
  404. data/lib/rubocop/cop/style/one_line_conditional.rb +9 -4
  405. data/lib/rubocop/cop/style/option_hash.rb +11 -25
  406. data/lib/rubocop/cop/style/optional_arguments.rb +1 -2
  407. data/lib/rubocop/cop/style/or_assignment.rb +88 -0
  408. data/lib/rubocop/cop/style/parallel_assignment.rb +16 -16
  409. data/lib/rubocop/cop/style/parentheses_around_condition.rb +30 -13
  410. data/lib/rubocop/cop/style/percent_literal_delimiters.rb +25 -4
  411. data/lib/rubocop/cop/style/percent_q_literals.rb +29 -8
  412. data/lib/rubocop/cop/style/perl_backrefs.rb +8 -1
  413. data/lib/rubocop/cop/style/preferred_hash_methods.rb +7 -11
  414. data/lib/rubocop/cop/style/proc.rb +10 -2
  415. data/lib/rubocop/cop/style/raise_args.rb +22 -29
  416. data/lib/rubocop/cop/style/random_with_offset.rb +160 -0
  417. data/lib/rubocop/cop/style/redundant_begin.rb +16 -5
  418. data/lib/rubocop/cop/style/redundant_conditional.rb +96 -0
  419. data/lib/rubocop/cop/style/redundant_exception.rb +4 -4
  420. data/lib/rubocop/cop/style/redundant_freeze.rb +1 -1
  421. data/lib/rubocop/cop/style/redundant_parentheses.rb +14 -12
  422. data/lib/rubocop/cop/style/redundant_return.rb +28 -15
  423. data/lib/rubocop/cop/style/redundant_self.rb +35 -27
  424. data/lib/rubocop/cop/style/regexp_literal.rb +88 -27
  425. data/lib/rubocop/cop/style/rescue_modifier.rb +12 -1
  426. data/lib/rubocop/cop/style/rescue_standard_error.rb +122 -0
  427. data/lib/rubocop/cop/style/return_nil.rb +89 -0
  428. data/lib/rubocop/cop/style/safe_navigation.rb +100 -48
  429. data/lib/rubocop/cop/style/self_assignment.rb +13 -13
  430. data/lib/rubocop/cop/style/semicolon.rb +19 -9
  431. data/lib/rubocop/cop/style/send.rb +10 -1
  432. data/lib/rubocop/cop/style/signal_exception.rb +104 -3
  433. data/lib/rubocop/cop/style/single_line_block_params.rb +16 -15
  434. data/lib/rubocop/cop/style/single_line_methods.rb +26 -18
  435. data/lib/rubocop/cop/style/special_global_vars.rb +19 -14
  436. data/lib/rubocop/cop/style/stabby_lambda_parentheses.rb +23 -50
  437. data/lib/rubocop/cop/style/stderr_puts.rb +54 -0
  438. data/lib/rubocop/cop/style/string_hash_keys.rb +36 -0
  439. data/lib/rubocop/cop/style/string_literals.rb +26 -3
  440. data/lib/rubocop/cop/style/string_literals_in_interpolation.rb +16 -1
  441. data/lib/rubocop/cop/style/string_methods.rb +19 -8
  442. data/lib/rubocop/cop/style/struct_inheritance.rb +3 -3
  443. data/lib/rubocop/cop/style/symbol_array.rb +7 -35
  444. data/lib/rubocop/cop/style/symbol_literal.rb +1 -1
  445. data/lib/rubocop/cop/style/symbol_proc.rb +11 -25
  446. data/lib/rubocop/cop/style/ternary_parentheses.rb +46 -51
  447. data/lib/rubocop/cop/style/trailing_body_on_method_definition.rb +101 -0
  448. data/lib/rubocop/cop/style/trailing_comma_in_arguments.rb +20 -6
  449. data/lib/rubocop/cop/style/trailing_comma_in_literal.rb +22 -7
  450. data/lib/rubocop/cop/style/trailing_method_end_statement.rb +95 -0
  451. data/lib/rubocop/cop/style/trailing_underscore_variable.rb +70 -24
  452. data/lib/rubocop/cop/style/trivial_accessors.rb +72 -65
  453. data/lib/rubocop/cop/style/unless_else.rb +16 -1
  454. data/lib/rubocop/cop/style/unneeded_capital_w.rb +18 -8
  455. data/lib/rubocop/cop/style/unneeded_interpolation.rb +15 -19
  456. data/lib/rubocop/cop/style/unneeded_percent_q.rb +14 -13
  457. data/lib/rubocop/cop/style/variable_interpolation.rb +23 -9
  458. data/lib/rubocop/cop/style/when_then.rb +14 -1
  459. data/lib/rubocop/cop/style/while_until_do.rb +27 -4
  460. data/lib/rubocop/cop/style/while_until_modifier.rb +26 -6
  461. data/lib/rubocop/cop/style/word_array.rb +9 -30
  462. data/lib/rubocop/cop/style/yoda_condition.rb +51 -22
  463. data/lib/rubocop/cop/style/zero_length_predicate.rb +44 -29
  464. data/lib/rubocop/cop/team.rb +16 -8
  465. data/lib/rubocop/cop/util.rb +43 -34
  466. data/lib/rubocop/cop/variable_force.rb +1 -1
  467. data/lib/rubocop/cop/variable_force/assignment.rb +4 -2
  468. data/lib/rubocop/cop/variable_force/scope.rb +1 -5
  469. data/lib/rubocop/cop/variable_force/variable.rb +1 -1
  470. data/lib/rubocop/formatter/disabled_config_formatter.rb +3 -4
  471. data/lib/rubocop/formatter/formatter_set.rb +3 -1
  472. data/lib/rubocop/formatter/html_formatter.rb +1 -1
  473. data/lib/rubocop/formatter/json_formatter.rb +9 -3
  474. data/lib/rubocop/formatter/offense_count_formatter.rb +2 -0
  475. data/lib/rubocop/formatter/quiet_formatter.rb +13 -0
  476. data/lib/rubocop/formatter/simple_text_formatter.rb +3 -3
  477. data/lib/rubocop/formatter/tap_formatter.rb +71 -0
  478. data/lib/rubocop/formatter/worst_offenders_formatter.rb +2 -0
  479. data/lib/rubocop/node_pattern.rb +46 -29
  480. data/lib/rubocop/options.rb +13 -8
  481. data/lib/rubocop/path_util.rb +15 -3
  482. data/lib/rubocop/processed_source.rb +8 -9
  483. data/lib/rubocop/rake_task.rb +16 -23
  484. data/lib/rubocop/remote_config.rb +13 -1
  485. data/lib/rubocop/result_cache.rb +1 -0
  486. data/lib/rubocop/rspec/cop_helper.rb +10 -10
  487. data/lib/rubocop/rspec/expect_offense.rb +6 -8
  488. data/lib/rubocop/rspec/shared_contexts.rb +4 -8
  489. data/lib/rubocop/rspec/shared_examples.rb +8 -8
  490. data/lib/rubocop/rspec/support.rb +5 -5
  491. data/lib/rubocop/runner.rb +1 -1
  492. data/lib/rubocop/string_util.rb +2 -0
  493. data/lib/rubocop/token.rb +74 -0
  494. data/lib/rubocop/version.rb +1 -1
  495. metadata +118 -48
  496. data/lib/rubocop/cop/layout/space_inside_brackets.rb +0 -20
  497. data/lib/rubocop/cop/lint/invalid_character_literal.rb +0 -41
  498. data/lib/rubocop/cop/mixin/access_modifier_node.rb +0 -41
  499. data/lib/rubocop/cop/mixin/on_method_def.rb +0 -44
  500. data/lib/rubocop/cop/mixin/space_inside.rb +0 -76
  501. data/lib/rubocop/cop/style/accessor_method_name.rb +0 -45
  502. data/lib/rubocop/cop/style/class_and_module_camel_case.rb +0 -29
  503. data/lib/rubocop/cop/style/constant_name.rb +0 -29
  504. data/lib/rubocop/cop/style/method_name.rb +0 -34
  505. data/lib/rubocop/cop/style/predicate_name.rb +0 -67
  506. data/lib/rubocop/cop/style/variable_name.rb +0 -39
@@ -5,10 +5,14 @@ module RuboCop
5
5
  module PathUtil
6
6
  module_function
7
7
 
8
- def relative_path(path, base_dir = Dir.pwd)
8
+ def relative_path(path, base_dir = PathUtil.pwd)
9
9
  # Optimization for the common case where path begins with the base
10
10
  # dir. Just cut off the first part.
11
- return path[(base_dir.length + 1)..-1] if path.start_with?(base_dir)
11
+ if path.start_with?(base_dir)
12
+ base_dir_length = base_dir.length
13
+ result_length = path.length - base_dir_length - 1
14
+ return path[base_dir_length + 1, result_length]
15
+ end
12
16
 
13
17
  path_name = Pathname.new(File.expand_path(path))
14
18
  path_name.relative_path_from(Pathname.new(base_dir)).to_s
@@ -16,7 +20,7 @@ module RuboCop
16
20
 
17
21
  def smart_path(path)
18
22
  # Ideally, we calculate this relative to the project root.
19
- base_dir = Dir.pwd
23
+ base_dir = PathUtil.pwd
20
24
 
21
25
  if path.start_with? base_dir
22
26
  relative_path(path, base_dir)
@@ -43,5 +47,13 @@ module RuboCop
43
47
  def absolute?(path)
44
48
  path =~ %r{\A([A-Z]:)?/}
45
49
  end
50
+
51
+ def self.pwd
52
+ @pwd ||= Dir.pwd
53
+ end
54
+
55
+ def self.reset_pwd
56
+ @pwd = nil
57
+ end
46
58
  end
47
59
  end
@@ -54,7 +54,7 @@ module RuboCop
54
54
  def lines
55
55
  @lines ||= begin
56
56
  all_lines = @buffer.source_lines
57
- last_token_line = tokens.any? ? tokens.last.pos.line : all_lines.size
57
+ last_token_line = tokens.any? ? tokens.last.line : all_lines.size
58
58
  result = []
59
59
  all_lines.each_with_index do |line, ix|
60
60
  break if ix >= last_token_line && line == '__END__'
@@ -107,14 +107,9 @@ module RuboCop
107
107
  [ast, comments, tokens]
108
108
  end
109
109
 
110
- def parser_class(ruby_version) # rubocop:disable Metrics/MethodLength
110
+ # rubocop:disable Metrics/MethodLength
111
+ def parser_class(ruby_version)
111
112
  case ruby_version
112
- when 1.9
113
- require 'parser/ruby19'
114
- Parser::Ruby19
115
- when 2.0
116
- require 'parser/ruby20'
117
- Parser::Ruby20
118
113
  when 2.1
119
114
  require 'parser/ruby21'
120
115
  Parser::Ruby21
@@ -127,16 +122,20 @@ module RuboCop
127
122
  when 2.4
128
123
  require 'parser/ruby24'
129
124
  Parser::Ruby24
125
+ when 2.5
126
+ require 'parser/ruby25'
127
+ Parser::Ruby25
130
128
  else
131
129
  raise ArgumentError, "Unknown Ruby version: #{ruby_version.inspect}"
132
130
  end
133
131
  end
132
+ # rubocop:enable Metrics/MethodLength
134
133
 
135
134
  def create_parser(ruby_version)
136
135
  builder = RuboCop::AST::Builder.new
137
136
 
138
137
  parser_class(ruby_version).new(builder).tap do |parser|
139
- # On JRuby and Rubinius, there's a risk that we hang in tokenize() if we
138
+ # On JRuby there's a risk that we hang in tokenize() if we
140
139
  # don't set the all errors as fatal flag. The problem is caused by a bug
141
140
  # in Racc that is discussed in issue #93 of the whitequark/parser
142
141
  # project on GitHub.
@@ -17,25 +17,21 @@ module RuboCop
17
17
  attr_accessor :requires
18
18
  attr_accessor :options
19
19
 
20
- def initialize(*args, &task_block)
21
- setup_ivars(args)
20
+ def initialize(name = :rubocop, *args, &task_block)
21
+ setup_ivars(name)
22
22
 
23
23
  desc 'Run RuboCop' unless ::Rake.application.last_description
24
24
 
25
25
  task(name, *args) do |_, task_args|
26
- RakeFileUtils.send(:verbose, verbose) do
26
+ RakeFileUtils.verbose(verbose) do
27
27
  yield(*[self, task_args].slice(0, task_block.arity)) if block_given?
28
- run_main_task(verbose)
28
+ run_cli(verbose, full_options)
29
29
  end
30
30
  end
31
31
 
32
32
  setup_subtasks(name, *args, &task_block)
33
33
  end
34
34
 
35
- def run_main_task(verbose)
36
- run_cli(verbose, full_options)
37
- end
38
-
39
35
  private
40
36
 
41
37
  def run_cli(verbose, options)
@@ -50,19 +46,14 @@ module RuboCop
50
46
  end
51
47
 
52
48
  def full_options
53
- [].tap do |result|
54
- result.concat(formatters.map { |f| ['--format', f] }.flatten)
55
- result.concat(requires.map { |r| ['--require', r] }.flatten)
56
- result.concat(options.flatten)
57
- result.concat(patterns)
58
- end
49
+ formatters.map { |f| ['--format', f] }.flatten
50
+ .concat(requires.map { |r| ['--require', r] }.flatten)
51
+ .concat(options.flatten)
52
+ .concat(patterns)
59
53
  end
60
54
 
61
- def setup_ivars(args)
62
- # More lazy-loading to keep load time down.
63
- require 'rubocop/options'
64
-
65
- @name = args.shift || :rubocop
55
+ def setup_ivars(name)
56
+ @name = name
66
57
  @verbose = true
67
58
  @fail_on_error = true
68
59
  @patterns = []
@@ -72,13 +63,15 @@ module RuboCop
72
63
  end
73
64
 
74
65
  def setup_subtasks(name, *args, &task_block)
75
- namespace name do
66
+ namespace(name) do
76
67
  desc 'Auto-correct RuboCop offenses'
77
68
 
78
69
  task(:auto_correct, *args) do |_, task_args|
79
- yield(*[self, task_args].slice(0, task_block.arity)) if block_given?
80
- options = full_options.unshift('--auto-correct')
81
- run_cli(verbose, options)
70
+ RakeFileUtils.verbose(verbose) do
71
+ yield(*[self, task_args].slice(0, task_block.arity)) if block_given?
72
+ options = full_options.unshift('--auto-correct')
73
+ run_cli(verbose, options)
74
+ end
82
75
  end
83
76
  end
84
77
  end
@@ -6,6 +6,8 @@ require 'time'
6
6
  module RuboCop
7
7
  # Common methods and behaviors for dealing with remote config files.
8
8
  class RemoteConfig
9
+ attr_reader :uri
10
+
9
11
  CACHE_LIFETIME = 24 * 60 * 60
10
12
 
11
13
  def initialize(url, base_dir)
@@ -17,6 +19,8 @@ module RuboCop
17
19
  return cache_path unless cache_path_expired?
18
20
 
19
21
  request do |response|
22
+ next if response.is_a?(Net::HTTPNotModified)
23
+ next if response.is_a?(SocketError)
20
24
  open cache_path, 'w' do |io|
21
25
  io.write response.body
22
26
  end
@@ -25,6 +29,12 @@ module RuboCop
25
29
  cache_path
26
30
  end
27
31
 
32
+ def inherit_from_remote(file, path)
33
+ new_uri = @uri.dup
34
+ new_uri.path.gsub!(%r{/[^/]*$}, "/#{file}")
35
+ RemoteConfig.new(new_uri.to_s, File.dirname(path))
36
+ end
37
+
28
38
  private
29
39
 
30
40
  def request(uri = @uri, limit = 10, &block)
@@ -39,11 +49,13 @@ module RuboCop
39
49
  end
40
50
 
41
51
  handle_response(http.request(request), limit, &block)
52
+ rescue SocketError => err
53
+ handle_response(err, limit, &block)
42
54
  end
43
55
 
44
56
  def handle_response(response, limit, &block)
45
57
  case response
46
- when Net::HTTPSuccess
58
+ when Net::HTTPSuccess, Net::HTTPNotModified, SocketError
47
59
  yield response
48
60
  when Net::HTTPRedirection
49
61
  request(URI.parse(response['location']), limit - 1, &block)
@@ -133,6 +133,7 @@ module RuboCop
133
133
 
134
134
  def file_checksum(file, config_store)
135
135
  Digest::MD5.hexdigest(Dir.pwd + file + IO.read(file) +
136
+ File.stat(file).mode.to_s +
136
137
  config_store.for(file).to_s)
137
138
  rescue Errno::ENOENT
138
139
  # Spurious files that come and go should not cause a crash, at least not
@@ -10,15 +10,15 @@ module CopHelper
10
10
  let(:enabled_rails) { false }
11
11
  let(:rails_version) { false }
12
12
 
13
- def inspect_source_file(cop, source)
14
- Tempfile.open('tmp') { |f| inspect_source(cop, source, f) }
13
+ def inspect_source_file(source)
14
+ Tempfile.open('tmp') { |f| inspect_source(source, f) }
15
15
  end
16
16
 
17
- def inspect_gemfile(cop, source)
18
- inspect_source(cop, source, 'Gemfile')
17
+ def inspect_gemfile(source)
18
+ inspect_source(source, 'Gemfile')
19
19
  end
20
20
 
21
- def inspect_source(cop, source, file = nil)
21
+ def inspect_source(source, file = nil)
22
22
  if source.is_a?(Array) && source.size == 1
23
23
  raise "Don't use an array for a single line of code: #{source}"
24
24
  end
@@ -41,11 +41,11 @@ module CopHelper
41
41
  RuboCop::ProcessedSource.new(source, ruby_version, file)
42
42
  end
43
43
 
44
- def autocorrect_source_file(cop, source)
45
- Tempfile.open('tmp') { |f| autocorrect_source(cop, source, f) }
44
+ def autocorrect_source_file(source)
45
+ Tempfile.open('tmp') { |f| autocorrect_source(source, f) }
46
46
  end
47
47
 
48
- def autocorrect_source(cop, source, file = nil)
48
+ def autocorrect_source(source, file = nil)
49
49
  cop.instance_variable_get(:@options)[:auto_correct] = true
50
50
  processed_source = parse_source(source, file)
51
51
  _investigate(cop, processed_source)
@@ -55,10 +55,10 @@ module CopHelper
55
55
  corrector.rewrite
56
56
  end
57
57
 
58
- def autocorrect_source_with_loop(cop, source, file = nil)
58
+ def autocorrect_source_with_loop(source, file = nil)
59
59
  loop do
60
60
  cop.instance_variable_set(:@corrections, [])
61
- new_source = autocorrect_source(cop, source, file)
61
+ new_source = autocorrect_source(source, file)
62
62
  return new_source if new_source == source
63
63
  source = new_source
64
64
  end
@@ -23,7 +23,7 @@ module RuboCop
23
23
  #
24
24
  # @example Equivalent assertion without `expect_offense`
25
25
  #
26
- # inspect_source(cop, <<-RUBY.strip_indent)
26
+ # inspect_source(<<-RUBY.strip_indent)
27
27
  # a do
28
28
  # b
29
29
  # end.c
@@ -44,23 +44,21 @@ module RuboCop
44
44
  # that there were no offenses. The `expect_offenses` method has
45
45
  # to do more work by parsing out lines that contain carets.
46
46
  module ExpectOffense
47
- DEFAULT_FILENAME = 'example.rb'.freeze
48
-
49
- def expect_offense(source, filename = DEFAULT_FILENAME)
47
+ def expect_offense(source, file = nil)
50
48
  expected_annotations = AnnotatedSource.parse(source)
51
49
 
52
50
  if expected_annotations.plain_source == source
53
51
  raise 'Use expect_no_offenses to assert that no offenses are found'
54
52
  end
55
53
 
56
- inspect_source(cop, expected_annotations.plain_source, filename)
54
+ inspect_source(expected_annotations.plain_source, file)
57
55
  actual_annotations =
58
56
  expected_annotations.with_offense_annotations(cop.offenses)
59
- expect(expected_annotations.to_s).to eq(actual_annotations.to_s)
57
+ expect(actual_annotations.to_s).to eq(expected_annotations.to_s)
60
58
  end
61
59
 
62
- def expect_no_offenses(source, filename = DEFAULT_FILENAME)
63
- inspect_source(cop, source, filename)
60
+ def expect_no_offenses(source, file = nil)
61
+ inspect_source(source, file)
64
62
 
65
63
  expect(cop.offenses).to be_empty
66
64
  end
@@ -57,14 +57,6 @@ shared_context 'config', :config do
57
57
  end
58
58
  end
59
59
 
60
- shared_context 'ruby 1.9', :ruby19 do
61
- let(:ruby_version) { 1.9 }
62
- end
63
-
64
- shared_context 'ruby 2.0', :ruby20 do
65
- let(:ruby_version) { 2.0 }
66
- end
67
-
68
60
  shared_context 'ruby 2.1', :ruby21 do
69
61
  let(:ruby_version) { 2.1 }
70
62
  end
@@ -81,6 +73,10 @@ shared_context 'ruby 2.4', :ruby24 do
81
73
  let(:ruby_version) { 2.4 }
82
74
  end
83
75
 
76
+ shared_context 'ruby 2.5', :ruby25 do
77
+ let(:ruby_version) { 2.5 }
78
+ end
79
+
84
80
  shared_context 'with Rails', :enabled_rails do
85
81
  let(:enabled_rails) { true }
86
82
  end
@@ -4,7 +4,7 @@
4
4
 
5
5
  shared_examples_for 'accepts' do
6
6
  it 'accepts' do
7
- inspect_source(cop, source)
7
+ inspect_source(source)
8
8
  expect(cop.offenses).to be_empty
9
9
  end
10
10
  end
@@ -12,7 +12,7 @@ end
12
12
  shared_examples_for 'mimics MRI 2.1' do |grep_mri_warning|
13
13
  if RUBY_ENGINE == 'ruby' && RUBY_VERSION.start_with?('2.1')
14
14
  it "mimics MRI #{RUBY_VERSION} built-in syntax checking" do
15
- inspect_source(cop, source)
15
+ inspect_source(source)
16
16
  offenses_by_mri = MRISyntaxChecker.offenses_for_source(
17
17
  source, cop.name, grep_mri_warning
18
18
  )
@@ -38,7 +38,7 @@ shared_examples_for 'misaligned' do |prefix, alignment_base, arg, end_kw, name|
38
38
  end_kw]
39
39
 
40
40
  it "registers an offense for mismatched #{name} ... end" do
41
- inspect_source(cop, source)
41
+ inspect_source(source)
42
42
  expect(cop.offenses.size).to eq(1)
43
43
  base_regexp = Regexp.escape(alignment_base)
44
44
  regexp = /`end` at 2, \d+ is not aligned with `#{base_regexp}` at 1,/
@@ -58,7 +58,7 @@ shared_examples_for 'misaligned' do |prefix, alignment_base, arg, end_kw, name|
58
58
  it "auto-corrects mismatched #{name} ... end" do
59
59
  aligned_source = ["#{prefix}#{alignment_base} #{arg}",
60
60
  "#{' ' * prefix.length}#{end_kw.strip}"].join("\n")
61
- corrected = autocorrect_source(cop, source)
61
+ corrected = autocorrect_source(source)
62
62
  expect(corrected).to eq(aligned_source)
63
63
  end
64
64
  end
@@ -67,15 +67,15 @@ shared_examples_for 'aligned' do |alignment_base, arg, end_kw, name|
67
67
  name ||= alignment_base
68
68
  name = name.gsub(/\n/, ' <newline>')
69
69
  it "accepts matching #{name} ... end" do
70
- inspect_source(cop, ["#{alignment_base} #{arg}",
71
- end_kw])
70
+ inspect_source(["#{alignment_base} #{arg}",
71
+ end_kw])
72
72
  expect(cop.offenses).to be_empty
73
73
  end
74
74
  end
75
75
 
76
76
  shared_examples_for 'debugger' do |name, src|
77
77
  it "reports an offense for a #{name} call" do
78
- inspect_source(cop, src)
78
+ inspect_source(src)
79
79
  src = [src] if src.is_a? String
80
80
  expect(cop.offenses.size).to eq(src.size)
81
81
  expect(cop.messages)
@@ -86,7 +86,7 @@ end
86
86
 
87
87
  shared_examples_for 'non-debugger' do |name, src|
88
88
  it "does not report an offense for #{name}" do
89
- inspect_source(cop, src)
89
+ inspect_source(src)
90
90
  expect(cop.offenses).to be_empty
91
91
  end
92
92
  end
@@ -2,8 +2,8 @@
2
2
 
3
3
  # Require this file to load code that supports testing using RSpec.
4
4
 
5
- require 'rubocop/rspec/cop_helper'
6
- require 'rubocop/rspec/host_environment_simulation_helper'
7
- require 'rubocop/rspec/shared_contexts'
8
- require 'rubocop/rspec/shared_examples'
9
- require 'rubocop/rspec/expect_offense'
5
+ require_relative 'cop_helper'
6
+ require_relative 'host_environment_simulation_helper'
7
+ require_relative 'shared_contexts'
8
+ require_relative 'shared_examples'
9
+ require_relative 'expect_offense'
@@ -47,7 +47,7 @@ module RuboCop
47
47
  private
48
48
 
49
49
  # Warms up the RuboCop cache by forking a suitable number of rubocop
50
- # instances that each inspects its alotted group of files.
50
+ # instances that each inspects its allotted group of files.
51
51
  def warm_cache(target_files)
52
52
  puts 'Running parallel inspection' if @options[:debug]
53
53
  Parallel.each(target_files, &method(:file_offenses))
@@ -46,6 +46,7 @@ module RuboCop
46
46
  compute_non_zero_distance(matched_count.to_f, transposition_count)
47
47
  end
48
48
 
49
+ # rubocop:disable Metrics/AbcSize
49
50
  def find_common_characters
50
51
  common_chars_of_shorter = Array.new(shorter.size)
51
52
  common_chars_of_longer = Array.new(longer.size)
@@ -68,6 +69,7 @@ module RuboCop
68
69
 
69
70
  [common_chars_of_shorter, common_chars_of_longer].map(&:compact)
70
71
  end
72
+ # rubocop:enable Metrics/AbcSize
71
73
 
72
74
  def count_transpositions(common_chars_a, common_chars_b)
73
75
  common_chars_a.size.times.count do |index|
@@ -18,8 +18,82 @@ module RuboCop
18
18
  @text = text.to_s
19
19
  end
20
20
 
21
+ def line
22
+ pos.line
23
+ end
24
+
25
+ def column
26
+ pos.column
27
+ end
28
+
29
+ def begin_pos
30
+ pos.begin_pos
31
+ end
32
+
33
+ def end_pos
34
+ pos.end_pos
35
+ end
36
+
37
+ def comment?
38
+ type == :tCOMMENT
39
+ end
40
+
41
+ def semicolon?
42
+ type == :tSEMI
43
+ end
44
+
45
+ def left_array_bracket?
46
+ type == :tLBRACK
47
+ end
48
+
49
+ def left_ref_bracket?
50
+ type == :tLBRACK2
51
+ end
52
+
53
+ def right_bracket?
54
+ type == :tRBRACK
55
+ end
56
+
57
+ def left_brace?
58
+ type == :tLBRACE
59
+ end
60
+
61
+ def left_curly_brace?
62
+ type == :tLCURLY
63
+ end
64
+
65
+ def right_curly_brace?
66
+ type == :tRCURLY
67
+ end
68
+
69
+ def left_parens?
70
+ %i[tLPAREN tLPAREN2].include?(type)
71
+ end
72
+
73
+ def right_parens?
74
+ type == :tRPAREN
75
+ end
76
+
77
+ def comma?
78
+ type == :tCOMMA
79
+ end
80
+
81
+ def equal_sign?
82
+ %i[tEQL tOP_ASGN].include?(type)
83
+ end
84
+
21
85
  def to_s
22
86
  "[[#{@pos.line}, #{@pos.column}], #{@type}, #{@text.inspect}]"
23
87
  end
88
+
89
+ # Checks if there is whitespace after token
90
+ def space_after?
91
+ pos.source_buffer.source.match(/\G\s/, end_pos)
92
+ end
93
+
94
+ # Checks if there is whitespace before token
95
+ def space_before?
96
+ pos.source_buffer.source.match(/\G\s/, begin_pos - 1)
97
+ end
24
98
  end
25
99
  end