rubocop 0.42.0 → 0.43.0
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of rubocop might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/README.md +1 -1
- data/assets/output.html.erb +21 -10
- data/config/default.yml +32 -2
- data/config/disabled.yml +8 -1
- data/config/enabled.yml +40 -12
- data/lib/rubocop.rb +14 -2
- data/lib/rubocop/ast_node.rb +2 -0
- data/lib/rubocop/cached_data.rb +13 -11
- data/lib/rubocop/cli.rb +5 -5
- data/lib/rubocop/config.rb +68 -24
- data/lib/rubocop/config_loader.rb +13 -11
- data/lib/rubocop/config_loader_resolver.rb +4 -2
- data/lib/rubocop/cop/cop.rb +16 -5
- data/lib/rubocop/cop/lint/assignment_in_condition.rb +21 -20
- data/lib/rubocop/cop/lint/block_alignment.rb +3 -4
- data/lib/rubocop/cop/lint/def_end_alignment.rb +2 -3
- data/lib/rubocop/cop/lint/duplicate_methods.rb +16 -6
- data/lib/rubocop/cop/lint/else_layout.rb +1 -1
- data/lib/rubocop/cop/lint/empty_interpolation.rb +1 -1
- data/lib/rubocop/cop/lint/end_alignment.rb +4 -6
- data/lib/rubocop/cop/lint/eval.rb +1 -1
- data/lib/rubocop/cop/lint/format_parameter_mismatch.rb +1 -1
- data/lib/rubocop/cop/lint/ineffective_access_modifier.rb +8 -8
- data/lib/rubocop/cop/lint/inherit_exception.rb +22 -7
- data/lib/rubocop/cop/lint/literal_in_condition.rb +5 -5
- data/lib/rubocop/cop/lint/literal_in_interpolation.rb +3 -5
- data/lib/rubocop/cop/lint/next_without_accumulator.rb +1 -1
- data/lib/rubocop/cop/lint/parentheses_as_grouped_expression.rb +9 -8
- data/lib/rubocop/cop/lint/percent_string_array.rb +17 -6
- data/lib/rubocop/cop/lint/percent_symbol_array.rb +4 -4
- data/lib/rubocop/cop/lint/rand_one.rb +3 -3
- data/lib/rubocop/cop/lint/require_parentheses.rb +1 -3
- data/lib/rubocop/cop/lint/shadowed_exception.rb +39 -44
- data/lib/rubocop/cop/lint/string_conversion_in_interpolation.rb +2 -2
- data/lib/rubocop/cop/lint/underscore_prefixed_variable_name.rb +1 -2
- data/lib/rubocop/cop/lint/unified_integer.rb +38 -0
- data/lib/rubocop/cop/lint/unneeded_disable.rb +51 -38
- data/lib/rubocop/cop/lint/unneeded_splat_expansion.rb +114 -0
- data/lib/rubocop/cop/lint/useless_assignment.rb +25 -12
- data/lib/rubocop/cop/lint/useless_setter_call.rb +27 -28
- data/lib/rubocop/cop/lint/void.rb +2 -4
- data/lib/rubocop/cop/mixin/access_modifier_node.rb +5 -5
- data/lib/rubocop/cop/mixin/array_hash_indentation.rb +19 -17
- data/lib/rubocop/cop/mixin/autocorrect_alignment.rb +3 -5
- data/lib/rubocop/cop/mixin/configurable_naming.rb +4 -5
- data/lib/rubocop/cop/mixin/configurable_numbering.rb +52 -0
- data/lib/rubocop/cop/mixin/def_node.rb +28 -0
- data/lib/rubocop/cop/mixin/documentation_comment.rb +41 -0
- data/lib/rubocop/cop/mixin/end_keyword_alignment.rb +18 -13
- data/lib/rubocop/cop/mixin/if_node.rb +6 -0
- data/lib/rubocop/cop/mixin/match_range.rb +2 -5
- data/lib/rubocop/cop/mixin/multiline_expression_indentation.rb +2 -2
- data/lib/rubocop/cop/mixin/multiline_literal_brace_layout.rb +40 -28
- data/lib/rubocop/cop/mixin/negative_conditional.rb +6 -6
- data/lib/rubocop/cop/mixin/percent_literal.rb +1 -5
- data/lib/rubocop/cop/mixin/preceding_following_alignment.rb +14 -4
- data/lib/rubocop/cop/mixin/safe_mode.rb +23 -0
- data/lib/rubocop/cop/mixin/space_before_punctuation.rb +2 -4
- data/lib/rubocop/cop/mixin/space_inside.rb +1 -3
- data/lib/rubocop/cop/mixin/statement_modifier.rb +30 -20
- data/lib/rubocop/cop/mixin/trailing_comma.rb +19 -17
- data/lib/rubocop/cop/performance/case_when_splat.rb +16 -41
- data/lib/rubocop/cop/performance/casecmp.rb +28 -16
- data/lib/rubocop/cop/performance/count.rb +58 -34
- data/lib/rubocop/cop/performance/detect.rb +3 -7
- data/lib/rubocop/cop/performance/double_start_end_with.rb +17 -13
- data/lib/rubocop/cop/performance/fixed_size.rb +19 -14
- data/lib/rubocop/cop/performance/flat_map.rb +16 -9
- data/lib/rubocop/cop/performance/hash_each.rb +2 -3
- data/lib/rubocop/cop/performance/lstrip_rstrip.rb +4 -6
- data/lib/rubocop/cop/performance/redundant_match.rb +4 -1
- data/lib/rubocop/cop/performance/redundant_merge.rb +63 -32
- data/lib/rubocop/cop/performance/redundant_sort_by.rb +8 -7
- data/lib/rubocop/cop/performance/reverse_each.rb +1 -4
- data/lib/rubocop/cop/performance/size.rb +21 -8
- data/lib/rubocop/cop/performance/sort_with_block.rb +54 -0
- data/lib/rubocop/cop/performance/string_replacement.rb +3 -7
- data/lib/rubocop/cop/rails/delegate.rb +2 -3
- data/lib/rubocop/cop/rails/find_by.rb +4 -8
- data/lib/rubocop/cop/rails/not_null_column.rb +45 -0
- data/lib/rubocop/cop/rails/request_referer.rb +3 -3
- data/lib/rubocop/cop/rails/safe_navigation.rb +89 -0
- data/lib/rubocop/cop/rails/save_bang.rb +78 -9
- data/lib/rubocop/cop/rails/scope_args.rb +3 -1
- data/lib/rubocop/cop/rails/uniq_before_pluck.rb +2 -3
- data/lib/rubocop/cop/rails/validation.rb +1 -1
- data/lib/rubocop/cop/security/json_load.rb +36 -0
- data/lib/rubocop/cop/style/alias.rb +1 -1
- data/lib/rubocop/cop/style/align_hash.rb +25 -14
- data/lib/rubocop/cop/style/and_or.rb +13 -3
- data/lib/rubocop/cop/style/array_join.rb +3 -3
- data/lib/rubocop/cop/style/ascii_comments.rb +1 -2
- data/lib/rubocop/cop/style/ascii_identifiers.rb +1 -2
- data/lib/rubocop/cop/style/attr.rb +1 -3
- data/lib/rubocop/cop/style/block_comments.rb +2 -6
- data/lib/rubocop/cop/style/block_delimiters.rb +35 -21
- data/lib/rubocop/cop/style/braces_around_hash_parameters.rb +4 -4
- data/lib/rubocop/cop/style/case_indentation.rb +1 -3
- data/lib/rubocop/cop/style/class_methods.rb +3 -4
- data/lib/rubocop/cop/style/collection_methods.rb +1 -1
- data/lib/rubocop/cop/style/command_literal.rb +15 -8
- data/lib/rubocop/cop/style/comment_annotation.rb +1 -2
- data/lib/rubocop/cop/style/conditional_assignment.rb +68 -36
- data/lib/rubocop/cop/style/copyright.rb +1 -5
- data/lib/rubocop/cop/style/def_with_parentheses.rb +3 -5
- data/lib/rubocop/cop/style/documentation.rb +28 -56
- data/lib/rubocop/cop/style/documentation_method.rb +80 -0
- data/lib/rubocop/cop/style/each_for_simple_loop.rb +6 -5
- data/lib/rubocop/cop/style/each_with_object.rb +2 -2
- data/lib/rubocop/cop/style/else_alignment.rb +10 -9
- data/lib/rubocop/cop/style/empty_case_condition.rb +2 -4
- data/lib/rubocop/cop/style/empty_else.rb +1 -4
- data/lib/rubocop/cop/style/empty_line_between_defs.rb +1 -3
- data/lib/rubocop/cop/style/empty_lines_around_access_modifier.rb +2 -5
- data/lib/rubocop/cop/style/encoding.rb +28 -14
- data/lib/rubocop/cop/style/even_odd.rb +28 -17
- data/lib/rubocop/cop/style/extra_spacing.rb +36 -25
- data/lib/rubocop/cop/style/file_name.rb +19 -10
- data/lib/rubocop/cop/style/first_parameter_indentation.rb +2 -3
- data/lib/rubocop/cop/style/for.rb +12 -8
- data/lib/rubocop/cop/style/format_string.rb +1 -1
- data/lib/rubocop/cop/style/guard_clause.rb +22 -56
- data/lib/rubocop/cop/style/hash_syntax.rb +72 -7
- data/lib/rubocop/cop/style/if_unless_modifier.rb +23 -19
- data/lib/rubocop/cop/style/if_unless_modifier_of_if_unless.rb +3 -3
- data/lib/rubocop/cop/style/indentation_width.rb +30 -16
- data/lib/rubocop/cop/style/infinite_loop.rb +16 -13
- data/lib/rubocop/cop/style/initial_indentation.rb +23 -18
- data/lib/rubocop/cop/style/inline_comment.rb +16 -3
- data/lib/rubocop/cop/style/lambda.rb +22 -10
- data/lib/rubocop/cop/style/leading_comment_space.rb +12 -1
- data/lib/rubocop/cop/style/line_end_concatenation.rb +24 -6
- data/lib/rubocop/cop/style/method_call_parentheses.rb +18 -9
- data/lib/rubocop/cop/style/method_called_on_do_end_block.rb +3 -4
- data/lib/rubocop/cop/style/method_def_parentheses.rb +3 -4
- data/lib/rubocop/cop/style/method_missing.rb +10 -2
- data/lib/rubocop/cop/style/module_function.rb +14 -6
- data/lib/rubocop/cop/style/multiline_assignment_layout.rb +2 -5
- data/lib/rubocop/cop/style/multiline_block_chain.rb +3 -5
- data/lib/rubocop/cop/style/multiline_block_layout.rb +22 -15
- data/lib/rubocop/cop/style/multiline_method_call_brace_layout.rb +9 -0
- data/lib/rubocop/cop/style/multiline_method_call_indentation.rb +41 -20
- data/lib/rubocop/cop/style/multiline_operation_indentation.rb +6 -6
- data/lib/rubocop/cop/style/multiline_ternary_operator.rb +3 -5
- data/lib/rubocop/cop/style/mutable_constant.rb +21 -13
- data/lib/rubocop/cop/style/negated_if.rb +1 -1
- data/lib/rubocop/cop/style/negated_while.rb +3 -3
- data/lib/rubocop/cop/style/nested_modifier.rb +2 -4
- data/lib/rubocop/cop/style/next.rb +4 -4
- data/lib/rubocop/cop/style/non_nil_check.rb +18 -10
- data/lib/rubocop/cop/style/numeric_literal_prefix.rb +8 -0
- data/lib/rubocop/cop/style/numeric_predicate.rb +9 -9
- data/lib/rubocop/cop/style/one_line_conditional.rb +11 -1
- data/lib/rubocop/cop/style/op_method.rb +1 -1
- data/lib/rubocop/cop/style/option_hash.rb +8 -8
- data/lib/rubocop/cop/style/optional_arguments.rb +21 -8
- data/lib/rubocop/cop/style/parallel_assignment.rb +51 -35
- data/lib/rubocop/cop/style/parentheses_around_condition.rb +2 -2
- data/lib/rubocop/cop/style/percent_literal_delimiters.rb +1 -1
- data/lib/rubocop/cop/style/raise_args.rb +2 -2
- data/lib/rubocop/cop/style/redundant_begin.rb +1 -1
- data/lib/rubocop/cop/style/redundant_parentheses.rb +26 -15
- data/lib/rubocop/cop/style/redundant_return.rb +5 -5
- data/lib/rubocop/cop/style/redundant_self.rb +20 -11
- data/lib/rubocop/cop/style/regexp_literal.rb +16 -10
- data/lib/rubocop/cop/style/rescue_ensure_alignment.rb +8 -6
- data/lib/rubocop/cop/style/safe_navigation.rb +125 -0
- data/lib/rubocop/cop/style/self_assignment.rb +2 -2
- data/lib/rubocop/cop/style/semicolon.rb +9 -10
- data/lib/rubocop/cop/style/signal_exception.rb +2 -4
- data/lib/rubocop/cop/style/single_line_block_params.rb +1 -1
- data/lib/rubocop/cop/style/single_line_methods.rb +18 -11
- data/lib/rubocop/cop/style/space_after_method_name.rb +2 -3
- data/lib/rubocop/cop/style/space_after_not.rb +4 -6
- data/lib/rubocop/cop/style/space_around_block_parameters.rb +1 -2
- data/lib/rubocop/cop/style/space_around_equals_in_parameter_default.rb +1 -3
- data/lib/rubocop/cop/style/space_around_operators.rb +21 -16
- data/lib/rubocop/cop/style/space_before_block_braces.rb +2 -12
- data/lib/rubocop/cop/style/space_before_first_arg.rb +1 -3
- data/lib/rubocop/cop/style/space_inside_array_percent_literal.rb +1 -1
- data/lib/rubocop/cop/style/space_inside_block_braces.rb +33 -40
- data/lib/rubocop/cop/style/space_inside_hash_literal_braces.rb +38 -23
- data/lib/rubocop/cop/style/space_inside_percent_literal_delimiters.rb +1 -1
- data/lib/rubocop/cop/style/space_inside_string_interpolation.rb +26 -12
- data/lib/rubocop/cop/style/stabby_lambda_parentheses.rb +2 -4
- data/lib/rubocop/cop/style/symbol_array.rb +10 -10
- data/lib/rubocop/cop/style/symbol_proc.rb +28 -13
- data/lib/rubocop/cop/style/ternary_parentheses.rb +35 -5
- data/lib/rubocop/cop/style/trailing_blank_lines.rb +2 -4
- data/lib/rubocop/cop/style/trailing_underscore_variable.rb +29 -17
- data/lib/rubocop/cop/style/trivial_accessors.rb +6 -6
- data/lib/rubocop/cop/style/unless_else.rb +2 -6
- data/lib/rubocop/cop/style/unneeded_capital_w.rb +8 -4
- data/lib/rubocop/cop/style/unneeded_interpolation.rb +4 -5
- data/lib/rubocop/cop/style/unneeded_percent_q.rb +13 -7
- data/lib/rubocop/cop/style/variable_number.rb +79 -0
- data/lib/rubocop/cop/style/while_until_modifier.rb +1 -1
- data/lib/rubocop/cop/style/word_array.rb +25 -15
- data/lib/rubocop/cop/style/zero_length_predicate.rb +2 -0
- data/lib/rubocop/cop/util.rb +23 -4
- data/lib/rubocop/cop/variable_force.rb +59 -25
- data/lib/rubocop/cop/variable_force/locatable.rb +8 -6
- data/lib/rubocop/cop/variable_force/variable.rb +2 -2
- data/lib/rubocop/cop/variable_force/variable_table.rb +3 -3
- data/lib/rubocop/formatter/disabled_config_formatter.rb +16 -11
- data/lib/rubocop/formatter/formatter_set.rb +12 -10
- data/lib/rubocop/formatter/worst_offenders_formatter.rb +4 -4
- data/lib/rubocop/node_pattern.rb +79 -35
- data/lib/rubocop/options.rb +4 -4
- data/lib/rubocop/processed_source.rb +9 -5
- data/lib/rubocop/remote_config.rb +14 -10
- data/lib/rubocop/result_cache.rb +14 -6
- data/lib/rubocop/runner.rb +55 -34
- data/lib/rubocop/string_util.rb +9 -5
- data/lib/rubocop/target_finder.rb +1 -1
- data/lib/rubocop/token.rb +1 -1
- data/lib/rubocop/version.rb +1 -1
- metadata +15 -4
- data/lib/rubocop/cop/lint/useless_array_splat.rb +0 -56
- data/lib/rubocop/cop/performance/push_splat.rb +0 -47
data/lib/rubocop/string_util.rb
CHANGED
@@ -44,11 +44,7 @@ module RuboCop
|
|
44
44
|
transposition_count =
|
45
45
|
count_transpositions(common_chars_a, common_chars_b)
|
46
46
|
|
47
|
-
|
48
|
-
(matched_count / longer.size.to_f) +
|
49
|
-
((matched_count - transposition_count / 2) / matched_count.to_f)
|
50
|
-
|
51
|
-
sum / 3.0
|
47
|
+
compute_non_zero_distance(matched_count.to_f, transposition_count)
|
52
48
|
end
|
53
49
|
|
54
50
|
def find_common_characters
|
@@ -80,6 +76,14 @@ module RuboCop
|
|
80
76
|
end
|
81
77
|
end
|
82
78
|
|
79
|
+
def compute_non_zero_distance(matched_count, transposition_count)
|
80
|
+
sum = (matched_count / shorter.size.to_f) +
|
81
|
+
(matched_count / longer.size.to_f) +
|
82
|
+
((matched_count - transposition_count / 2) / matched_count)
|
83
|
+
|
84
|
+
sum / 3.0
|
85
|
+
end
|
86
|
+
|
83
87
|
def matching_index_range(origin)
|
84
88
|
min = origin - matching_window
|
85
89
|
min = 0 if min < 0
|
@@ -56,7 +56,7 @@ module RuboCop
|
|
56
56
|
def target_files_in_dir(base_dir = Dir.pwd)
|
57
57
|
# Support Windows: Backslashes from command-line -> forward slashes
|
58
58
|
if File::ALT_SEPARATOR
|
59
|
-
base_dir.gsub
|
59
|
+
base_dir = base_dir.gsub(File::ALT_SEPARATOR, File::SEPARATOR)
|
60
60
|
end
|
61
61
|
all_files = find_files(base_dir, File::FNM_DOTMATCH)
|
62
62
|
hidden_files = Set.new(all_files - find_files(base_dir, 0))
|
data/lib/rubocop/token.rb
CHANGED
data/lib/rubocop/version.rb
CHANGED
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: rubocop
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.43.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Bozhidar Batsov
|
@@ -10,7 +10,7 @@ authors:
|
|
10
10
|
autorequire:
|
11
11
|
bindir: bin
|
12
12
|
cert_chain: []
|
13
|
-
date: 2016-
|
13
|
+
date: 2016-09-19 00:00:00.000000000 Z
|
14
14
|
dependencies:
|
15
15
|
- !ruby/object:Gem::Dependency
|
16
16
|
name: rainbow
|
@@ -194,12 +194,13 @@ files:
|
|
194
194
|
- lib/rubocop/cop/lint/string_conversion_in_interpolation.rb
|
195
195
|
- lib/rubocop/cop/lint/syntax.rb
|
196
196
|
- lib/rubocop/cop/lint/underscore_prefixed_variable_name.rb
|
197
|
+
- lib/rubocop/cop/lint/unified_integer.rb
|
197
198
|
- lib/rubocop/cop/lint/unneeded_disable.rb
|
199
|
+
- lib/rubocop/cop/lint/unneeded_splat_expansion.rb
|
198
200
|
- lib/rubocop/cop/lint/unreachable_code.rb
|
199
201
|
- lib/rubocop/cop/lint/unused_block_argument.rb
|
200
202
|
- lib/rubocop/cop/lint/unused_method_argument.rb
|
201
203
|
- lib/rubocop/cop/lint/useless_access_modifier.rb
|
202
|
-
- lib/rubocop/cop/lint/useless_array_splat.rb
|
203
204
|
- lib/rubocop/cop/lint/useless_assignment.rb
|
204
205
|
- lib/rubocop/cop/lint/useless_comparison.rb
|
205
206
|
- lib/rubocop/cop/lint/useless_else_without_rescue.rb
|
@@ -225,6 +226,9 @@ files:
|
|
225
226
|
- lib/rubocop/cop/mixin/configurable_enforced_style.rb
|
226
227
|
- lib/rubocop/cop/mixin/configurable_max.rb
|
227
228
|
- lib/rubocop/cop/mixin/configurable_naming.rb
|
229
|
+
- lib/rubocop/cop/mixin/configurable_numbering.rb
|
230
|
+
- lib/rubocop/cop/mixin/def_node.rb
|
231
|
+
- lib/rubocop/cop/mixin/documentation_comment.rb
|
228
232
|
- lib/rubocop/cop/mixin/empty_lines_around_body.rb
|
229
233
|
- lib/rubocop/cop/mixin/end_keyword_alignment.rb
|
230
234
|
- lib/rubocop/cop/mixin/first_element_line_break.rb
|
@@ -246,6 +250,7 @@ files:
|
|
246
250
|
- lib/rubocop/cop/mixin/percent_literal.rb
|
247
251
|
- lib/rubocop/cop/mixin/preceding_following_alignment.rb
|
248
252
|
- lib/rubocop/cop/mixin/safe_assignment.rb
|
253
|
+
- lib/rubocop/cop/mixin/safe_mode.rb
|
249
254
|
- lib/rubocop/cop/mixin/space_after_punctuation.rb
|
250
255
|
- lib/rubocop/cop/mixin/space_before_punctuation.rb
|
251
256
|
- lib/rubocop/cop/mixin/space_inside.rb
|
@@ -266,7 +271,6 @@ files:
|
|
266
271
|
- lib/rubocop/cop/performance/flat_map.rb
|
267
272
|
- lib/rubocop/cop/performance/hash_each.rb
|
268
273
|
- lib/rubocop/cop/performance/lstrip_rstrip.rb
|
269
|
-
- lib/rubocop/cop/performance/push_splat.rb
|
270
274
|
- lib/rubocop/cop/performance/range_include.rb
|
271
275
|
- lib/rubocop/cop/performance/redundant_block_call.rb
|
272
276
|
- lib/rubocop/cop/performance/redundant_match.rb
|
@@ -275,6 +279,7 @@ files:
|
|
275
279
|
- lib/rubocop/cop/performance/reverse_each.rb
|
276
280
|
- lib/rubocop/cop/performance/sample.rb
|
277
281
|
- lib/rubocop/cop/performance/size.rb
|
282
|
+
- lib/rubocop/cop/performance/sort_with_block.rb
|
278
283
|
- lib/rubocop/cop/performance/start_with.rb
|
279
284
|
- lib/rubocop/cop/performance/string_replacement.rb
|
280
285
|
- lib/rubocop/cop/performance/times_map.rb
|
@@ -285,16 +290,19 @@ files:
|
|
285
290
|
- lib/rubocop/cop/rails/find_by.rb
|
286
291
|
- lib/rubocop/cop/rails/find_each.rb
|
287
292
|
- lib/rubocop/cop/rails/has_and_belongs_to_many.rb
|
293
|
+
- lib/rubocop/cop/rails/not_null_column.rb
|
288
294
|
- lib/rubocop/cop/rails/output.rb
|
289
295
|
- lib/rubocop/cop/rails/output_safety.rb
|
290
296
|
- lib/rubocop/cop/rails/pluralization_grammar.rb
|
291
297
|
- lib/rubocop/cop/rails/read_write_attribute.rb
|
292
298
|
- lib/rubocop/cop/rails/request_referer.rb
|
299
|
+
- lib/rubocop/cop/rails/safe_navigation.rb
|
293
300
|
- lib/rubocop/cop/rails/save_bang.rb
|
294
301
|
- lib/rubocop/cop/rails/scope_args.rb
|
295
302
|
- lib/rubocop/cop/rails/time_zone.rb
|
296
303
|
- lib/rubocop/cop/rails/uniq_before_pluck.rb
|
297
304
|
- lib/rubocop/cop/rails/validation.rb
|
305
|
+
- lib/rubocop/cop/security/json_load.rb
|
298
306
|
- lib/rubocop/cop/severity.rb
|
299
307
|
- lib/rubocop/cop/style/access_modifier_indentation.rb
|
300
308
|
- lib/rubocop/cop/style/accessor_method_name.rb
|
@@ -333,6 +341,7 @@ files:
|
|
333
341
|
- lib/rubocop/cop/style/copyright.rb
|
334
342
|
- lib/rubocop/cop/style/def_with_parentheses.rb
|
335
343
|
- lib/rubocop/cop/style/documentation.rb
|
344
|
+
- lib/rubocop/cop/style/documentation_method.rb
|
336
345
|
- lib/rubocop/cop/style/dot_position.rb
|
337
346
|
- lib/rubocop/cop/style/double_negation.rb
|
338
347
|
- lib/rubocop/cop/style/each_for_simple_loop.rb
|
@@ -437,6 +446,7 @@ files:
|
|
437
446
|
- lib/rubocop/cop/style/regexp_literal.rb
|
438
447
|
- lib/rubocop/cop/style/rescue_ensure_alignment.rb
|
439
448
|
- lib/rubocop/cop/style/rescue_modifier.rb
|
449
|
+
- lib/rubocop/cop/style/safe_navigation.rb
|
440
450
|
- lib/rubocop/cop/style/self_assignment.rb
|
441
451
|
- lib/rubocop/cop/style/semicolon.rb
|
442
452
|
- lib/rubocop/cop/style/send.rb
|
@@ -488,6 +498,7 @@ files:
|
|
488
498
|
- lib/rubocop/cop/style/unneeded_percent_q.rb
|
489
499
|
- lib/rubocop/cop/style/variable_interpolation.rb
|
490
500
|
- lib/rubocop/cop/style/variable_name.rb
|
501
|
+
- lib/rubocop/cop/style/variable_number.rb
|
491
502
|
- lib/rubocop/cop/style/when_then.rb
|
492
503
|
- lib/rubocop/cop/style/while_until_do.rb
|
493
504
|
- lib/rubocop/cop/style/while_until_modifier.rb
|
@@ -1,56 +0,0 @@
|
|
1
|
-
# encoding: utf-8
|
2
|
-
# frozen_string_literal: true
|
3
|
-
|
4
|
-
module RuboCop
|
5
|
-
module Cop
|
6
|
-
module Lint
|
7
|
-
# This cop checks for unncessary array splats.
|
8
|
-
#
|
9
|
-
# @example
|
10
|
-
#
|
11
|
-
# # bad:
|
12
|
-
#
|
13
|
-
# a, b = *[1, 2, 3]
|
14
|
-
#
|
15
|
-
# # good:
|
16
|
-
#
|
17
|
-
# a, b = [1, 2, 3]
|
18
|
-
#
|
19
|
-
# # bad:
|
20
|
-
#
|
21
|
-
# a = *[1, 2, 3]
|
22
|
-
#
|
23
|
-
# # good:
|
24
|
-
#
|
25
|
-
# a = [1, 2, 3]
|
26
|
-
class UselessArraySplat < Cop
|
27
|
-
MSG = 'Unnecessary array splat.'.freeze
|
28
|
-
ARRAY_NEW_PATTERN = '(send (const nil :Array) :new ...)'.freeze
|
29
|
-
|
30
|
-
%w(m lv cv iv c gv).each do |var_type|
|
31
|
-
define_method("on_#{var_type}asgn") do |node|
|
32
|
-
*, rhs = *node
|
33
|
-
|
34
|
-
return unless rhs.is_a?(Node) && rhs.array_type?
|
35
|
-
|
36
|
-
add_offense(rhs, splat_source_range(rhs)) if array_splat?(rhs)
|
37
|
-
end
|
38
|
-
end
|
39
|
-
|
40
|
-
private
|
41
|
-
|
42
|
-
def_node_matcher :array_splat?, <<-PATTERN
|
43
|
-
(array (splat {(array ...) (block #{ARRAY_NEW_PATTERN} ...) #{ARRAY_NEW_PATTERN}} ...))
|
44
|
-
PATTERN
|
45
|
-
|
46
|
-
def splat_source_range(node)
|
47
|
-
node.loc.expression.begin.resize(1)
|
48
|
-
end
|
49
|
-
|
50
|
-
def autocorrect(node)
|
51
|
-
->(corrector) { corrector.remove(splat_source_range(node)) }
|
52
|
-
end
|
53
|
-
end
|
54
|
-
end
|
55
|
-
end
|
56
|
-
end
|
@@ -1,47 +0,0 @@
|
|
1
|
-
# encoding: utf-8
|
2
|
-
# frozen_string_literal: true
|
3
|
-
|
4
|
-
module RuboCop
|
5
|
-
module Cop
|
6
|
-
module Performance
|
7
|
-
# This cop is used to identify usages of
|
8
|
-
#
|
9
|
-
# @example
|
10
|
-
# # bad
|
11
|
-
# [].push(*a)
|
12
|
-
#
|
13
|
-
# # good
|
14
|
-
# [].concat(a)
|
15
|
-
class PushSplat < Cop
|
16
|
-
include Parentheses
|
17
|
-
|
18
|
-
MSG = 'Use `concat` instead of `push(*)`.'.freeze
|
19
|
-
|
20
|
-
def_node_matcher :push_splat, <<-END
|
21
|
-
(send _ :push (splat ...))
|
22
|
-
END
|
23
|
-
|
24
|
-
def on_send(node)
|
25
|
-
push_splat(node) do
|
26
|
-
add_offense(node, :expression, MSG)
|
27
|
-
end
|
28
|
-
end
|
29
|
-
|
30
|
-
def autocorrect(node)
|
31
|
-
_receiver, _method, splat = *node
|
32
|
-
body, = *splat
|
33
|
-
lambda do |corrector|
|
34
|
-
corrector.replace(node.location.selector, 'concat')
|
35
|
-
|
36
|
-
source = if parens_required?(splat)
|
37
|
-
"(#{body.source})"
|
38
|
-
else
|
39
|
-
body.source
|
40
|
-
end
|
41
|
-
corrector.replace(splat.loc.expression, source)
|
42
|
-
end
|
43
|
-
end
|
44
|
-
end
|
45
|
-
end
|
46
|
-
end
|
47
|
-
end
|