rubocop 0.49.1 → 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.
- checksums.yaml +4 -4
- data/README.md +6 -9
- data/bin/rubocop +1 -1
- data/config/default.yml +264 -118
- data/config/disabled.yml +13 -9
- data/config/enabled.yml +1156 -918
- data/lib/rubocop.rb +555 -489
- data/lib/rubocop/ast/builder.rb +6 -1
- data/lib/rubocop/ast/node.rb +68 -52
- data/lib/rubocop/ast/node/args_node.rb +15 -10
- data/lib/rubocop/ast/node/array_node.rb +10 -1
- data/lib/rubocop/ast/node/block_node.rb +9 -0
- data/lib/rubocop/ast/node/def_node.rb +71 -0
- data/lib/rubocop/ast/node/for_node.rb +8 -0
- data/lib/rubocop/ast/node/if_node.rb +10 -2
- data/lib/rubocop/ast/node/mixin/basic_literal_node.rb +16 -0
- data/lib/rubocop/ast/node/mixin/collection_node.rb +15 -0
- data/lib/rubocop/ast/node/mixin/method_dispatch_node.rb +174 -0
- data/lib/rubocop/ast/node/mixin/method_identifier_predicates.rb +89 -0
- data/lib/rubocop/ast/node/mixin/parameterized_node.rb +18 -31
- data/lib/rubocop/ast/node/regexp_node.rb +35 -0
- data/lib/rubocop/ast/node/send_node.rb +21 -150
- data/lib/rubocop/ast/node/str_node.rb +14 -0
- data/lib/rubocop/ast/node/super_node.rb +3 -24
- data/lib/rubocop/ast/node/symbol_node.rb +20 -0
- data/lib/rubocop/ast/node/yield_node.rb +21 -0
- data/lib/rubocop/ast/traversal.rb +7 -7
- data/lib/rubocop/cached_data.rb +1 -6
- data/lib/rubocop/cli.rb +59 -13
- data/lib/rubocop/comment_config.rb +2 -5
- data/lib/rubocop/config.rb +136 -29
- data/lib/rubocop/config_loader.rb +61 -104
- data/lib/rubocop/config_loader_resolver.rb +102 -4
- data/lib/rubocop/cop/autocorrect_logic.rb +1 -1
- data/lib/rubocop/cop/bundler/duplicated_gem.rb +13 -11
- data/lib/rubocop/cop/bundler/insecure_protocol_source.rb +67 -0
- data/lib/rubocop/cop/bundler/ordered_gems.rb +7 -58
- data/lib/rubocop/cop/commissioner.rb +6 -3
- data/lib/rubocop/cop/cop.rb +11 -6
- data/lib/rubocop/cop/gemspec/duplicated_assignment.rb +102 -0
- data/lib/rubocop/cop/gemspec/ordered_dependencies.rb +97 -0
- data/lib/rubocop/cop/gemspec/required_ruby_version.rb +87 -0
- data/lib/rubocop/cop/generator.rb +122 -25
- data/lib/rubocop/cop/internal_affairs.rb +6 -2
- data/lib/rubocop/cop/internal_affairs/node_destructuring.rb +46 -0
- data/lib/rubocop/cop/internal_affairs/node_type_predicate.rb +16 -5
- data/lib/rubocop/cop/internal_affairs/offense_location_keyword.rb +54 -0
- data/lib/rubocop/cop/internal_affairs/redundant_location_argument.rb +59 -0
- data/lib/rubocop/cop/internal_affairs/redundant_message_argument.rb +71 -0
- data/lib/rubocop/cop/internal_affairs/useless_message_assertion.rb +3 -3
- data/lib/rubocop/cop/layout/access_modifier_indentation.rb +6 -10
- data/lib/rubocop/cop/layout/align_array.rb +2 -2
- data/lib/rubocop/cop/layout/align_hash.rb +18 -18
- data/lib/rubocop/cop/layout/align_parameters.rb +11 -23
- data/lib/rubocop/cop/layout/block_end_newline.rb +20 -6
- data/lib/rubocop/cop/layout/case_indentation.rb +15 -18
- data/lib/rubocop/cop/layout/class_structure.rb +306 -0
- data/lib/rubocop/cop/layout/closing_parenthesis_indentation.rb +7 -6
- data/lib/rubocop/cop/layout/comment_indentation.rb +42 -3
- data/lib/rubocop/cop/layout/dot_position.rb +31 -13
- data/lib/rubocop/cop/layout/else_alignment.rb +37 -17
- data/lib/rubocop/cop/layout/empty_line_after_magic_comment.rb +1 -1
- data/lib/rubocop/cop/layout/empty_line_between_defs.rb +22 -18
- data/lib/rubocop/cop/layout/empty_lines.rb +16 -2
- data/lib/rubocop/cop/layout/empty_lines_around_access_modifier.rb +23 -6
- data/lib/rubocop/cop/layout/empty_lines_around_arguments.rb +89 -0
- data/lib/rubocop/cop/layout/empty_lines_around_begin_body.rb +2 -2
- data/lib/rubocop/cop/layout/empty_lines_around_block_body.rb +4 -8
- data/lib/rubocop/cop/layout/empty_lines_around_class_body.rb +30 -5
- data/lib/rubocop/cop/layout/empty_lines_around_exception_handling_keywords.rb +10 -6
- data/lib/rubocop/cop/layout/empty_lines_around_method_body.rb +5 -5
- data/lib/rubocop/cop/layout/empty_lines_around_module_body.rb +22 -7
- data/lib/rubocop/cop/layout/end_of_line.rb +2 -2
- data/lib/rubocop/cop/layout/extra_spacing.rb +23 -26
- data/lib/rubocop/cop/layout/first_method_parameter_line_break.rb +3 -3
- data/lib/rubocop/cop/layout/first_parameter_indentation.rb +9 -3
- data/lib/rubocop/cop/layout/indent_array.rb +68 -21
- data/lib/rubocop/cop/layout/indent_hash.rb +71 -26
- data/lib/rubocop/cop/layout/indent_heredoc.rb +70 -35
- data/lib/rubocop/cop/layout/indentation_consistency.rb +1 -2
- data/lib/rubocop/cop/layout/indentation_width.rb +40 -27
- data/lib/rubocop/cop/layout/initial_indentation.rb +10 -7
- data/lib/rubocop/cop/layout/leading_comment_space.rb +32 -17
- data/lib/rubocop/cop/layout/multiline_array_brace_layout.rb +47 -14
- data/lib/rubocop/cop/layout/multiline_assignment_layout.rb +12 -11
- data/lib/rubocop/cop/layout/multiline_block_layout.rb +19 -16
- data/lib/rubocop/cop/layout/multiline_hash_brace_layout.rb +46 -13
- data/lib/rubocop/cop/layout/multiline_method_call_indentation.rb +29 -27
- data/lib/rubocop/cop/layout/multiline_method_definition_brace_layout.rb +7 -3
- data/lib/rubocop/cop/layout/multiline_operation_indentation.rb +6 -0
- data/lib/rubocop/cop/layout/rescue_ensure_alignment.rb +12 -4
- data/lib/rubocop/cop/layout/space_after_colon.rb +13 -6
- data/lib/rubocop/cop/layout/space_after_comma.rb +11 -1
- data/lib/rubocop/cop/layout/space_after_method_name.rb +8 -6
- data/lib/rubocop/cop/layout/space_after_not.rb +1 -1
- data/lib/rubocop/cop/layout/space_after_semicolon.rb +8 -1
- data/lib/rubocop/cop/layout/space_around_block_parameters.rb +32 -25
- data/lib/rubocop/cop/layout/space_around_equals_in_parameter_default.rb +28 -17
- data/lib/rubocop/cop/layout/space_around_keyword.rb +22 -16
- data/lib/rubocop/cop/layout/space_around_operators.rb +27 -14
- data/lib/rubocop/cop/layout/space_before_block_braces.rb +61 -12
- data/lib/rubocop/cop/layout/space_before_comma.rb +12 -1
- data/lib/rubocop/cop/layout/space_before_comment.rb +10 -5
- data/lib/rubocop/cop/layout/space_before_first_arg.rb +5 -4
- data/lib/rubocop/cop/layout/space_before_semicolon.rb +8 -1
- data/lib/rubocop/cop/layout/space_in_lambda_literal.rb +12 -14
- data/lib/rubocop/cop/layout/space_inside_array_literal_brackets.rb +235 -0
- data/lib/rubocop/cop/layout/space_inside_array_percent_literal.rb +4 -4
- data/lib/rubocop/cop/layout/space_inside_block_braces.rb +89 -18
- data/lib/rubocop/cop/layout/space_inside_hash_literal_braces.rb +62 -36
- data/lib/rubocop/cop/layout/space_inside_parens.rb +40 -3
- data/lib/rubocop/cop/layout/space_inside_percent_literal_delimiters.rb +1 -1
- data/lib/rubocop/cop/layout/space_inside_range_literal.rb +15 -15
- data/lib/rubocop/cop/layout/space_inside_reference_brackets.rb +81 -0
- data/lib/rubocop/cop/layout/space_inside_string_interpolation.rb +32 -17
- data/lib/rubocop/cop/layout/tab.rb +7 -4
- data/lib/rubocop/cop/layout/trailing_blank_lines.rb +11 -9
- data/lib/rubocop/cop/layout/trailing_whitespace.rb +1 -1
- data/lib/rubocop/cop/lint/ambiguous_block_association.rb +12 -19
- data/lib/rubocop/cop/lint/assignment_in_condition.rb +16 -2
- data/lib/rubocop/cop/lint/block_alignment.rb +42 -30
- data/lib/rubocop/cop/lint/boolean_symbol.rb +38 -0
- data/lib/rubocop/cop/lint/circular_argument_reference.rb +3 -14
- data/lib/rubocop/cop/lint/condition_position.rb +5 -1
- data/lib/rubocop/cop/lint/debugger.rb +18 -11
- data/lib/rubocop/cop/lint/def_end_alignment.rb +9 -14
- data/lib/rubocop/cop/lint/deprecated_class_methods.rb +4 -4
- data/lib/rubocop/cop/lint/duplicate_case_condition.rb +3 -3
- data/lib/rubocop/cop/lint/duplicate_methods.rb +75 -5
- data/lib/rubocop/cop/lint/duplicated_key.rb +1 -1
- data/lib/rubocop/cop/lint/each_with_object_argument.rb +1 -1
- data/lib/rubocop/cop/lint/else_layout.rb +3 -3
- data/lib/rubocop/cop/lint/empty_ensure.rb +1 -1
- data/lib/rubocop/cop/lint/empty_expression.rb +1 -1
- data/lib/rubocop/cop/lint/empty_interpolation.rb +1 -1
- data/lib/rubocop/cop/lint/empty_when.rb +1 -1
- data/lib/rubocop/cop/lint/end_alignment.rb +13 -14
- data/lib/rubocop/cop/lint/end_in_method.rb +1 -1
- data/lib/rubocop/cop/lint/ensure_return.rb +1 -1
- data/lib/rubocop/cop/lint/float_out_of_range.rb +5 -5
- data/lib/rubocop/cop/lint/format_parameter_mismatch.rb +36 -41
- data/lib/rubocop/cop/lint/handle_exceptions.rb +1 -1
- data/lib/rubocop/cop/lint/implicit_string_concatenation.rb +1 -1
- data/lib/rubocop/cop/lint/ineffective_access_modifier.rb +25 -20
- data/lib/rubocop/cop/lint/inherit_exception.rb +16 -19
- data/lib/rubocop/cop/lint/interpolation_check.rb +37 -0
- data/lib/rubocop/cop/lint/{literal_in_condition.rb → literal_as_condition.rb} +21 -7
- data/lib/rubocop/cop/lint/literal_in_interpolation.rb +1 -1
- data/lib/rubocop/cop/lint/loop.rb +1 -1
- data/lib/rubocop/cop/lint/missing_cop_enable_directive.rb +81 -0
- data/lib/rubocop/cop/lint/multiple_compare.rb +1 -1
- data/lib/rubocop/cop/lint/nested_method_definition.rb +6 -8
- data/lib/rubocop/cop/lint/nested_percent_literal.rb +58 -0
- data/lib/rubocop/cop/lint/next_without_accumulator.rb +1 -1
- data/lib/rubocop/cop/lint/non_local_exit_from_iterator.rb +4 -4
- data/lib/rubocop/cop/lint/parentheses_as_grouped_expression.rb +4 -3
- data/lib/rubocop/cop/lint/percent_string_array.rb +13 -22
- data/lib/rubocop/cop/lint/percent_symbol_array.rb +12 -12
- data/lib/rubocop/cop/lint/rand_one.rb +8 -2
- data/lib/rubocop/cop/lint/redundant_with_index.rb +80 -0
- data/lib/rubocop/cop/lint/redundant_with_object.rb +81 -0
- data/lib/rubocop/cop/lint/regexp_as_condition.rb +29 -0
- data/lib/rubocop/cop/lint/require_parentheses.rb +5 -3
- data/lib/rubocop/cop/lint/rescue_exception.rb +1 -1
- data/lib/rubocop/cop/lint/rescue_type.rb +18 -9
- data/lib/rubocop/cop/lint/return_in_void_context.rb +74 -0
- data/lib/rubocop/cop/lint/safe_navigation_chain.rb +1 -1
- data/lib/rubocop/cop/lint/script_permission.rb +8 -1
- data/lib/rubocop/cop/lint/shadowed_argument.rb +146 -0
- data/lib/rubocop/cop/lint/shadowed_exception.rb +37 -10
- data/lib/rubocop/cop/lint/shadowing_outer_local_variable.rb +1 -1
- data/lib/rubocop/cop/lint/string_conversion_in_interpolation.rb +7 -7
- data/lib/rubocop/cop/lint/syntax.rb +23 -20
- data/lib/rubocop/cop/lint/underscore_prefixed_variable_name.rb +1 -1
- data/lib/rubocop/cop/lint/unified_integer.rb +5 -4
- data/lib/rubocop/cop/lint/unneeded_disable.rb +41 -16
- data/lib/rubocop/cop/lint/unneeded_require_statement.rb +51 -0
- data/lib/rubocop/cop/lint/unneeded_splat_expansion.rb +45 -19
- data/lib/rubocop/cop/lint/unreachable_code.rb +53 -8
- data/lib/rubocop/cop/lint/unused_method_argument.rb +2 -1
- data/lib/rubocop/cop/lint/uri_escape_unescape.rb +74 -0
- data/lib/rubocop/cop/lint/uri_regexp.rb +73 -0
- data/lib/rubocop/cop/lint/useless_access_modifier.rb +12 -16
- data/lib/rubocop/cop/lint/useless_assignment.rb +1 -1
- data/lib/rubocop/cop/lint/useless_comparison.rb +1 -1
- data/lib/rubocop/cop/lint/useless_setter_call.rb +15 -12
- data/lib/rubocop/cop/lint/void.rb +38 -27
- data/lib/rubocop/cop/message_annotator.rb +4 -2
- data/lib/rubocop/cop/metrics/abc_size.rb +2 -2
- data/lib/rubocop/cop/metrics/block_nesting.rb +1 -1
- data/lib/rubocop/cop/metrics/class_length.rb +3 -1
- data/lib/rubocop/cop/metrics/cyclomatic_complexity.rb +2 -1
- data/lib/rubocop/cop/metrics/line_length.rb +8 -5
- data/lib/rubocop/cop/metrics/method_length.rb +8 -3
- data/lib/rubocop/cop/metrics/module_length.rb +3 -1
- data/lib/rubocop/cop/metrics/parameter_lists.rb +14 -5
- data/lib/rubocop/cop/metrics/perceived_complexity.rb +2 -1
- data/lib/rubocop/cop/mixin/array_hash_indentation.rb +3 -2
- data/lib/rubocop/cop/mixin/autocorrect_alignment.rb +2 -2
- data/lib/rubocop/cop/mixin/code_length.rb +1 -1
- data/lib/rubocop/cop/mixin/configurable_formatting.rb +1 -1
- data/lib/rubocop/cop/mixin/def_node.rb +1 -1
- data/lib/rubocop/cop/mixin/documentation_comment.rb +1 -1
- data/lib/rubocop/cop/mixin/empty_lines_around_body.rb +14 -7
- data/lib/rubocop/cop/mixin/empty_parameter.rb +23 -0
- data/lib/rubocop/cop/mixin/end_keyword_alignment.rb +8 -4
- data/lib/rubocop/cop/mixin/enforce_superclass.rb +3 -3
- data/lib/rubocop/cop/mixin/first_element_line_break.rb +12 -3
- data/lib/rubocop/cop/mixin/heredoc.rb +28 -0
- data/lib/rubocop/cop/mixin/method_complexity.rb +33 -7
- data/lib/rubocop/cop/mixin/multiline_expression_indentation.rb +74 -33
- data/lib/rubocop/cop/mixin/multiline_literal_brace_layout.rb +34 -8
- data/lib/rubocop/cop/mixin/negative_conditional.rb +4 -1
- data/lib/rubocop/cop/mixin/ordered_gem_node.rb +67 -0
- data/lib/rubocop/cop/mixin/parentheses.rb +12 -0
- data/lib/rubocop/cop/mixin/parser_diagnostic.rb +4 -1
- data/lib/rubocop/cop/mixin/percent_array.rb +52 -0
- data/lib/rubocop/cop/mixin/space_after_punctuation.rb +9 -8
- data/lib/rubocop/cop/mixin/space_before_punctuation.rb +11 -10
- data/lib/rubocop/cop/mixin/statement_modifier.rb +7 -17
- data/lib/rubocop/cop/mixin/string_help.rb +1 -1
- data/lib/rubocop/cop/mixin/string_literals_help.rb +1 -1
- data/lib/rubocop/cop/mixin/surrounding_space.rb +95 -8
- data/lib/rubocop/cop/mixin/too_many_lines.rb +2 -2
- data/lib/rubocop/cop/mixin/trailing_comma.rb +25 -17
- data/lib/rubocop/cop/mixin/unused_argument.rb +6 -2
- data/lib/rubocop/cop/naming/accessor_method_name.rb +55 -0
- data/lib/rubocop/cop/{style → naming}/ascii_identifiers.rb +35 -2
- data/lib/rubocop/cop/{style/op_method.rb → naming/binary_operator_parameter_name.rb} +7 -6
- data/lib/rubocop/cop/naming/class_and_module_camel_case.rb +33 -0
- data/lib/rubocop/cop/naming/constant_name.rb +58 -0
- data/lib/rubocop/cop/{style → naming}/file_name.rb +28 -13
- data/lib/rubocop/cop/naming/heredoc_delimiter_case.rb +62 -0
- data/lib/rubocop/cop/naming/heredoc_delimiter_naming.rb +59 -0
- data/lib/rubocop/cop/naming/method_name.rb +40 -0
- data/lib/rubocop/cop/naming/predicate_name.rb +101 -0
- data/lib/rubocop/cop/naming/variable_name.rb +50 -0
- data/lib/rubocop/cop/{style → naming}/variable_number.rb +11 -28
- data/lib/rubocop/cop/offense.rb +6 -1
- data/lib/rubocop/cop/performance/caller.rb +39 -11
- data/lib/rubocop/cop/performance/case_when_splat.rb +3 -7
- data/lib/rubocop/cop/performance/casecmp.rb +9 -8
- data/lib/rubocop/cop/performance/compare_with_block.rb +23 -13
- data/lib/rubocop/cop/performance/count.rb +7 -4
- data/lib/rubocop/cop/performance/detect.rb +9 -6
- data/lib/rubocop/cop/performance/double_start_end_with.rb +12 -20
- data/lib/rubocop/cop/performance/end_with.rb +6 -6
- data/lib/rubocop/cop/performance/fixed_size.rb +1 -1
- data/lib/rubocop/cop/performance/flat_map.rb +5 -2
- data/lib/rubocop/cop/performance/hash_each_methods.rb +85 -40
- data/lib/rubocop/cop/performance/lstrip_rstrip.rb +9 -6
- data/lib/rubocop/cop/performance/range_include.rb +3 -3
- data/lib/rubocop/cop/performance/redundant_block_call.rb +28 -28
- data/lib/rubocop/cop/performance/redundant_match.rb +13 -12
- data/lib/rubocop/cop/performance/redundant_merge.rb +44 -26
- data/lib/rubocop/cop/performance/redundant_sort_by.rb +9 -6
- data/lib/rubocop/cop/performance/regexp_match.rb +19 -10
- data/lib/rubocop/cop/performance/reverse_each.rb +1 -1
- data/lib/rubocop/cop/performance/sample.rb +1 -1
- data/lib/rubocop/cop/performance/size.rb +3 -3
- data/lib/rubocop/cop/performance/start_with.rb +6 -6
- data/lib/rubocop/cop/performance/string_replacement.rb +6 -6
- data/lib/rubocop/cop/performance/times_map.rb +32 -22
- data/lib/rubocop/cop/performance/unfreeze_string.rb +50 -0
- data/lib/rubocop/cop/performance/uri_default_parser.rb +47 -0
- data/lib/rubocop/cop/rails/action_filter.rb +23 -1
- data/lib/rubocop/cop/rails/active_support_aliases.rb +4 -5
- data/lib/rubocop/cop/rails/application_job.rb +5 -3
- data/lib/rubocop/cop/rails/application_record.rb +5 -3
- data/lib/rubocop/cop/rails/blank.rb +20 -17
- data/lib/rubocop/cop/rails/create_table_with_timestamps.rb +82 -0
- data/lib/rubocop/cop/rails/date.rb +7 -6
- data/lib/rubocop/cop/rails/delegate.rb +53 -29
- data/lib/rubocop/cop/rails/delegate_allow_blank.rb +4 -4
- data/lib/rubocop/cop/rails/dynamic_find_by.rb +2 -2
- data/lib/rubocop/cop/rails/enum_uniqueness.rb +4 -4
- data/lib/rubocop/cop/rails/environment_comparison.rb +66 -0
- data/lib/rubocop/cop/rails/exit.rb +8 -1
- data/lib/rubocop/cop/rails/file_path.rb +8 -11
- data/lib/rubocop/cop/rails/find_by.rb +2 -1
- data/lib/rubocop/cop/rails/find_each.rb +1 -1
- data/lib/rubocop/cop/rails/has_and_belongs_to_many.rb +8 -1
- data/lib/rubocop/cop/rails/has_many_or_has_one_dependent.rb +76 -0
- data/lib/rubocop/cop/rails/http_positional_arguments.rb +40 -44
- data/lib/rubocop/cop/rails/inverse_of.rb +96 -0
- data/lib/rubocop/cop/rails/lexically_scoped_action_filter.rb +112 -0
- data/lib/rubocop/cop/rails/not_null_column.rb +6 -6
- data/lib/rubocop/cop/rails/output.rb +11 -2
- data/lib/rubocop/cop/rails/output_safety.rb +16 -21
- data/lib/rubocop/cop/rails/pluralization_grammar.rb +10 -10
- data/lib/rubocop/cop/rails/presence.rb +105 -0
- data/lib/rubocop/cop/rails/present.rb +14 -17
- data/lib/rubocop/cop/rails/read_write_attribute.rb +13 -13
- data/lib/rubocop/cop/rails/redundant_receiver_in_with_options.rb +91 -0
- data/lib/rubocop/cop/rails/relative_date_constant.rb +11 -11
- data/lib/rubocop/cop/rails/request_referer.rb +3 -3
- data/lib/rubocop/cop/rails/reversible_migration.rb +36 -35
- data/lib/rubocop/cop/rails/safe_navigation.rb +7 -8
- data/lib/rubocop/cop/rails/save_bang.rb +19 -17
- data/lib/rubocop/cop/rails/scope_args.rb +2 -2
- data/lib/rubocop/cop/rails/skips_model_validations.rb +2 -2
- data/lib/rubocop/cop/rails/time_zone.rb +3 -2
- data/lib/rubocop/cop/rails/uniq_before_pluck.rb +4 -2
- data/lib/rubocop/cop/rails/unknown_env.rb +63 -0
- data/lib/rubocop/cop/rails/validation.rb +8 -8
- data/lib/rubocop/cop/registry.rb +2 -1
- data/lib/rubocop/cop/security/eval.rb +4 -4
- data/lib/rubocop/cop/security/json_load.rb +7 -5
- data/lib/rubocop/cop/security/marshal_load.rb +8 -6
- data/lib/rubocop/cop/security/yaml_load.rb +4 -4
- data/lib/rubocop/cop/style/alias.rb +49 -27
- data/lib/rubocop/cop/style/and_or.rb +65 -45
- data/lib/rubocop/cop/style/array_join.rb +10 -1
- data/lib/rubocop/cop/style/ascii_comments.rb +24 -4
- data/lib/rubocop/cop/style/attr.rb +15 -5
- data/lib/rubocop/cop/style/auto_resource_cleanup.rb +7 -5
- data/lib/rubocop/cop/style/bare_percent_literals.rb +31 -10
- data/lib/rubocop/cop/style/begin_block.rb +1 -1
- data/lib/rubocop/cop/style/block_comments.rb +17 -3
- data/lib/rubocop/cop/style/block_delimiters.rb +82 -16
- data/lib/rubocop/cop/style/braces_around_hash_parameters.rb +68 -32
- data/lib/rubocop/cop/style/case_equality.rb +13 -1
- data/lib/rubocop/cop/style/character_literal.rb +10 -0
- data/lib/rubocop/cop/style/class_and_module_children.rb +8 -4
- data/lib/rubocop/cop/style/class_check.rb +29 -10
- data/lib/rubocop/cop/style/class_methods.rb +10 -9
- data/lib/rubocop/cop/style/class_vars.rb +5 -4
- data/lib/rubocop/cop/style/collection_methods.rb +5 -3
- data/lib/rubocop/cop/style/colon_method_call.rb +18 -2
- data/lib/rubocop/cop/style/colon_method_definition.rb +36 -0
- data/lib/rubocop/cop/style/command_literal.rb +90 -30
- data/lib/rubocop/cop/style/comment_annotation.rb +39 -11
- data/lib/rubocop/cop/style/commented_keyword.rb +84 -0
- data/lib/rubocop/cop/style/conditional_assignment.rb +41 -41
- data/lib/rubocop/cop/style/copyright.rb +27 -28
- data/lib/rubocop/cop/style/date_time.rb +44 -0
- data/lib/rubocop/cop/style/def_with_parentheses.rb +31 -5
- data/lib/rubocop/cop/style/dir.rb +48 -0
- data/lib/rubocop/cop/style/documentation.rb +17 -2
- data/lib/rubocop/cop/style/documentation_method.rb +2 -6
- data/lib/rubocop/cop/style/double_negation.rb +1 -1
- data/lib/rubocop/cop/style/each_for_simple_loop.rb +8 -8
- data/lib/rubocop/cop/style/each_with_object.rb +6 -5
- data/lib/rubocop/cop/style/empty_block_parameter.rb +47 -0
- data/lib/rubocop/cop/style/empty_case_condition.rb +3 -3
- data/lib/rubocop/cop/style/empty_else.rb +55 -24
- data/lib/rubocop/cop/style/empty_lambda_parameter.rb +43 -0
- data/lib/rubocop/cop/style/empty_literal.rb +25 -14
- data/lib/rubocop/cop/style/empty_method.rb +29 -25
- data/lib/rubocop/cop/style/encoding.rb +8 -51
- data/lib/rubocop/cop/style/end_block.rb +1 -1
- data/lib/rubocop/cop/style/eval_with_location.rb +146 -0
- data/lib/rubocop/cop/style/even_odd.rb +4 -2
- data/lib/rubocop/cop/style/extend_self.rb +92 -0
- data/lib/rubocop/cop/style/flip_flop.rb +13 -2
- data/lib/rubocop/cop/style/for.rb +6 -2
- data/lib/rubocop/cop/style/format_string.rb +33 -5
- data/lib/rubocop/cop/style/format_string_token.rb +17 -15
- data/lib/rubocop/cop/style/frozen_string_literal_comment.rb +7 -6
- data/lib/rubocop/cop/style/global_vars.rb +12 -2
- data/lib/rubocop/cop/style/guard_clause.rb +6 -4
- data/lib/rubocop/cop/style/hash_syntax.rb +56 -56
- data/lib/rubocop/cop/style/identical_conditional_branches.rb +12 -8
- data/lib/rubocop/cop/style/if_inside_else.rb +11 -11
- data/lib/rubocop/cop/style/if_unless_modifier.rb +8 -7
- data/lib/rubocop/cop/style/if_unless_modifier_of_if_unless.rb +3 -2
- data/lib/rubocop/cop/style/if_with_semicolon.rb +10 -1
- data/lib/rubocop/cop/style/implicit_runtime_error.rb +7 -6
- data/lib/rubocop/cop/style/infinite_loop.rb +4 -4
- data/lib/rubocop/cop/style/inline_comment.rb +1 -1
- data/lib/rubocop/cop/style/inverse_methods.rb +24 -14
- data/lib/rubocop/cop/style/lambda.rb +45 -43
- data/lib/rubocop/cop/style/lambda_call.rb +37 -10
- data/lib/rubocop/cop/style/line_end_concatenation.rb +5 -5
- data/lib/rubocop/cop/style/method_call_with_args_parentheses.rb +3 -19
- data/lib/rubocop/cop/style/method_call_without_args_parentheses.rb +6 -4
- data/lib/rubocop/cop/style/method_called_on_do_end_block.rb +1 -1
- data/lib/rubocop/cop/style/method_def_parentheses.rb +20 -25
- data/lib/rubocop/cop/style/method_missing.rb +13 -26
- data/lib/rubocop/cop/style/min_max.rb +68 -0
- data/lib/rubocop/cop/style/missing_else.rb +20 -6
- data/lib/rubocop/cop/style/mixin_grouping.rb +31 -21
- data/lib/rubocop/cop/style/mixin_usage.rb +71 -0
- data/lib/rubocop/cop/style/module_function.rb +27 -11
- data/lib/rubocop/cop/style/multiline_block_chain.rb +1 -1
- data/lib/rubocop/cop/style/multiline_if_modifier.rb +8 -4
- data/lib/rubocop/cop/style/multiline_if_then.rb +15 -13
- data/lib/rubocop/cop/style/multiline_memoization.rb +33 -17
- data/lib/rubocop/cop/style/multiline_ternary_operator.rb +1 -1
- data/lib/rubocop/cop/style/multiple_comparison.rb +1 -1
- data/lib/rubocop/cop/style/mutable_constant.rb +11 -15
- data/lib/rubocop/cop/style/negated_if.rb +27 -31
- data/lib/rubocop/cop/style/negated_while.rb +1 -5
- data/lib/rubocop/cop/style/nested_modifier.rb +1 -1
- data/lib/rubocop/cop/style/nested_parenthesized_calls.rb +26 -23
- data/lib/rubocop/cop/style/nested_ternary_operator.rb +1 -1
- data/lib/rubocop/cop/style/next.rb +41 -12
- data/lib/rubocop/cop/style/nil_comparison.rb +8 -8
- data/lib/rubocop/cop/style/non_nil_check.rb +41 -38
- data/lib/rubocop/cop/style/not.rb +15 -5
- data/lib/rubocop/cop/style/numeric_literal_prefix.rb +8 -4
- data/lib/rubocop/cop/style/numeric_literals.rb +9 -9
- data/lib/rubocop/cop/style/numeric_predicate.rb +21 -21
- data/lib/rubocop/cop/style/one_line_conditional.rb +9 -4
- data/lib/rubocop/cop/style/option_hash.rb +11 -25
- data/lib/rubocop/cop/style/optional_arguments.rb +1 -2
- data/lib/rubocop/cop/style/or_assignment.rb +88 -0
- data/lib/rubocop/cop/style/parallel_assignment.rb +16 -16
- data/lib/rubocop/cop/style/parentheses_around_condition.rb +30 -13
- data/lib/rubocop/cop/style/percent_literal_delimiters.rb +25 -4
- data/lib/rubocop/cop/style/percent_q_literals.rb +29 -8
- data/lib/rubocop/cop/style/perl_backrefs.rb +8 -1
- data/lib/rubocop/cop/style/preferred_hash_methods.rb +7 -11
- data/lib/rubocop/cop/style/proc.rb +10 -2
- data/lib/rubocop/cop/style/raise_args.rb +22 -29
- data/lib/rubocop/cop/style/random_with_offset.rb +160 -0
- data/lib/rubocop/cop/style/redundant_begin.rb +16 -5
- data/lib/rubocop/cop/style/redundant_conditional.rb +96 -0
- data/lib/rubocop/cop/style/redundant_exception.rb +4 -4
- data/lib/rubocop/cop/style/redundant_freeze.rb +1 -1
- data/lib/rubocop/cop/style/redundant_parentheses.rb +14 -12
- data/lib/rubocop/cop/style/redundant_return.rb +28 -15
- data/lib/rubocop/cop/style/redundant_self.rb +35 -27
- data/lib/rubocop/cop/style/regexp_literal.rb +88 -27
- data/lib/rubocop/cop/style/rescue_modifier.rb +12 -1
- data/lib/rubocop/cop/style/rescue_standard_error.rb +122 -0
- data/lib/rubocop/cop/style/return_nil.rb +89 -0
- data/lib/rubocop/cop/style/safe_navigation.rb +100 -48
- data/lib/rubocop/cop/style/self_assignment.rb +13 -13
- data/lib/rubocop/cop/style/semicolon.rb +19 -9
- data/lib/rubocop/cop/style/send.rb +10 -1
- data/lib/rubocop/cop/style/signal_exception.rb +104 -3
- data/lib/rubocop/cop/style/single_line_block_params.rb +16 -15
- data/lib/rubocop/cop/style/single_line_methods.rb +26 -18
- data/lib/rubocop/cop/style/special_global_vars.rb +19 -14
- data/lib/rubocop/cop/style/stabby_lambda_parentheses.rb +23 -50
- data/lib/rubocop/cop/style/stderr_puts.rb +54 -0
- data/lib/rubocop/cop/style/string_hash_keys.rb +36 -0
- data/lib/rubocop/cop/style/string_literals.rb +26 -3
- data/lib/rubocop/cop/style/string_literals_in_interpolation.rb +16 -1
- data/lib/rubocop/cop/style/string_methods.rb +19 -8
- data/lib/rubocop/cop/style/struct_inheritance.rb +3 -3
- data/lib/rubocop/cop/style/symbol_array.rb +7 -35
- data/lib/rubocop/cop/style/symbol_literal.rb +1 -1
- data/lib/rubocop/cop/style/symbol_proc.rb +11 -25
- data/lib/rubocop/cop/style/ternary_parentheses.rb +46 -51
- data/lib/rubocop/cop/style/trailing_body_on_method_definition.rb +101 -0
- data/lib/rubocop/cop/style/trailing_comma_in_arguments.rb +20 -6
- data/lib/rubocop/cop/style/trailing_comma_in_literal.rb +22 -7
- data/lib/rubocop/cop/style/trailing_method_end_statement.rb +95 -0
- data/lib/rubocop/cop/style/trailing_underscore_variable.rb +70 -24
- data/lib/rubocop/cop/style/trivial_accessors.rb +72 -65
- data/lib/rubocop/cop/style/unless_else.rb +16 -1
- data/lib/rubocop/cop/style/unneeded_capital_w.rb +18 -8
- data/lib/rubocop/cop/style/unneeded_interpolation.rb +15 -19
- data/lib/rubocop/cop/style/unneeded_percent_q.rb +14 -13
- data/lib/rubocop/cop/style/variable_interpolation.rb +23 -9
- data/lib/rubocop/cop/style/when_then.rb +14 -1
- data/lib/rubocop/cop/style/while_until_do.rb +27 -4
- data/lib/rubocop/cop/style/while_until_modifier.rb +26 -6
- data/lib/rubocop/cop/style/word_array.rb +9 -30
- data/lib/rubocop/cop/style/yoda_condition.rb +51 -22
- data/lib/rubocop/cop/style/zero_length_predicate.rb +44 -29
- data/lib/rubocop/cop/team.rb +16 -8
- data/lib/rubocop/cop/util.rb +43 -34
- data/lib/rubocop/cop/variable_force.rb +1 -1
- data/lib/rubocop/cop/variable_force/assignment.rb +4 -2
- data/lib/rubocop/cop/variable_force/scope.rb +1 -5
- data/lib/rubocop/cop/variable_force/variable.rb +1 -1
- data/lib/rubocop/formatter/disabled_config_formatter.rb +3 -4
- data/lib/rubocop/formatter/formatter_set.rb +3 -1
- data/lib/rubocop/formatter/html_formatter.rb +1 -1
- data/lib/rubocop/formatter/json_formatter.rb +9 -3
- data/lib/rubocop/formatter/offense_count_formatter.rb +2 -0
- data/lib/rubocop/formatter/quiet_formatter.rb +13 -0
- data/lib/rubocop/formatter/simple_text_formatter.rb +3 -3
- data/lib/rubocop/formatter/tap_formatter.rb +71 -0
- data/lib/rubocop/formatter/worst_offenders_formatter.rb +2 -0
- data/lib/rubocop/node_pattern.rb +46 -29
- data/lib/rubocop/options.rb +13 -8
- data/lib/rubocop/path_util.rb +15 -3
- data/lib/rubocop/processed_source.rb +8 -9
- data/lib/rubocop/rake_task.rb +16 -23
- data/lib/rubocop/remote_config.rb +13 -1
- data/lib/rubocop/result_cache.rb +1 -0
- data/lib/rubocop/rspec/cop_helper.rb +10 -10
- data/lib/rubocop/rspec/expect_offense.rb +6 -8
- data/lib/rubocop/rspec/shared_contexts.rb +4 -8
- data/lib/rubocop/rspec/shared_examples.rb +8 -8
- data/lib/rubocop/rspec/support.rb +5 -5
- data/lib/rubocop/runner.rb +1 -1
- data/lib/rubocop/string_util.rb +2 -0
- data/lib/rubocop/token.rb +74 -0
- data/lib/rubocop/version.rb +1 -1
- metadata +118 -48
- data/lib/rubocop/cop/layout/space_inside_brackets.rb +0 -20
- data/lib/rubocop/cop/lint/invalid_character_literal.rb +0 -41
- data/lib/rubocop/cop/mixin/access_modifier_node.rb +0 -41
- data/lib/rubocop/cop/mixin/on_method_def.rb +0 -44
- data/lib/rubocop/cop/mixin/space_inside.rb +0 -76
- data/lib/rubocop/cop/style/accessor_method_name.rb +0 -45
- data/lib/rubocop/cop/style/class_and_module_camel_case.rb +0 -29
- data/lib/rubocop/cop/style/constant_name.rb +0 -29
- data/lib/rubocop/cop/style/method_name.rb +0 -34
- data/lib/rubocop/cop/style/predicate_name.rb +0 -67
- data/lib/rubocop/cop/style/variable_name.rb +0 -39
data/lib/rubocop/ast/builder.rb
CHANGED
@@ -19,6 +19,7 @@ module RuboCop
|
|
19
19
|
ArrayNode => [:array],
|
20
20
|
BlockNode => [:block],
|
21
21
|
CaseNode => [:case],
|
22
|
+
DefNode => %i[def defs],
|
22
23
|
EnsureNode => [:ensure],
|
23
24
|
ForNode => [:for],
|
24
25
|
HashNode => [:hash],
|
@@ -26,12 +27,16 @@ module RuboCop
|
|
26
27
|
KeywordSplatNode => [:kwsplat],
|
27
28
|
OrNode => [:or],
|
28
29
|
PairNode => [:pair],
|
30
|
+
RegexpNode => [:regexp],
|
29
31
|
ResbodyNode => [:resbody],
|
30
32
|
SendNode => %i[csend send],
|
33
|
+
StrNode => %i[str dstr xstr],
|
31
34
|
SuperNode => %i[super zsuper],
|
35
|
+
SymbolNode => [:sym],
|
32
36
|
UntilNode => %i[until until_post],
|
33
37
|
WhenNode => [:when],
|
34
|
-
WhileNode => %i[while while_post]
|
38
|
+
WhileNode => %i[while while_post],
|
39
|
+
YieldNode => [:yield]
|
35
40
|
}.freeze
|
36
41
|
|
37
42
|
# Generates {Node} from the given information.
|
data/lib/rubocop/ast/node.rb
CHANGED
@@ -20,8 +20,11 @@ module RuboCop
|
|
20
20
|
#
|
21
21
|
class Node < Parser::AST::Node # rubocop:disable Metrics/ClassLength
|
22
22
|
include RuboCop::AST::Sexp
|
23
|
+
extend NodePattern::Macros
|
23
24
|
|
24
|
-
|
25
|
+
# <=> isn't included here, because it doesn't return a boolean.
|
26
|
+
COMPARISON_OPERATORS = %i[== === != <= >= > <].freeze
|
27
|
+
ARITHMETIC_OPERATORS = %i[+ - * / % **].freeze
|
25
28
|
|
26
29
|
TRUTHY_LITERALS = %i[str dstr xstr int float sym dsym array
|
27
30
|
hash regexp true irange erange complex
|
@@ -44,19 +47,6 @@ module RuboCop
|
|
44
47
|
OPERATOR_KEYWORDS = %i[and or].freeze
|
45
48
|
SPECIAL_KEYWORDS = %w[__FILE__ __LINE__ __ENCODING__].freeze
|
46
49
|
|
47
|
-
# def_matcher can be used to define a pattern-matching method on Node
|
48
|
-
class << self
|
49
|
-
def def_matcher(method_name, pattern_str)
|
50
|
-
compiler = RuboCop::NodePattern::Compiler.new(pattern_str, 'self')
|
51
|
-
src = "def #{method_name}(" \
|
52
|
-
"#{compiler.emit_param_list});" \
|
53
|
-
"#{compiler.emit_method_code};end"
|
54
|
-
|
55
|
-
location = caller_locations(1, 1).first
|
56
|
-
class_eval(src, location.path, location.lineno)
|
57
|
-
end
|
58
|
-
end
|
59
|
-
|
60
50
|
# @see http://rubydoc.info/gems/ast/AST/Node:initialize
|
61
51
|
def initialize(type, children = [], properties = {})
|
62
52
|
@mutable_attributes = {}
|
@@ -271,12 +261,17 @@ module RuboCop
|
|
271
261
|
|
272
262
|
## Destructuring
|
273
263
|
|
274
|
-
|
275
|
-
|
276
|
-
|
264
|
+
def_node_matcher :receiver, <<-PATTERN
|
265
|
+
{(send $_ ...) (block (send $_ ...) ...)}
|
266
|
+
PATTERN
|
267
|
+
|
268
|
+
def_node_matcher :method_name, <<-PATTERN
|
269
|
+
{(send _ $_ ...) (block (send _ $_ ...) ...)}
|
270
|
+
PATTERN
|
271
|
+
|
277
272
|
# Note: for masgn, #asgn_rhs will be an array node
|
278
|
-
|
279
|
-
|
273
|
+
def_node_matcher :asgn_rhs, '[assignment? (... $_)]'
|
274
|
+
def_node_matcher :str_content, '(str $_)'
|
280
275
|
|
281
276
|
def const_name
|
282
277
|
return unless const_type?
|
@@ -288,11 +283,11 @@ module RuboCop
|
|
288
283
|
end
|
289
284
|
end
|
290
285
|
|
291
|
-
|
286
|
+
def_node_matcher :defined_module0, <<-PATTERN
|
292
287
|
{(class (const $_ $_) ...)
|
293
288
|
(module (const $_ $_) ...)
|
294
|
-
(casgn $_ $_ (send (const nil {:Class :Module}) :new ...))
|
295
|
-
(casgn $_ $_ (block (send (const nil {:Class :Module}) :new ...) ...))}
|
289
|
+
(casgn $_ $_ (send (const nil? {:Class :Module}) :new ...))
|
290
|
+
(casgn $_ $_ (block (send (const nil? {:Class :Module}) :new ...) ...))}
|
296
291
|
PATTERN
|
297
292
|
private :defined_module0
|
298
293
|
|
@@ -320,11 +315,28 @@ module RuboCop
|
|
320
315
|
## Predicates
|
321
316
|
|
322
317
|
def multiline?
|
323
|
-
|
318
|
+
line_count > 1
|
324
319
|
end
|
325
320
|
|
326
321
|
def single_line?
|
327
|
-
|
322
|
+
line_count == 1
|
323
|
+
end
|
324
|
+
|
325
|
+
def line_count
|
326
|
+
return 0 unless source_range
|
327
|
+
source_range.last_line - source_range.first_line + 1
|
328
|
+
end
|
329
|
+
|
330
|
+
def nonempty_line_count
|
331
|
+
source.lines.grep(/\S/).size
|
332
|
+
end
|
333
|
+
|
334
|
+
def empty?
|
335
|
+
length.zero?
|
336
|
+
end
|
337
|
+
|
338
|
+
def length
|
339
|
+
source_range ? source_range.size : 0
|
328
340
|
end
|
329
341
|
|
330
342
|
def asgn_method_call?
|
@@ -332,10 +344,19 @@ module RuboCop
|
|
332
344
|
method_name.to_s.end_with?('='.freeze)
|
333
345
|
end
|
334
346
|
|
335
|
-
|
336
|
-
|
337
|
-
|
338
|
-
|
347
|
+
def arithmetic_operation?
|
348
|
+
ARITHMETIC_OPERATORS.include?(method_name)
|
349
|
+
end
|
350
|
+
|
351
|
+
def_node_matcher :equals_asgn?, <<-PATTERN
|
352
|
+
{lvasgn ivasgn cvasgn gvasgn casgn masgn}
|
353
|
+
PATTERN
|
354
|
+
|
355
|
+
def_node_matcher :shorthand_asgn?, '{op_asgn or_asgn and_asgn}'
|
356
|
+
|
357
|
+
def_node_matcher :assignment?, <<-PATTERN
|
358
|
+
{equals_asgn? shorthand_asgn? asgn_method_call?}
|
359
|
+
PATTERN
|
339
360
|
|
340
361
|
def literal?
|
341
362
|
LITERALS.include?(type)
|
@@ -368,7 +389,7 @@ module RuboCop
|
|
368
389
|
case type
|
369
390
|
when :send
|
370
391
|
receiver, method_name, *args = *self
|
371
|
-
COMPARISON_OPERATORS.include?(method_name) &&
|
392
|
+
[*COMPARISON_OPERATORS, :!, :<=>].include?(method_name) &&
|
372
393
|
receiver.send(recursive_kind) &&
|
373
394
|
args.all?(&recursive_kind)
|
374
395
|
when :begin, :pair, *OPERATOR_KEYWORDS, *COMPOSITE_LITERALS
|
@@ -439,24 +460,25 @@ module RuboCop
|
|
439
460
|
int_type? || float_type?
|
440
461
|
end
|
441
462
|
|
442
|
-
|
443
|
-
[{(send nil {:raise :fail} ...) return break next} single_line?]
|
463
|
+
def_node_matcher :guard_clause?, <<-PATTERN
|
464
|
+
[{(send nil? {:raise :fail} ...) return break next} single_line?]
|
444
465
|
PATTERN
|
445
466
|
|
446
|
-
|
447
|
-
|
448
|
-
|
449
|
-
(
|
450
|
-
(send (const nil :Proc) :new)}
|
467
|
+
def_node_matcher :proc?, <<-PATTERN
|
468
|
+
{(block (send nil? :proc) ...)
|
469
|
+
(block (send (const nil? :Proc) :new) ...)
|
470
|
+
(send (const nil? :Proc) :new)}
|
451
471
|
PATTERN
|
452
|
-
def_matcher :lambda_or_proc?, '{lambda? proc?}'
|
453
472
|
|
454
|
-
|
455
|
-
|
456
|
-
|
473
|
+
def_node_matcher :lambda?, '(block (send nil? :lambda) ...)'
|
474
|
+
def_node_matcher :lambda_or_proc?, '{lambda? proc?}'
|
475
|
+
|
476
|
+
def_node_matcher :class_constructor?, <<-PATTERN
|
477
|
+
{ (send (const nil? {:Class :Module}) :new ...)
|
478
|
+
(block (send (const nil? {:Class :Module}) :new ...) ...)}
|
457
479
|
PATTERN
|
458
480
|
|
459
|
-
|
481
|
+
def_node_matcher :module_definition?, <<-PATTERN
|
460
482
|
{class module (casgn _ _ class_constructor?)}
|
461
483
|
PATTERN
|
462
484
|
|
@@ -468,7 +490,7 @@ module RuboCop
|
|
468
490
|
# So, does the return value of this node matter? If we changed it to
|
469
491
|
# `(...; nil)`, might that affect anything?
|
470
492
|
#
|
471
|
-
# rubocop:disable Metrics/MethodLength
|
493
|
+
# rubocop:disable Metrics/MethodLength, Metrics/CyclomaticComplexity
|
472
494
|
def value_used?
|
473
495
|
# Be conservative and return true if we're not sure.
|
474
496
|
return false if parent.nil?
|
@@ -490,7 +512,7 @@ module RuboCop
|
|
490
512
|
true
|
491
513
|
end
|
492
514
|
end
|
493
|
-
# rubocop:enable Metrics/MethodLength
|
515
|
+
# rubocop:enable Metrics/MethodLength, Metrics/CyclomaticComplexity
|
494
516
|
|
495
517
|
# Some expressions are evaluated for their value, some for their side
|
496
518
|
# effects, and some for both.
|
@@ -596,15 +618,9 @@ module RuboCop
|
|
596
618
|
end
|
597
619
|
end
|
598
620
|
|
599
|
-
|
600
|
-
|
601
|
-
|
602
|
-
block_node.method_name == :new &&
|
603
|
-
receiver && receiver.const_type? &&
|
604
|
-
(receiver.const_name == 'Class' || receiver.const_name == 'Module') &&
|
605
|
-
block_node.parent &&
|
606
|
-
block_node.parent.casgn_type?
|
607
|
-
end
|
621
|
+
def_node_matcher :new_class_or_module_block?, <<-PATTERN
|
622
|
+
^(casgn _ _ (block (send (const _ {:Class :Module}) :new) ...))
|
623
|
+
PATTERN
|
608
624
|
end
|
609
625
|
end
|
610
626
|
end
|
@@ -6,18 +6,23 @@ module RuboCop
|
|
6
6
|
# node when the builder constructs the AST, making its methods available
|
7
7
|
# to all `args` nodes within RuboCop.
|
8
8
|
class ArgsNode < Node
|
9
|
-
|
10
|
-
#
|
11
|
-
# @return [Boolean] whether this `args` node has any arguments
|
12
|
-
def empty?
|
13
|
-
to_a.empty?
|
14
|
-
end
|
9
|
+
include CollectionNode
|
15
10
|
|
16
|
-
#
|
11
|
+
# It returns true if arguments are empty, and delimiters do not exist.
|
12
|
+
# @example:
|
13
|
+
# # true
|
14
|
+
# def x; end
|
15
|
+
# x { }
|
16
|
+
# -> {}
|
17
17
|
#
|
18
|
-
#
|
19
|
-
def
|
20
|
-
|
18
|
+
# # false
|
19
|
+
# def x(); end
|
20
|
+
# def x a; end
|
21
|
+
# x { || }
|
22
|
+
# -> () {}
|
23
|
+
# -> a {}
|
24
|
+
def empty_and_without_delimiters?
|
25
|
+
loc.expression.nil?
|
21
26
|
end
|
22
27
|
end
|
23
28
|
end
|
@@ -31,7 +31,7 @@ module RuboCop
|
|
31
31
|
# Check for any percent literal.
|
32
32
|
#
|
33
33
|
# @overload percent_literal?(type)
|
34
|
-
# Check for percent
|
34
|
+
# Check for percent literal of type `type`.
|
35
35
|
#
|
36
36
|
# @param type [Symbol] an optional percent literal type
|
37
37
|
#
|
@@ -43,6 +43,15 @@ module RuboCop
|
|
43
43
|
loc.begin && loc.begin.source.start_with?('%')
|
44
44
|
end
|
45
45
|
end
|
46
|
+
|
47
|
+
# Checks whether the `array` literal is delimited by either percent or
|
48
|
+
# square brackets
|
49
|
+
#
|
50
|
+
# @return [Boolean] whether the array is enclosed in percent or square
|
51
|
+
# brackets
|
52
|
+
def bracketed?
|
53
|
+
square_brackets? || percent_literal?
|
54
|
+
end
|
46
55
|
end
|
47
56
|
end
|
48
57
|
end
|
@@ -9,6 +9,8 @@ module RuboCop
|
|
9
9
|
# A `block` node is essentially a method send with a block. Parser nests
|
10
10
|
# the `send` node inside the `block` node.
|
11
11
|
class BlockNode < Node
|
12
|
+
VOID_CONTEXT_METHODS = %i[each].freeze
|
13
|
+
|
12
14
|
# The `send` node associated with this block.
|
13
15
|
#
|
14
16
|
# @return [SendNode] the `send` node associated with the `block` node
|
@@ -95,6 +97,13 @@ module RuboCop
|
|
95
97
|
send_node.method?(:lambda)
|
96
98
|
end
|
97
99
|
|
100
|
+
# Checks whether this node body is a void context.
|
101
|
+
#
|
102
|
+
# @return [Boolean] whether the `block` node body is a void context
|
103
|
+
def void_context?
|
104
|
+
VOID_CONTEXT_METHODS.include?(send_node.method_name)
|
105
|
+
end
|
106
|
+
|
98
107
|
# Custom destructuring method. This can be used to normalize
|
99
108
|
# destructuring for different variations of the node.
|
100
109
|
#
|
@@ -0,0 +1,71 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module RuboCop
|
4
|
+
module AST
|
5
|
+
# A node extension for `def` nodes. This will be used in place of a plain
|
6
|
+
# node when the builder constructs the AST, making its methods available
|
7
|
+
# to all `def` nodes within RuboCop.
|
8
|
+
class DefNode < Node
|
9
|
+
include ParameterizedNode
|
10
|
+
include MethodIdentifierPredicates
|
11
|
+
|
12
|
+
# Checks whether this node body is a void context.
|
13
|
+
#
|
14
|
+
# @return [Boolean] whether the `def` node body is a void context
|
15
|
+
def void_context?
|
16
|
+
method?(:initialize) || assignment_method?
|
17
|
+
end
|
18
|
+
|
19
|
+
# The name of the defined method as a symbol.
|
20
|
+
#
|
21
|
+
# @return [Symbol] the name of the defined method
|
22
|
+
def method_name
|
23
|
+
node_parts[2]
|
24
|
+
end
|
25
|
+
|
26
|
+
# An array containing the arguments of the method definition.
|
27
|
+
#
|
28
|
+
# @return [Array<Node>] the arguments of the method definition
|
29
|
+
def arguments
|
30
|
+
node_parts[1]
|
31
|
+
end
|
32
|
+
|
33
|
+
# The body of the method definition.
|
34
|
+
#
|
35
|
+
# @note this can be either a `begin` node, if the method body contains
|
36
|
+
# multiple expressions, or any other node, if it contains a single
|
37
|
+
# expression.
|
38
|
+
#
|
39
|
+
# @return [Node] the body of the method definition
|
40
|
+
def body
|
41
|
+
node_parts[0]
|
42
|
+
end
|
43
|
+
|
44
|
+
# The receiver of the method definition, if any.
|
45
|
+
#
|
46
|
+
# @return [Node, nil] the receiver of the method definition, or `nil`.
|
47
|
+
def receiver
|
48
|
+
node_parts[3]
|
49
|
+
end
|
50
|
+
|
51
|
+
# Custom destructuring method. This can be used to normalize
|
52
|
+
# destructuring for different variations of the node.
|
53
|
+
#
|
54
|
+
# In this case, the `def` node destructures into:
|
55
|
+
#
|
56
|
+
# `method_name, arguments, body`
|
57
|
+
#
|
58
|
+
# while the `defs` node destructures into:
|
59
|
+
#
|
60
|
+
# `receiver, method_name, arguments, body`
|
61
|
+
#
|
62
|
+
# so we reverse the destructured array to get the optional receiver
|
63
|
+
# at the end, where it can be discarded.
|
64
|
+
#
|
65
|
+
# @return [Array] the different parts of the `def` or `defs` node
|
66
|
+
def node_parts
|
67
|
+
to_a.reverse
|
68
|
+
end
|
69
|
+
end
|
70
|
+
end
|
71
|
+
end
|
@@ -20,6 +20,14 @@ module RuboCop
|
|
20
20
|
loc.begin && loc.begin.is?('do')
|
21
21
|
end
|
22
22
|
|
23
|
+
# Checks whether this node body is a void context.
|
24
|
+
# Always `true` for `for`.
|
25
|
+
#
|
26
|
+
# @return [true] whether the `for` node body is a void context
|
27
|
+
def void_context?
|
28
|
+
true
|
29
|
+
end
|
30
|
+
|
23
31
|
# Returns the iteration variable of the `for` loop.
|
24
32
|
#
|
25
33
|
# @return [Node] The iteration variable of the `for` loop
|
@@ -82,10 +82,10 @@ module RuboCop
|
|
82
82
|
(if? || unless?) && super
|
83
83
|
end
|
84
84
|
|
85
|
-
#
|
85
|
+
# Chacks whether the `if` node has nested `if` nodes in any of its
|
86
86
|
# branches.
|
87
87
|
#
|
88
|
-
# @note This
|
88
|
+
# @note This performs a shallow search.
|
89
89
|
#
|
90
90
|
# @return [Boolean] whether the `if` node contains nested conditionals
|
91
91
|
def nested_conditional?
|
@@ -98,6 +98,14 @@ module RuboCop
|
|
98
98
|
false
|
99
99
|
end
|
100
100
|
|
101
|
+
# Checks whether the `if` node has at least one `elsif` branch. Returns
|
102
|
+
# true if this `if` node itself is an `elsif`.
|
103
|
+
#
|
104
|
+
# @return [Boolean] whether the `if` node has at least one `elsif` branch
|
105
|
+
def elsif_conditional?
|
106
|
+
else_branch && else_branch.if_type? && else_branch.elsif?
|
107
|
+
end
|
108
|
+
|
101
109
|
# Returns the branch of the `if` node that gets evaluated when its
|
102
110
|
# condition is truthy.
|
103
111
|
#
|
@@ -0,0 +1,16 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module RuboCop
|
4
|
+
module AST
|
5
|
+
# Common functionality for primitive literal nodes: `sym`, `str`,
|
6
|
+
# `int`, `float`, ...
|
7
|
+
module BasicLiteralNode
|
8
|
+
# Returns the value of the literal.
|
9
|
+
#
|
10
|
+
# @return [mixed] the value of the literal
|
11
|
+
def value
|
12
|
+
node_parts[0]
|
13
|
+
end
|
14
|
+
end
|
15
|
+
end
|
16
|
+
end
|
@@ -0,0 +1,15 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module RuboCop
|
4
|
+
module AST
|
5
|
+
# A mixin that helps give collection nodes array polymorphism.
|
6
|
+
module CollectionNode
|
7
|
+
extend Forwardable
|
8
|
+
|
9
|
+
ARRAY_METHODS =
|
10
|
+
(Array.instance_methods - Object.instance_methods - [:to_a]).freeze
|
11
|
+
|
12
|
+
def_delegators :to_a, *ARRAY_METHODS
|
13
|
+
end
|
14
|
+
end
|
15
|
+
end
|