rubocop 0.42.0 → 0.52.1
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/LICENSE.txt +1 -1
- data/README.md +106 -20
- data/assets/output.html.erb +21 -10
- data/bin/rubocop +1 -2
- data/config/default.yml +914 -483
- data/config/disabled.yml +61 -41
- data/config/enabled.yml +1396 -878
- data/lib/rubocop/ast/builder.rb +72 -0
- data/lib/rubocop/ast/node/and_node.rb +37 -0
- data/lib/rubocop/ast/node/args_node.rb +29 -0
- data/lib/rubocop/ast/node/array_node.rb +57 -0
- data/lib/rubocop/ast/node/block_node.rb +116 -0
- data/lib/rubocop/ast/node/case_node.rb +64 -0
- data/lib/rubocop/ast/node/def_node.rb +71 -0
- data/lib/rubocop/ast/node/ensure_node.rb +25 -0
- data/lib/rubocop/ast/node/for_node.rb +61 -0
- data/lib/rubocop/ast/node/hash_node.rb +109 -0
- data/lib/rubocop/ast/node/if_node.rb +146 -0
- data/lib/rubocop/ast/node/keyword_splat_node.rb +45 -0
- data/lib/rubocop/ast/node/mixin/basic_literal_node.rb +16 -0
- data/lib/rubocop/ast/node/mixin/binary_operator_node.rb +23 -0
- data/lib/rubocop/ast/node/mixin/collection_node.rb +15 -0
- data/lib/rubocop/ast/node/mixin/conditional_node.rb +45 -0
- data/lib/rubocop/ast/node/mixin/hash_element_node.rb +125 -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/modifier_node.rb +17 -0
- data/lib/rubocop/ast/node/mixin/parameterized_node.rb +61 -0
- data/lib/rubocop/ast/node/mixin/predicate_operator_node.rb +35 -0
- data/lib/rubocop/ast/node/or_node.rb +37 -0
- data/lib/rubocop/ast/node/pair_node.rb +64 -0
- data/lib/rubocop/ast/node/regexp_node.rb +35 -0
- data/lib/rubocop/ast/node/resbody_node.rb +25 -0
- data/lib/rubocop/ast/node/send_node.rb +45 -0
- data/lib/rubocop/ast/node/str_node.rb +14 -0
- data/lib/rubocop/ast/node/super_node.rb +21 -0
- data/lib/rubocop/ast/node/symbol_node.rb +20 -0
- data/lib/rubocop/ast/node/until_node.rb +43 -0
- data/lib/rubocop/ast/node/when_node.rb +61 -0
- data/lib/rubocop/ast/node/while_node.rb +43 -0
- data/lib/rubocop/ast/node/yield_node.rb +21 -0
- data/lib/rubocop/ast/node.rb +634 -0
- data/lib/rubocop/ast/sexp.rb +16 -0
- data/lib/rubocop/{ast_node → ast}/traversal.rb +23 -24
- data/lib/rubocop/cached_data.rb +11 -31
- data/lib/rubocop/cli.rb +116 -33
- data/lib/rubocop/comment_config.rb +4 -10
- data/lib/rubocop/config.rb +355 -102
- data/lib/rubocop/config_loader.rb +93 -78
- data/lib/rubocop/config_loader_resolver.rb +106 -7
- data/lib/rubocop/config_store.rb +4 -1
- data/lib/rubocop/cop/autocorrect_logic.rb +1 -2
- data/lib/rubocop/cop/badge.rb +73 -0
- data/lib/rubocop/cop/bundler/duplicated_gem.rb +71 -0
- data/lib/rubocop/cop/bundler/insecure_protocol_source.rb +67 -0
- data/lib/rubocop/cop/bundler/ordered_gems.rb +71 -0
- data/lib/rubocop/cop/commissioner.rb +27 -10
- data/lib/rubocop/cop/cop.rb +62 -107
- data/lib/rubocop/cop/corrector.rb +0 -1
- data/lib/rubocop/cop/correctors/alignment_corrector.rb +121 -0
- data/lib/rubocop/cop/correctors/condition_corrector.rb +28 -0
- data/lib/rubocop/cop/correctors/empty_line_corrector.rb +26 -0
- data/lib/rubocop/cop/correctors/multiline_literal_brace_corrector.rb +62 -0
- data/lib/rubocop/cop/correctors/ordered_gem_corrector.rb +44 -0
- data/lib/rubocop/cop/correctors/parentheses_corrector.rb +31 -0
- data/lib/rubocop/cop/correctors/punctuation_corrector.rb +29 -0
- data/lib/rubocop/cop/correctors/space_corrector.rb +34 -0
- data/lib/rubocop/cop/correctors/string_literal_corrector.rb +25 -0
- data/lib/rubocop/cop/correctors/unused_arg_corrector.rb +31 -0
- data/lib/rubocop/cop/force.rb +0 -1
- data/lib/rubocop/cop/gemspec/duplicated_assignment.rb +102 -0
- data/lib/rubocop/cop/gemspec/ordered_dependencies.rb +106 -0
- data/lib/rubocop/cop/gemspec/required_ruby_version.rb +87 -0
- data/lib/rubocop/cop/generator/require_file_injector.rb +78 -0
- data/lib/rubocop/cop/generator.rb +191 -0
- data/lib/rubocop/cop/ignored_node.rb +0 -1
- data/lib/rubocop/cop/internal_affairs/node_destructuring.rb +46 -0
- data/lib/rubocop/cop/internal_affairs/node_type_predicate.rb +44 -0
- 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 +52 -0
- data/lib/rubocop/cop/internal_affairs.rb +8 -0
- data/lib/rubocop/cop/{style → layout}/access_modifier_indentation.rb +39 -10
- data/lib/rubocop/cop/layout/align_array.rb +39 -0
- data/lib/rubocop/cop/layout/align_hash.rb +235 -0
- data/lib/rubocop/cop/{style → layout}/align_parameters.rb +38 -19
- data/lib/rubocop/cop/{style → layout}/block_end_newline.rb +26 -8
- data/lib/rubocop/cop/layout/case_indentation.rb +160 -0
- data/lib/rubocop/cop/layout/class_structure.rb +306 -0
- data/lib/rubocop/cop/{style → layout}/closing_parenthesis_indentation.rb +18 -13
- data/lib/rubocop/cop/{style → layout}/comment_indentation.rb +48 -6
- data/lib/rubocop/cop/{style → layout}/dot_position.rb +34 -21
- data/lib/rubocop/cop/{style → layout}/else_alignment.rb +55 -37
- data/lib/rubocop/cop/layout/empty_line_after_magic_comment.rb +63 -0
- data/lib/rubocop/cop/layout/empty_line_between_defs.rb +147 -0
- data/lib/rubocop/cop/{style → layout}/empty_lines.rb +17 -4
- data/lib/rubocop/cop/{style → layout}/empty_lines_around_access_modifier.rb +40 -24
- data/lib/rubocop/cop/layout/empty_lines_around_arguments.rb +87 -0
- data/lib/rubocop/cop/layout/empty_lines_around_begin_body.rb +46 -0
- data/lib/rubocop/cop/{style → layout}/empty_lines_around_block_body.rb +9 -12
- data/lib/rubocop/cop/layout/empty_lines_around_class_body.rb +68 -0
- data/lib/rubocop/cop/layout/empty_lines_around_exception_handling_keywords.rb +135 -0
- data/lib/rubocop/cop/{style → layout}/empty_lines_around_method_body.rb +10 -7
- data/lib/rubocop/cop/{style → layout}/empty_lines_around_module_body.rb +27 -9
- data/lib/rubocop/cop/layout/end_of_line.rb +52 -0
- data/lib/rubocop/cop/{style → layout}/extra_spacing.rb +63 -53
- data/lib/rubocop/cop/{style → layout}/first_array_element_line_break.rb +5 -2
- data/lib/rubocop/cop/{style → layout}/first_hash_element_line_break.rb +5 -2
- data/lib/rubocop/cop/{style → layout}/first_method_argument_line_break.rb +7 -4
- data/lib/rubocop/cop/{style → layout}/first_method_parameter_line_break.rb +8 -5
- data/lib/rubocop/cop/{style → layout}/first_parameter_indentation.rb +32 -26
- data/lib/rubocop/cop/{style → layout}/indent_array.rb +75 -25
- data/lib/rubocop/cop/{style → layout}/indent_assignment.rb +9 -6
- data/lib/rubocop/cop/{style → layout}/indent_hash.rb +80 -31
- data/lib/rubocop/cop/layout/indent_heredoc.rb +208 -0
- data/lib/rubocop/cop/{style → layout}/indentation_consistency.rb +7 -5
- data/lib/rubocop/cop/{style → layout}/indentation_width.rb +151 -117
- data/lib/rubocop/cop/layout/initial_indentation.rb +45 -0
- data/lib/rubocop/cop/layout/leading_comment_space.rb +58 -0
- data/lib/rubocop/cop/{style → layout}/multiline_array_brace_layout.rb +52 -16
- data/lib/rubocop/cop/{style → layout}/multiline_assignment_layout.rb +18 -21
- data/lib/rubocop/cop/{style → layout}/multiline_block_layout.rb +37 -43
- data/lib/rubocop/cop/{style → layout}/multiline_hash_brace_layout.rb +55 -15
- data/lib/rubocop/cop/{style → layout}/multiline_method_call_brace_layout.rb +15 -4
- data/lib/rubocop/cop/layout/multiline_method_call_indentation.rb +221 -0
- data/lib/rubocop/cop/{style → layout}/multiline_method_definition_brace_layout.rb +12 -5
- data/lib/rubocop/cop/{style → layout}/multiline_operation_indentation.rb +23 -13
- data/lib/rubocop/cop/{style → layout}/rescue_ensure_alignment.rb +24 -13
- data/lib/rubocop/cop/{style → layout}/space_after_colon.rb +17 -13
- data/lib/rubocop/cop/layout/space_after_comma.rb +35 -0
- data/lib/rubocop/cop/{style → layout}/space_after_method_name.rb +11 -11
- data/lib/rubocop/cop/layout/space_after_not.rb +38 -0
- data/lib/rubocop/cop/{style → layout}/space_after_semicolon.rb +14 -4
- data/lib/rubocop/cop/{style → layout}/space_around_block_parameters.rb +52 -28
- data/lib/rubocop/cop/{style → layout}/space_around_equals_in_parameter_default.rb +29 -21
- data/lib/rubocop/cop/{style → layout}/space_around_keyword.rb +33 -29
- data/lib/rubocop/cop/layout/space_around_operators.rb +159 -0
- data/lib/rubocop/cop/layout/space_before_block_braces.rb +107 -0
- data/lib/rubocop/cop/layout/space_before_comma.rb +31 -0
- data/lib/rubocop/cop/{style → layout}/space_before_comment.rb +11 -7
- data/lib/rubocop/cop/{style → layout}/space_before_first_arg.rb +23 -20
- data/lib/rubocop/cop/layout/space_before_semicolon.rb +27 -0
- data/lib/rubocop/cop/layout/space_in_lambda_literal.rb +85 -0
- data/lib/rubocop/cop/layout/space_inside_array_literal_brackets.rb +236 -0
- data/lib/rubocop/cop/{style → layout}/space_inside_array_percent_literal.rb +8 -8
- data/lib/rubocop/cop/layout/space_inside_block_braces.rb +228 -0
- data/lib/rubocop/cop/{style → layout}/space_inside_hash_literal_braces.rb +91 -51
- data/lib/rubocop/cop/layout/space_inside_parens.rb +53 -0
- data/lib/rubocop/cop/{style → layout}/space_inside_percent_literal_delimiters.rb +14 -13
- data/lib/rubocop/cop/{style → layout}/space_inside_range_literal.rb +16 -17
- data/lib/rubocop/cop/layout/space_inside_reference_brackets.rb +90 -0
- data/lib/rubocop/cop/layout/space_inside_string_interpolation.rb +80 -0
- data/lib/rubocop/cop/{style → layout}/tab.rb +8 -6
- data/lib/rubocop/cop/{style → layout}/trailing_blank_lines.rb +14 -15
- data/lib/rubocop/cop/{style → layout}/trailing_whitespace.rb +3 -4
- data/lib/rubocop/cop/lint/ambiguous_block_association.rb +59 -0
- data/lib/rubocop/cop/lint/ambiguous_operator.rb +13 -9
- data/lib/rubocop/cop/lint/ambiguous_regexp_literal.rb +7 -1
- data/lib/rubocop/cop/lint/assignment_in_condition.rb +55 -25
- data/lib/rubocop/cop/lint/block_alignment.rb +75 -34
- data/lib/rubocop/cop/lint/boolean_symbol.rb +38 -0
- data/lib/rubocop/cop/lint/circular_argument_reference.rb +17 -15
- data/lib/rubocop/cop/lint/condition_position.rb +16 -15
- data/lib/rubocop/cop/lint/debugger.rb +57 -23
- data/lib/rubocop/cop/lint/def_end_alignment.rb +28 -14
- data/lib/rubocop/cop/lint/deprecated_class_methods.rb +19 -10
- data/lib/rubocop/cop/lint/duplicate_case_condition.rb +53 -0
- data/lib/rubocop/cop/lint/duplicate_methods.rb +108 -14
- data/lib/rubocop/cop/lint/duplicated_key.rb +16 -9
- data/lib/rubocop/cop/lint/each_with_object_argument.rb +15 -6
- data/lib/rubocop/cop/lint/else_layout.rb +27 -31
- data/lib/rubocop/cop/lint/empty_ensure.rb +44 -3
- data/lib/rubocop/cop/lint/empty_expression.rb +42 -0
- data/lib/rubocop/cop/lint/empty_interpolation.rb +16 -3
- data/lib/rubocop/cop/lint/empty_when.rb +38 -0
- data/lib/rubocop/cop/lint/end_alignment.rb +57 -39
- data/lib/rubocop/cop/lint/end_in_method.rb +24 -2
- data/lib/rubocop/cop/lint/ensure_return.rb +23 -3
- data/lib/rubocop/cop/lint/float_out_of_range.rb +10 -6
- data/lib/rubocop/cop/lint/format_parameter_mismatch.rb +67 -46
- data/lib/rubocop/cop/lint/handle_exceptions.rb +41 -4
- data/lib/rubocop/cop/lint/implicit_string_concatenation.rb +9 -5
- data/lib/rubocop/cop/lint/ineffective_access_modifier.rb +42 -29
- data/lib/rubocop/cop/lint/inherit_exception.rb +34 -23
- data/lib/rubocop/cop/lint/interpolation_check.rb +37 -0
- data/lib/rubocop/cop/lint/{literal_in_condition.rb → literal_as_condition.rb} +51 -40
- data/lib/rubocop/cop/lint/literal_in_interpolation.rb +13 -8
- data/lib/rubocop/cop/lint/loop.rb +37 -2
- data/lib/rubocop/cop/lint/missing_cop_enable_directive.rb +81 -0
- data/lib/rubocop/cop/lint/multiple_compare.rb +48 -0
- data/lib/rubocop/cop/lint/nested_method_definition.rb +54 -12
- data/lib/rubocop/cop/lint/nested_percent_literal.rb +58 -0
- data/lib/rubocop/cop/lint/next_without_accumulator.rb +7 -3
- data/lib/rubocop/cop/lint/non_local_exit_from_iterator.rb +32 -23
- data/lib/rubocop/cop/lint/parentheses_as_grouped_expression.rb +22 -14
- data/lib/rubocop/cop/lint/percent_string_array.rb +42 -27
- data/lib/rubocop/cop/lint/percent_symbol_array.rb +28 -19
- data/lib/rubocop/cop/lint/rand_one.rb +17 -8
- 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 +24 -30
- data/lib/rubocop/cop/lint/rescue_exception.rb +21 -2
- data/lib/rubocop/cop/lint/rescue_type.rb +90 -0
- data/lib/rubocop/cop/lint/return_in_void_context.rb +74 -0
- data/lib/rubocop/cop/lint/safe_navigation_chain.rb +70 -0
- data/lib/rubocop/cop/lint/script_permission.rb +49 -0
- data/lib/rubocop/cop/lint/shadowed_argument.rb +146 -0
- data/lib/rubocop/cop/lint/shadowed_exception.rb +78 -57
- data/lib/rubocop/cop/lint/shadowing_outer_local_variable.rb +25 -2
- data/lib/rubocop/cop/lint/string_conversion_in_interpolation.rb +18 -12
- data/lib/rubocop/cop/lint/syntax.rb +23 -21
- data/lib/rubocop/cop/lint/underscore_prefixed_variable_name.rb +26 -4
- data/lib/rubocop/cop/lint/unified_integer.rb +43 -0
- data/lib/rubocop/cop/lint/unneeded_disable.rb +117 -56
- data/lib/rubocop/cop/lint/unneeded_require_statement.rb +51 -0
- data/lib/rubocop/cop/lint/unneeded_splat_expansion.rb +167 -0
- data/lib/rubocop/cop/lint/unreachable_code.rb +72 -8
- data/lib/rubocop/cop/lint/unused_block_argument.rb +87 -27
- data/lib/rubocop/cop/lint/unused_method_argument.rb +18 -2
- data/lib/rubocop/cop/lint/uri_escape_unescape.rb +75 -0
- data/lib/rubocop/cop/lint/uri_regexp.rb +73 -0
- data/lib/rubocop/cop/lint/useless_access_modifier.rb +40 -18
- data/lib/rubocop/cop/lint/useless_assignment.rb +45 -14
- data/lib/rubocop/cop/lint/useless_comparison.rb +8 -10
- data/lib/rubocop/cop/lint/useless_else_without_rescue.rb +16 -2
- data/lib/rubocop/cop/lint/useless_setter_call.rb +57 -43
- data/lib/rubocop/cop/lint/void.rb +83 -23
- data/lib/rubocop/cop/message_annotator.rb +118 -0
- data/lib/rubocop/cop/metrics/abc_size.rb +3 -4
- data/lib/rubocop/cop/metrics/block_length.rb +32 -0
- data/lib/rubocop/cop/metrics/block_nesting.rb +21 -10
- data/lib/rubocop/cop/metrics/class_length.rb +3 -2
- data/lib/rubocop/cop/metrics/cyclomatic_complexity.rb +4 -4
- data/lib/rubocop/cop/metrics/line_length.rb +67 -14
- data/lib/rubocop/cop/metrics/method_length.rb +10 -10
- data/lib/rubocop/cop/metrics/module_length.rb +3 -2
- data/lib/rubocop/cop/metrics/parameter_lists.rb +15 -6
- data/lib/rubocop/cop/metrics/perceived_complexity.rb +5 -6
- data/lib/rubocop/cop/mixin/alignment.rb +70 -0
- data/lib/rubocop/cop/mixin/annotation_comment.rb +0 -1
- data/lib/rubocop/cop/mixin/array_hash_indentation.rb +26 -22
- data/lib/rubocop/cop/mixin/array_min_size.rb +59 -0
- data/lib/rubocop/cop/mixin/array_syntax.rb +4 -12
- data/lib/rubocop/cop/mixin/check_assignment.rb +6 -7
- data/lib/rubocop/cop/mixin/classish_length.rb +0 -1
- data/lib/rubocop/cop/mixin/code_length.rb +4 -3
- data/lib/rubocop/cop/mixin/configurable_enforced_style.rb +21 -16
- data/lib/rubocop/cop/mixin/configurable_formatting.rb +48 -0
- data/lib/rubocop/cop/mixin/configurable_max.rb +5 -4
- data/lib/rubocop/cop/mixin/configurable_naming.rb +5 -35
- data/lib/rubocop/cop/mixin/configurable_numbering.rb +17 -0
- data/lib/rubocop/cop/mixin/def_node.rb +29 -0
- data/lib/rubocop/cop/mixin/documentation_comment.rb +46 -0
- data/lib/rubocop/cop/mixin/duplication.rb +46 -0
- data/lib/rubocop/cop/mixin/empty_lines_around_body.rb +119 -27
- data/lib/rubocop/cop/mixin/empty_parameter.rb +23 -0
- data/lib/rubocop/cop/mixin/end_keyword_alignment.rb +11 -27
- data/lib/rubocop/cop/mixin/enforce_superclass.rb +30 -0
- data/lib/rubocop/cop/mixin/first_element_line_break.rb +15 -11
- data/lib/rubocop/cop/mixin/frozen_string_literal.rb +15 -13
- data/lib/rubocop/cop/mixin/hash_alignment.rb +116 -0
- data/lib/rubocop/cop/mixin/heredoc.rb +28 -0
- data/lib/rubocop/cop/mixin/ignored_pattern.rb +29 -0
- data/lib/rubocop/cop/mixin/integer_node.rb +2 -1
- data/lib/rubocop/cop/mixin/match_range.rb +4 -6
- data/lib/rubocop/cop/mixin/method_complexity.rb +33 -8
- data/lib/rubocop/cop/mixin/method_preference.rb +2 -1
- data/lib/rubocop/cop/mixin/min_body_length.rb +2 -1
- data/lib/rubocop/cop/mixin/multiline_expression_indentation.rb +100 -66
- data/lib/rubocop/cop/mixin/multiline_literal_brace_layout.rb +49 -51
- data/lib/rubocop/cop/mixin/negative_conditional.rb +18 -13
- data/lib/rubocop/cop/mixin/on_normal_if_unless.rb +1 -25
- data/lib/rubocop/cop/mixin/ordered_gem_node.rb +48 -0
- data/lib/rubocop/cop/mixin/parentheses.rb +2 -8
- data/lib/rubocop/cop/mixin/parser_diagnostic.rb +4 -2
- data/lib/rubocop/cop/mixin/percent_array.rb +52 -0
- data/lib/rubocop/cop/mixin/percent_literal.rb +69 -6
- data/lib/rubocop/cop/mixin/preceding_following_alignment.rb +16 -5
- data/lib/rubocop/cop/mixin/rescue_node.rb +23 -0
- data/lib/rubocop/cop/mixin/safe_assignment.rb +3 -1
- data/lib/rubocop/cop/mixin/safe_mode.rb +22 -0
- data/lib/rubocop/cop/mixin/space_after_punctuation.rb +8 -10
- data/lib/rubocop/cop/mixin/space_before_punctuation.rb +10 -14
- data/lib/rubocop/cop/mixin/statement_modifier.rb +29 -32
- data/lib/rubocop/cop/mixin/string_help.rb +3 -2
- data/lib/rubocop/cop/mixin/string_literals_help.rb +3 -15
- data/lib/rubocop/cop/mixin/surrounding_space.rb +78 -9
- data/lib/rubocop/cop/mixin/target_rails_version.rb +16 -0
- data/lib/rubocop/cop/mixin/target_ruby_version.rb +16 -0
- data/lib/rubocop/cop/mixin/too_many_lines.rb +39 -0
- data/lib/rubocop/cop/mixin/trailing_comma.rb +37 -38
- data/lib/rubocop/cop/mixin/unused_argument.rb +6 -16
- data/lib/rubocop/cop/naming/accessor_method_name.rb +55 -0
- data/lib/rubocop/cop/{style → naming}/ascii_identifiers.rb +36 -5
- data/lib/rubocop/cop/naming/binary_operator_parameter_name.rb +42 -0
- 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 +72 -29
- 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/naming/variable_number.rb +61 -0
- data/lib/rubocop/cop/offense.rb +9 -5
- data/lib/rubocop/cop/performance/caller.rb +69 -0
- data/lib/rubocop/cop/performance/case_when_splat.rb +65 -89
- data/lib/rubocop/cop/performance/casecmp.rb +37 -25
- data/lib/rubocop/cop/performance/compare_with_block.rb +117 -0
- data/lib/rubocop/cop/performance/count.rb +33 -43
- data/lib/rubocop/cop/performance/detect.rb +30 -31
- data/lib/rubocop/cop/performance/double_start_end_with.rb +55 -26
- data/lib/rubocop/cop/performance/end_with.rb +9 -9
- data/lib/rubocop/cop/performance/fixed_size.rb +21 -17
- data/lib/rubocop/cop/performance/flat_map.rb +30 -33
- data/lib/rubocop/cop/performance/hash_each_methods.rb +129 -0
- data/lib/rubocop/cop/performance/lstrip_rstrip.rb +14 -14
- data/lib/rubocop/cop/performance/range_include.rb +5 -4
- data/lib/rubocop/cop/performance/redundant_block_call.rb +28 -29
- data/lib/rubocop/cop/performance/redundant_match.rb +19 -15
- data/lib/rubocop/cop/performance/redundant_merge.rb +100 -52
- data/lib/rubocop/cop/performance/redundant_sort_by.rb +17 -14
- data/lib/rubocop/cop/performance/regexp_match.rb +224 -0
- data/lib/rubocop/cop/performance/reverse_each.rb +3 -6
- data/lib/rubocop/cop/performance/sample.rb +84 -83
- data/lib/rubocop/cop/performance/size.rb +22 -15
- data/lib/rubocop/cop/performance/start_with.rb +9 -9
- data/lib/rubocop/cop/performance/string_replacement.rb +35 -70
- data/lib/rubocop/cop/performance/times_map.rb +33 -24
- 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 +67 -47
- data/lib/rubocop/cop/rails/active_support_aliases.rb +68 -0
- data/lib/rubocop/cop/rails/application_job.rb +40 -0
- data/lib/rubocop/cop/rails/application_record.rb +40 -0
- data/lib/rubocop/cop/rails/blank.rb +142 -0
- data/lib/rubocop/cop/rails/create_table_with_timestamps.rb +82 -0
- data/lib/rubocop/cop/rails/date.rb +47 -42
- data/lib/rubocop/cop/rails/delegate.rb +55 -33
- data/lib/rubocop/cop/rails/delegate_allow_blank.rb +51 -0
- data/lib/rubocop/cop/rails/dynamic_find_by.rb +82 -0
- data/lib/rubocop/cop/rails/enum_uniqueness.rb +45 -0
- data/lib/rubocop/cop/rails/environment_comparison.rb +66 -0
- data/lib/rubocop/cop/rails/exit.rb +17 -11
- data/lib/rubocop/cop/rails/file_path.rb +72 -0
- data/lib/rubocop/cop/rails/find_by.rb +14 -20
- data/lib/rubocop/cop/rails/find_each.rb +8 -21
- data/lib/rubocop/cop/rails/has_and_belongs_to_many.rb +9 -2
- data/lib/rubocop/cop/rails/has_many_or_has_one_dependent.rb +84 -0
- data/lib/rubocop/cop/rails/http_positional_arguments.rb +102 -0
- data/lib/rubocop/cop/rails/inverse_of.rb +218 -0
- data/lib/rubocop/cop/rails/lexically_scoped_action_filter.rb +112 -0
- data/lib/rubocop/cop/rails/not_null_column.rb +67 -0
- data/lib/rubocop/cop/rails/output.rb +15 -13
- data/lib/rubocop/cop/rails/output_safety.rb +65 -17
- data/lib/rubocop/cop/rails/pluralization_grammar.rb +30 -29
- data/lib/rubocop/cop/rails/presence.rb +118 -0
- data/lib/rubocop/cop/rails/present.rb +143 -0
- data/lib/rubocop/cop/rails/read_write_attribute.rb +20 -26
- data/lib/rubocop/cop/rails/redundant_receiver_in_with_options.rb +133 -0
- data/lib/rubocop/cop/rails/relative_date_constant.rb +88 -0
- data/lib/rubocop/cop/rails/request_referer.rb +28 -13
- data/lib/rubocop/cop/rails/reversible_migration.rb +281 -0
- data/lib/rubocop/cop/rails/safe_navigation.rb +90 -0
- data/lib/rubocop/cop/rails/save_bang.rb +104 -19
- data/lib/rubocop/cop/rails/scope_args.rb +5 -10
- data/lib/rubocop/cop/rails/skips_model_validations.rb +70 -0
- data/lib/rubocop/cop/rails/time_zone.rb +34 -21
- data/lib/rubocop/cop/rails/uniq_before_pluck.rb +17 -14
- data/lib/rubocop/cop/rails/unknown_env.rb +63 -0
- data/lib/rubocop/cop/rails/validation.rb +16 -20
- data/lib/rubocop/cop/registry.rb +172 -0
- data/lib/rubocop/cop/security/eval.rb +30 -0
- data/lib/rubocop/cop/security/json_load.rb +46 -0
- data/lib/rubocop/cop/security/marshal_load.rb +39 -0
- data/lib/rubocop/cop/security/yaml_load.rb +37 -0
- data/lib/rubocop/cop/severity.rb +1 -2
- data/lib/rubocop/cop/style/alias.rb +54 -33
- data/lib/rubocop/cop/style/and_or.rb +77 -63
- data/lib/rubocop/cop/style/array_join.rb +13 -9
- data/lib/rubocop/cop/style/ascii_comments.rb +25 -7
- data/lib/rubocop/cop/style/attr.rb +24 -11
- data/lib/rubocop/cop/style/auto_resource_cleanup.rb +21 -16
- data/lib/rubocop/cop/style/bare_percent_literals.rb +31 -11
- data/lib/rubocop/cop/style/begin_block.rb +1 -2
- data/lib/rubocop/cop/style/block_comments.rb +20 -11
- data/lib/rubocop/cop/style/block_delimiters.rb +122 -51
- data/lib/rubocop/cop/style/braces_around_hash_parameters.rb +142 -54
- data/lib/rubocop/cop/style/case_equality.rb +15 -4
- data/lib/rubocop/cop/style/character_literal.rb +12 -5
- data/lib/rubocop/cop/style/class_and_module_children.rb +85 -6
- data/lib/rubocop/cop/style/class_check.rb +35 -19
- data/lib/rubocop/cop/style/class_methods.rb +13 -14
- data/lib/rubocop/cop/style/class_vars.rb +5 -5
- data/lib/rubocop/cop/style/collection_methods.rb +12 -13
- data/lib/rubocop/cop/style/colon_method_call.rb +24 -16
- data/lib/rubocop/cop/style/colon_method_definition.rb +36 -0
- data/lib/rubocop/cop/style/command_literal.rb +98 -32
- data/lib/rubocop/cop/style/comment_annotation.rb +41 -15
- data/lib/rubocop/cop/style/commented_keyword.rb +84 -0
- data/lib/rubocop/cop/style/conditional_assignment.rb +161 -112
- data/lib/rubocop/cop/style/copyright.rb +32 -34
- data/lib/rubocop/cop/style/date_time.rb +44 -0
- data/lib/rubocop/cop/style/def_with_parentheses.rb +32 -9
- data/lib/rubocop/cop/style/dir.rb +48 -0
- data/lib/rubocop/cop/style/documentation.rb +44 -58
- data/lib/rubocop/cop/style/documentation_method.rb +76 -0
- data/lib/rubocop/cop/style/double_negation.rb +3 -3
- data/lib/rubocop/cop/style/each_for_simple_loop.rb +14 -13
- data/lib/rubocop/cop/style/each_with_object.rb +28 -25
- data/lib/rubocop/cop/style/empty_block_parameter.rb +47 -0
- data/lib/rubocop/cop/style/empty_case_condition.rb +18 -30
- data/lib/rubocop/cop/style/empty_else.rb +82 -51
- data/lib/rubocop/cop/style/empty_lambda_parameter.rb +43 -0
- data/lib/rubocop/cop/style/empty_literal.rb +76 -48
- data/lib/rubocop/cop/style/empty_method.rb +112 -0
- data/lib/rubocop/cop/style/encoding.rb +10 -40
- data/lib/rubocop/cop/style/end_block.rb +1 -2
- data/lib/rubocop/cop/style/eval_with_location.rb +146 -0
- data/lib/rubocop/cop/style/even_odd.rb +25 -44
- data/lib/rubocop/cop/style/flip_flop.rb +13 -3
- data/lib/rubocop/cop/style/for.rb +19 -15
- data/lib/rubocop/cop/style/format_string.rb +88 -42
- data/lib/rubocop/cop/style/format_string_token.rb +163 -0
- data/lib/rubocop/cop/style/frozen_string_literal_comment.rb +90 -15
- data/lib/rubocop/cop/style/global_vars.rb +14 -5
- data/lib/rubocop/cop/style/guard_clause.rb +22 -62
- data/lib/rubocop/cop/style/hash_syntax.rb +109 -59
- data/lib/rubocop/cop/style/identical_conditional_branches.rb +73 -32
- data/lib/rubocop/cop/style/if_inside_else.rb +16 -20
- data/lib/rubocop/cop/style/if_unless_modifier.rb +48 -39
- data/lib/rubocop/cop/style/if_unless_modifier_of_if_unless.rb +6 -12
- data/lib/rubocop/cop/style/if_with_semicolon.rb +10 -2
- data/lib/rubocop/cop/style/implicit_runtime_error.rb +7 -7
- data/lib/rubocop/cop/style/infinite_loop.rb +33 -32
- data/lib/rubocop/cop/style/inline_comment.rb +17 -5
- data/lib/rubocop/cop/style/inverse_methods.rb +149 -0
- data/lib/rubocop/cop/style/lambda.rb +66 -63
- data/lib/rubocop/cop/style/lambda_call.rb +50 -20
- data/lib/rubocop/cop/style/line_end_concatenation.rb +38 -17
- data/lib/rubocop/cop/style/method_call_with_args_parentheses.rb +90 -0
- data/lib/rubocop/cop/style/{method_call_parentheses.rb → method_call_without_args_parentheses.rb} +32 -25
- data/lib/rubocop/cop/style/method_called_on_do_end_block.rb +9 -9
- data/lib/rubocop/cop/style/method_def_parentheses.rb +101 -29
- data/lib/rubocop/cop/style/method_missing.rb +14 -20
- data/lib/rubocop/cop/style/min_max.rb +68 -0
- data/lib/rubocop/cop/style/missing_else.rb +61 -21
- data/lib/rubocop/cop/style/mixin_grouping.rb +145 -0
- data/lib/rubocop/cop/style/mixin_usage.rb +82 -0
- data/lib/rubocop/cop/style/module_function.rb +44 -18
- data/lib/rubocop/cop/style/multiline_block_chain.rb +8 -15
- data/lib/rubocop/cop/style/multiline_if_modifier.rb +67 -0
- data/lib/rubocop/cop/style/multiline_if_then.rb +21 -14
- data/lib/rubocop/cop/style/multiline_memoization.rb +93 -0
- data/lib/rubocop/cop/style/multiline_ternary_operator.rb +21 -9
- data/lib/rubocop/cop/style/multiple_comparison.rb +77 -0
- data/lib/rubocop/cop/style/mutable_constant.rb +17 -9
- data/lib/rubocop/cop/style/negated_if.rb +76 -25
- data/lib/rubocop/cop/style/negated_while.rb +4 -22
- data/lib/rubocop/cop/style/nested_modifier.rb +17 -47
- data/lib/rubocop/cop/style/nested_parenthesized_calls.rb +32 -28
- data/lib/rubocop/cop/style/nested_ternary_operator.rb +3 -6
- data/lib/rubocop/cop/style/next.rb +72 -53
- data/lib/rubocop/cop/style/nil_comparison.rb +10 -14
- data/lib/rubocop/cop/style/non_nil_check.rb +69 -62
- data/lib/rubocop/cop/style/not.rb +19 -13
- data/lib/rubocop/cop/style/numeric_literal_prefix.rb +16 -7
- data/lib/rubocop/cop/style/numeric_literals.rb +33 -12
- data/lib/rubocop/cop/style/numeric_predicate.rb +30 -32
- data/lib/rubocop/cop/style/one_line_conditional.rb +21 -17
- data/lib/rubocop/cop/style/option_hash.rb +11 -37
- data/lib/rubocop/cop/style/optional_arguments.rb +20 -9
- data/lib/rubocop/cop/style/or_assignment.rb +88 -0
- data/lib/rubocop/cop/style/parallel_assignment.rb +83 -64
- data/lib/rubocop/cop/style/parentheses_around_condition.rb +37 -19
- data/lib/rubocop/cop/style/percent_literal_delimiters.rb +50 -15
- data/lib/rubocop/cop/style/percent_q_literals.rb +40 -17
- data/lib/rubocop/cop/style/perl_backrefs.rb +9 -3
- data/lib/rubocop/cop/style/preferred_hash_methods.rb +48 -14
- data/lib/rubocop/cop/style/proc.rb +13 -10
- data/lib/rubocop/cop/style/raise_args.rb +46 -50
- data/lib/rubocop/cop/style/random_with_offset.rb +160 -0
- data/lib/rubocop/cop/style/redundant_begin.rb +16 -6
- data/lib/rubocop/cop/style/redundant_conditional.rb +96 -0
- data/lib/rubocop/cop/style/redundant_exception.rb +4 -5
- data/lib/rubocop/cop/style/redundant_freeze.rb +7 -10
- data/lib/rubocop/cop/style/redundant_parentheses.rb +70 -31
- data/lib/rubocop/cop/style/redundant_return.rb +61 -23
- data/lib/rubocop/cop/style/redundant_self.rb +62 -60
- data/lib/rubocop/cop/style/regexp_literal.rb +100 -34
- data/lib/rubocop/cop/style/rescue_modifier.rb +15 -17
- 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 +197 -0
- data/lib/rubocop/cop/style/self_assignment.rb +20 -17
- data/lib/rubocop/cop/style/semicolon.rb +25 -17
- data/lib/rubocop/cop/style/send.rb +14 -4
- data/lib/rubocop/cop/style/signal_exception.rb +105 -7
- data/lib/rubocop/cop/style/single_line_block_params.rb +27 -21
- data/lib/rubocop/cop/style/single_line_methods.rb +45 -31
- data/lib/rubocop/cop/style/special_global_vars.rb +32 -28
- data/lib/rubocop/cop/style/stabby_lambda_parentheses.rb +24 -53
- 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 +31 -5
- data/lib/rubocop/cop/style/string_literals_in_interpolation.rb +20 -2
- data/lib/rubocop/cop/style/string_methods.rb +22 -9
- data/lib/rubocop/cop/style/struct_inheritance.rb +5 -17
- data/lib/rubocop/cop/style/symbol_array.rb +39 -65
- data/lib/rubocop/cop/style/symbol_literal.rb +1 -2
- data/lib/rubocop/cop/style/symbol_proc.rb +35 -52
- data/lib/rubocop/cop/style/ternary_parentheses.rb +143 -42
- data/lib/rubocop/cop/style/trailing_body_on_method_definition.rb +101 -0
- data/lib/rubocop/cop/style/trailing_comma_in_arguments.rb +31 -20
- data/lib/rubocop/cop/style/trailing_comma_in_literal.rb +26 -8
- data/lib/rubocop/cop/style/trailing_method_end_statement.rb +95 -0
- data/lib/rubocop/cop/style/trailing_underscore_variable.rb +97 -37
- data/lib/rubocop/cop/style/trivial_accessors.rb +72 -66
- data/lib/rubocop/cop/style/unless_else.rb +19 -13
- data/lib/rubocop/cop/style/unneeded_capital_w.rb +24 -10
- data/lib/rubocop/cop/style/unneeded_interpolation.rb +22 -24
- data/lib/rubocop/cop/style/unneeded_percent_q.rb +28 -22
- data/lib/rubocop/cop/style/variable_interpolation.rb +23 -10
- data/lib/rubocop/cop/style/when_then.rb +18 -4
- data/lib/rubocop/cop/style/while_until_do.rb +34 -16
- data/lib/rubocop/cop/style/while_until_modifier.rb +32 -12
- data/lib/rubocop/cop/style/word_array.rb +45 -102
- data/lib/rubocop/cop/style/yoda_condition.rb +107 -0
- data/lib/rubocop/cop/style/zero_length_predicate.rb +55 -32
- data/lib/rubocop/cop/team.rb +33 -35
- data/lib/rubocop/cop/util.rb +120 -54
- data/lib/rubocop/cop/variable_force/assignment.rb +5 -9
- data/lib/rubocop/cop/variable_force/branch.rb +318 -0
- data/lib/rubocop/cop/variable_force/branchable.rb +21 -0
- data/lib/rubocop/cop/variable_force/reference.rb +1 -2
- data/lib/rubocop/cop/variable_force/scope.rb +37 -26
- data/lib/rubocop/cop/variable_force/variable.rb +12 -12
- data/lib/rubocop/cop/variable_force/variable_table.rb +3 -4
- data/lib/rubocop/cop/variable_force.rb +72 -39
- data/lib/rubocop/error.rb +0 -1
- data/lib/rubocop/formatter/base_formatter.rb +4 -9
- data/lib/rubocop/formatter/clang_style_formatter.rb +2 -3
- data/lib/rubocop/formatter/colorizable.rb +9 -10
- data/lib/rubocop/formatter/disabled_config_formatter.rb +48 -35
- data/lib/rubocop/formatter/disabled_lines_formatter.rb +0 -1
- data/lib/rubocop/formatter/emacs_style_formatter.rb +0 -1
- data/lib/rubocop/formatter/file_list_formatter.rb +0 -1
- data/lib/rubocop/formatter/formatter_set.rb +16 -13
- data/lib/rubocop/formatter/fuubar_style_formatter.rb +6 -1
- data/lib/rubocop/formatter/html_formatter.rb +5 -5
- data/lib/rubocop/formatter/json_formatter.rb +9 -4
- data/lib/rubocop/formatter/offense_count_formatter.rb +2 -1
- data/lib/rubocop/formatter/progress_formatter.rb +0 -1
- data/lib/rubocop/formatter/quiet_formatter.rb +13 -0
- data/lib/rubocop/formatter/simple_text_formatter.rb +7 -17
- data/lib/rubocop/formatter/tap_formatter.rb +71 -0
- data/lib/rubocop/formatter/text_util.rb +0 -1
- data/lib/rubocop/formatter/worst_offenders_formatter.rb +6 -5
- data/lib/rubocop/magic_comment.rb +210 -0
- data/lib/rubocop/name_similarity.rb +0 -1
- data/lib/rubocop/node_pattern.rb +181 -118
- data/lib/rubocop/options.rb +154 -88
- data/lib/rubocop/path_util.rb +38 -4
- data/lib/rubocop/platform.rb +11 -0
- data/lib/rubocop/processed_source.rb +23 -20
- data/lib/rubocop/rake_task.rb +16 -24
- data/lib/rubocop/remote_config.rb +40 -13
- data/lib/rubocop/result_cache.rb +33 -24
- data/lib/rubocop/rspec/cop_helper.rb +21 -7
- data/lib/rubocop/rspec/expect_offense.rb +165 -0
- data/lib/rubocop/rspec/host_environment_simulation_helper.rb +1 -2
- data/lib/rubocop/rspec/shared_contexts.rb +24 -9
- data/lib/rubocop/rspec/shared_examples.rb +10 -19
- data/lib/rubocop/rspec/support.rb +5 -5
- data/lib/rubocop/runner.rb +74 -39
- data/lib/rubocop/string_interpreter.rb +0 -1
- data/lib/rubocop/string_util.rb +11 -6
- data/lib/rubocop/target_finder.rb +70 -8
- data/lib/rubocop/token.rb +79 -2
- data/lib/rubocop/version.rb +2 -5
- data/lib/rubocop/warning.rb +0 -1
- data/lib/rubocop.rb +569 -398
- metadata +301 -112
- data/lib/rubocop/ast_node/builder.rb +0 -31
- data/lib/rubocop/ast_node/sexp.rb +0 -14
- data/lib/rubocop/ast_node.rb +0 -623
- data/lib/rubocop/cop/lint/eval.rb +0 -23
- data/lib/rubocop/cop/lint/invalid_character_literal.rb +0 -39
- data/lib/rubocop/cop/lint/useless_array_splat.rb +0 -56
- data/lib/rubocop/cop/mixin/access_modifier_node.rb +0 -42
- data/lib/rubocop/cop/mixin/autocorrect_alignment.rb +0 -152
- data/lib/rubocop/cop/mixin/hash_node.rb +0 -15
- data/lib/rubocop/cop/mixin/if_node.rb +0 -37
- data/lib/rubocop/cop/mixin/on_method_def.rb +0 -31
- data/lib/rubocop/cop/mixin/space_inside.rb +0 -79
- data/lib/rubocop/cop/performance/hash_each.rb +0 -86
- data/lib/rubocop/cop/performance/push_splat.rb +0 -47
- data/lib/rubocop/cop/style/accessor_method_name.rb +0 -46
- data/lib/rubocop/cop/style/align_array.rb +0 -21
- data/lib/rubocop/cop/style/align_hash.rb +0 -256
- data/lib/rubocop/cop/style/case_indentation.rb +0 -92
- data/lib/rubocop/cop/style/class_and_module_camel_case.rb +0 -30
- data/lib/rubocop/cop/style/constant_name.rb +0 -30
- data/lib/rubocop/cop/style/empty_line_between_defs.rb +0 -76
- data/lib/rubocop/cop/style/empty_lines_around_class_body.rb +0 -40
- data/lib/rubocop/cop/style/end_of_line.rb +0 -31
- data/lib/rubocop/cop/style/initial_indentation.rb +0 -38
- data/lib/rubocop/cop/style/leading_comment_space.rb +0 -33
- data/lib/rubocop/cop/style/method_name.rb +0 -29
- data/lib/rubocop/cop/style/multiline_method_call_indentation.rb +0 -176
- data/lib/rubocop/cop/style/op_method.rb +0 -44
- data/lib/rubocop/cop/style/predicate_name.rb +0 -68
- data/lib/rubocop/cop/style/space_after_comma.rb +0 -22
- data/lib/rubocop/cop/style/space_after_not.rb +0 -42
- data/lib/rubocop/cop/style/space_around_operators.rb +0 -132
- data/lib/rubocop/cop/style/space_before_block_braces.rb +0 -65
- data/lib/rubocop/cop/style/space_before_comma.rb +0 -17
- data/lib/rubocop/cop/style/space_before_semicolon.rb +0 -17
- data/lib/rubocop/cop/style/space_inside_block_braces.rb +0 -166
- data/lib/rubocop/cop/style/space_inside_brackets.rb +0 -21
- data/lib/rubocop/cop/style/space_inside_parens.rb +0 -17
- data/lib/rubocop/cop/style/space_inside_string_interpolation.rb +0 -52
- data/lib/rubocop/cop/style/variable_name.rb +0 -40
- data/lib/rubocop/cop/variable_force/locatable.rb +0 -197
@@ -1,9 +1,8 @@
|
|
1
|
-
# encoding: utf-8
|
2
1
|
# frozen_string_literal: true
|
3
2
|
|
4
3
|
module RuboCop
|
5
4
|
module Cop
|
6
|
-
module
|
5
|
+
module Layout
|
7
6
|
# This cop checks the indentation of the first parameter in a method call.
|
8
7
|
# Parameters after the first one are checked by Style/AlignParameters, not
|
9
8
|
# by this cop.
|
@@ -20,27 +19,27 @@ module RuboCop
|
|
20
19
|
# first_param,
|
21
20
|
# second_param)
|
22
21
|
class FirstParameterIndentation < Cop
|
23
|
-
include
|
22
|
+
include Alignment
|
24
23
|
include ConfigurableEnforcedStyle
|
25
24
|
|
25
|
+
MSG = 'Indent the first parameter one step more than %<base>s.'.freeze
|
26
|
+
|
26
27
|
def on_send(node)
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
check_alignment([args.first],
|
37
|
-
base_indentation + configured_indentation_width)
|
28
|
+
return if !node.arguments? || node.operator_method?
|
29
|
+
|
30
|
+
indent = base_indentation(node) + configured_indentation_width
|
31
|
+
|
32
|
+
check_alignment([node.first_argument], indent)
|
33
|
+
end
|
34
|
+
|
35
|
+
def autocorrect(node)
|
36
|
+
AlignmentCorrector.correct(processed_source, node, column_delta)
|
38
37
|
end
|
39
38
|
|
40
39
|
private
|
41
40
|
|
42
41
|
def message(arg_node)
|
43
|
-
return 'Bad indentation of the first parameter.'
|
42
|
+
return 'Bad indentation of the first parameter.' unless arg_node
|
44
43
|
|
45
44
|
send_node = arg_node.parent
|
46
45
|
text = base_range(send_node, arg_node).source.strip
|
@@ -51,21 +50,25 @@ module RuboCop
|
|
51
50
|
else
|
52
51
|
'the start of the previous line'
|
53
52
|
end
|
54
|
-
|
53
|
+
|
54
|
+
format(MSG, base: base)
|
55
|
+
end
|
56
|
+
|
57
|
+
def base_indentation(node)
|
58
|
+
if special_inner_call_indentation?(node)
|
59
|
+
column_of(base_range(node, node.first_argument))
|
60
|
+
else
|
61
|
+
previous_code_line(node.first_argument.first_line) =~ /\S/
|
62
|
+
end
|
55
63
|
end
|
56
64
|
|
57
65
|
def special_inner_call_indentation?(node)
|
58
66
|
return false if style == :consistent
|
59
67
|
|
60
68
|
parent = node.parent
|
61
|
-
return false unless parent
|
62
|
-
return false unless parent.send_type?
|
63
|
-
|
64
|
-
_receiver, method_name, *_args = *parent
|
65
|
-
# :[]= is a send node, but we want to treat it as an assignment.
|
66
|
-
return false if method_name == :[]=
|
67
69
|
|
68
|
-
return false
|
70
|
+
return false unless eligible_method_call?(parent)
|
71
|
+
return false if !parent.parenthesized? &&
|
69
72
|
style == :special_for_inner_method_call_in_parentheses
|
70
73
|
|
71
74
|
# The node must begin inside the parent, otherwise node is the first
|
@@ -73,10 +76,13 @@ module RuboCop
|
|
73
76
|
node.source_range.begin_pos > parent.source_range.begin_pos
|
74
77
|
end
|
75
78
|
|
79
|
+
def_node_matcher :eligible_method_call?, <<-PATTERN
|
80
|
+
(send _ !:[]= ...)
|
81
|
+
PATTERN
|
82
|
+
|
76
83
|
def base_range(send_node, arg_node)
|
77
|
-
|
78
|
-
|
79
|
-
arg_node.source_range.begin_pos)
|
84
|
+
range_between(send_node.source_range.begin_pos,
|
85
|
+
arg_node.source_range.begin_pos)
|
80
86
|
end
|
81
87
|
|
82
88
|
# Returns the column of the given range. For single line ranges, this
|
@@ -1,9 +1,8 @@
|
|
1
|
-
# encoding: utf-8
|
2
1
|
# frozen_string_literal: true
|
3
2
|
|
4
3
|
module RuboCop
|
5
4
|
module Cop
|
6
|
-
module
|
5
|
+
module Layout
|
7
6
|
# This cop checks the indentation of the first element in an array literal
|
8
7
|
# where the opening bracket and the first element are on separate lines.
|
9
8
|
# The other elements' indentations are handled by the AlignArray cop.
|
@@ -20,30 +19,74 @@ module RuboCop
|
|
20
19
|
# This default style is called 'special_inside_parentheses'. Alternative
|
21
20
|
# styles are 'consistent' and 'align_brackets'. Here are examples:
|
22
21
|
#
|
23
|
-
#
|
24
|
-
#
|
25
|
-
#
|
26
|
-
#
|
27
|
-
#
|
28
|
-
# :its_like_this
|
29
|
-
# ])
|
30
|
-
# # consistent
|
31
|
-
# array = [
|
32
|
-
# :value
|
33
|
-
# ]
|
34
|
-
# and_in_a_method_call([
|
35
|
-
# :no_difference
|
36
|
-
# ])
|
37
|
-
# # align_brackets
|
38
|
-
# and_now_for_something = [
|
39
|
-
# :completely_different
|
40
|
-
# ]
|
22
|
+
# @example EnforcedStyle: special_inside_parentheses (default)
|
23
|
+
# # The `special_inside_parentheses` style enforces that the first
|
24
|
+
# # element in an array literal where the opening bracket and first
|
25
|
+
# # element are on seprate lines is indented one step (two spaces) more
|
26
|
+
# # than the position inside the opening parenthesis.
|
41
27
|
#
|
28
|
+
# #bad
|
29
|
+
# array = [
|
30
|
+
# :value
|
31
|
+
# ]
|
32
|
+
# and_in_a_method_call([
|
33
|
+
# :no_difference
|
34
|
+
# ])
|
35
|
+
#
|
36
|
+
# #good
|
37
|
+
# array = [
|
38
|
+
# :value
|
39
|
+
# ]
|
40
|
+
# but_in_a_method_call([
|
41
|
+
# :its_like_this
|
42
|
+
# ])
|
43
|
+
#
|
44
|
+
# @example EnforcedStyle: consistent
|
45
|
+
# # The `consistent` style enforces that the first element in an array
|
46
|
+
# # literal where the opening bracket and the first element are on
|
47
|
+
# # seprate lines is indented the same as an array literal which is not
|
48
|
+
# # defined inside a method call.
|
49
|
+
#
|
50
|
+
# #bad
|
51
|
+
# # consistent
|
52
|
+
# array = [
|
53
|
+
# :value
|
54
|
+
# ]
|
55
|
+
# but_in_a_method_call([
|
56
|
+
# :its_like_this
|
57
|
+
# ])
|
58
|
+
#
|
59
|
+
# #good
|
60
|
+
# array = [
|
61
|
+
# :value
|
62
|
+
# ]
|
63
|
+
# and_in_a_method_call([
|
64
|
+
# :no_difference
|
65
|
+
# ])
|
66
|
+
#
|
67
|
+
# @example EnforcedStyle: align_brackets
|
68
|
+
# # The `align_brackets` style enforces that the opening and closing
|
69
|
+
# # brackets are indented to the same position.
|
70
|
+
#
|
71
|
+
# #bad
|
72
|
+
# # align_brackets
|
73
|
+
# and_now_for_something = [
|
74
|
+
# :completely_different
|
75
|
+
# ]
|
76
|
+
#
|
77
|
+
# #good
|
78
|
+
# # align_brackets
|
79
|
+
# and_now_for_something = [
|
80
|
+
# :completely_different
|
81
|
+
# ]
|
42
82
|
class IndentArray < Cop
|
43
|
-
include
|
83
|
+
include Alignment
|
44
84
|
include ConfigurableEnforcedStyle
|
45
85
|
include ArrayHashIndentation
|
46
86
|
|
87
|
+
MSG = 'Use %<configured_indentation_width>d spaces for indentation ' \
|
88
|
+
'in an array, relative to %<base_description>s.'.freeze
|
89
|
+
|
47
90
|
def on_array(node)
|
48
91
|
check(node, nil) if node.loc.begin
|
49
92
|
end
|
@@ -54,6 +97,10 @@ module RuboCop
|
|
54
97
|
end
|
55
98
|
end
|
56
99
|
|
100
|
+
def autocorrect(node)
|
101
|
+
AlignmentCorrector.correct(processed_source, node, @column_delta)
|
102
|
+
end
|
103
|
+
|
57
104
|
private
|
58
105
|
|
59
106
|
def brace_alignment_style
|
@@ -64,7 +111,7 @@ module RuboCop
|
|
64
111
|
return if ignored_node?(array_node)
|
65
112
|
|
66
113
|
left_bracket = array_node.loc.begin
|
67
|
-
first_elem = array_node.
|
114
|
+
first_elem = array_node.values.first
|
68
115
|
if first_elem
|
69
116
|
return if first_elem.source_range.line == left_bracket.line
|
70
117
|
check_first(first_elem, left_bracket, left_parenthesis, 0)
|
@@ -91,7 +138,7 @@ module RuboCop
|
|
91
138
|
'Indent the right bracket the same as the start of the line' \
|
92
139
|
' where the left bracket is.'
|
93
140
|
end
|
94
|
-
add_offense(right_bracket, right_bracket, msg)
|
141
|
+
add_offense(right_bracket, location: right_bracket, message: msg)
|
95
142
|
end
|
96
143
|
|
97
144
|
# Returns the description of what the correct indentation is based on.
|
@@ -106,8 +153,11 @@ module RuboCop
|
|
106
153
|
end
|
107
154
|
|
108
155
|
def message(base_description)
|
109
|
-
format(
|
110
|
-
|
156
|
+
format(
|
157
|
+
MSG,
|
158
|
+
configured_indentation_width: configured_indentation_width,
|
159
|
+
base_description: base_description
|
160
|
+
)
|
111
161
|
end
|
112
162
|
end
|
113
163
|
end
|
@@ -1,9 +1,8 @@
|
|
1
|
-
# encoding: utf-8
|
2
1
|
# frozen_string_literal: true
|
3
2
|
|
4
3
|
module RuboCop
|
5
4
|
module Cop
|
6
|
-
module
|
5
|
+
module Layout
|
7
6
|
# This cop checks the indentation of the first line of the
|
8
7
|
# right-hand-side of a multi-line assignment.
|
9
8
|
#
|
@@ -17,14 +16,14 @@ module RuboCop
|
|
17
16
|
# # good
|
18
17
|
# value =
|
19
18
|
# if foo
|
20
|
-
#
|
21
|
-
#
|
19
|
+
# 'bar'
|
20
|
+
# end
|
22
21
|
#
|
23
22
|
# The indentation of the remaining lines can be corrected with
|
24
23
|
# other cops such as `IndentationConsistency` and `EndAlignment`.
|
25
24
|
class IndentAssignment < Cop
|
26
25
|
include CheckAssignment
|
27
|
-
include
|
26
|
+
include Alignment
|
28
27
|
|
29
28
|
MSG = 'Indent the first line of the right-hand-side of a ' \
|
30
29
|
'multi-line assignment.'.freeze
|
@@ -32,11 +31,15 @@ module RuboCop
|
|
32
31
|
def check_assignment(node, rhs)
|
33
32
|
return unless rhs
|
34
33
|
return unless node.loc.operator
|
35
|
-
return if node.loc.operator.line == rhs.
|
34
|
+
return if node.loc.operator.line == rhs.first_line
|
36
35
|
|
37
36
|
base = display_column(node.source_range)
|
38
37
|
check_alignment([rhs], base + configured_indentation_width)
|
39
38
|
end
|
39
|
+
|
40
|
+
def autocorrect(node)
|
41
|
+
AlignmentCorrector.correct(processed_source, node, column_delta)
|
42
|
+
end
|
40
43
|
end
|
41
44
|
end
|
42
45
|
end
|
@@ -1,9 +1,8 @@
|
|
1
|
-
# encoding: utf-8
|
2
1
|
# frozen_string_literal: true
|
3
2
|
|
4
3
|
module RuboCop
|
5
4
|
module Cop
|
6
|
-
module
|
5
|
+
module Layout
|
7
6
|
# This cops checks the indentation of the first key in a hash literal
|
8
7
|
# where the opening brace and the first key are on separate lines. The
|
9
8
|
# other keys' indentations are handled by the AlignHash cop.
|
@@ -20,30 +19,72 @@ module RuboCop
|
|
20
19
|
# This default style is called 'special_inside_parentheses'. Alternative
|
21
20
|
# styles are 'consistent' and 'align_braces'. Here are examples:
|
22
21
|
#
|
23
|
-
#
|
24
|
-
#
|
25
|
-
#
|
26
|
-
#
|
27
|
-
#
|
28
|
-
# its_like: :this
|
29
|
-
# })
|
30
|
-
# # consistent
|
31
|
-
# hash = {
|
32
|
-
# key: :value
|
33
|
-
# }
|
34
|
-
# and_in_a_method_call({
|
35
|
-
# no: :difference
|
36
|
-
# })
|
37
|
-
# # align_braces
|
38
|
-
# and_now_for_something = {
|
39
|
-
# completely: :different
|
40
|
-
# }
|
22
|
+
# @example EnforcedStyle: special_inside_parentheses (default)
|
23
|
+
# # The `special_inside_parentheses` style enforces that the first key
|
24
|
+
# # in a hash literal where the opening brace and the first key are on
|
25
|
+
# # separate lines is indented one step (two spaces) more than the
|
26
|
+
# # position inside the opening parentheses.
|
41
27
|
#
|
28
|
+
# # bad
|
29
|
+
# hash = {
|
30
|
+
# key: :value
|
31
|
+
# }
|
32
|
+
# and_in_a_method_call({
|
33
|
+
# no: :difference
|
34
|
+
# })
|
35
|
+
#
|
36
|
+
# # good
|
37
|
+
# special_inside_parentheses
|
38
|
+
# hash = {
|
39
|
+
# key: :value
|
40
|
+
# }
|
41
|
+
# but_in_a_method_call({
|
42
|
+
# its_like: :this
|
43
|
+
# })
|
44
|
+
#
|
45
|
+
# @example EnforcedStyle: consistent
|
46
|
+
# # The `consistent` style enforces that the first key in a hash
|
47
|
+
# # literal where the opening brace and the first key are on
|
48
|
+
# # seprate lines is indented the same as a hash literal which is not
|
49
|
+
# # defined inside a method call.
|
50
|
+
#
|
51
|
+
# # bad
|
52
|
+
# hash = {
|
53
|
+
# key: :value
|
54
|
+
# }
|
55
|
+
# but_in_a_method_call({
|
56
|
+
# its_like: :this
|
57
|
+
# })
|
58
|
+
#
|
59
|
+
# # good
|
60
|
+
# hash = {
|
61
|
+
# key: :value
|
62
|
+
# }
|
63
|
+
# and_in_a_method_call({
|
64
|
+
# no: :difference
|
65
|
+
# })
|
66
|
+
#
|
67
|
+
# @example EnforcedStyle: align_braces
|
68
|
+
# # The `align_brackets` style enforces that the opening and closing
|
69
|
+
# # braces are indented to the same position.
|
70
|
+
#
|
71
|
+
# # bad
|
72
|
+
# and_now_for_something = {
|
73
|
+
# completely: :different
|
74
|
+
# }
|
75
|
+
#
|
76
|
+
# # good
|
77
|
+
# and_now_for_something = {
|
78
|
+
# completely: :different
|
79
|
+
# }
|
42
80
|
class IndentHash < Cop
|
43
|
-
include
|
81
|
+
include Alignment
|
44
82
|
include ConfigurableEnforcedStyle
|
45
83
|
include ArrayHashIndentation
|
46
84
|
|
85
|
+
MSG = 'Use %<configured_indentation_width>d spaces for indentation ' \
|
86
|
+
'in a hash, relative to %<base_description>s.'.freeze
|
87
|
+
|
47
88
|
def on_hash(node)
|
48
89
|
check(node, nil) if node.loc.begin
|
49
90
|
end
|
@@ -54,6 +95,10 @@ module RuboCop
|
|
54
95
|
end
|
55
96
|
end
|
56
97
|
|
98
|
+
def autocorrect(node)
|
99
|
+
AlignmentCorrector.correct(processed_source, node, @column_delta)
|
100
|
+
end
|
101
|
+
|
57
102
|
private
|
58
103
|
|
59
104
|
def brace_alignment_style
|
@@ -64,12 +109,13 @@ module RuboCop
|
|
64
109
|
return if ignored_node?(hash_node)
|
65
110
|
|
66
111
|
left_brace = hash_node.loc.begin
|
67
|
-
first_pair = hash_node.
|
112
|
+
first_pair = hash_node.pairs.first
|
113
|
+
|
68
114
|
if first_pair
|
69
115
|
return if first_pair.source_range.line == left_brace.line
|
70
116
|
|
71
117
|
if separator_style?(first_pair)
|
72
|
-
check_based_on_longest_key(hash_node
|
118
|
+
check_based_on_longest_key(hash_node, left_brace,
|
73
119
|
left_parenthesis)
|
74
120
|
else
|
75
121
|
check_first(first_pair, left_brace, left_parenthesis, 0)
|
@@ -96,20 +142,20 @@ module RuboCop
|
|
96
142
|
'Indent the right brace the same as the start of the line ' \
|
97
143
|
'where the left brace is.'
|
98
144
|
end
|
99
|
-
add_offense(right_brace, right_brace, msg)
|
145
|
+
add_offense(right_brace, location: right_brace, message: msg)
|
100
146
|
end
|
101
147
|
|
102
148
|
def separator_style?(first_pair)
|
103
149
|
separator = first_pair.loc.operator
|
104
150
|
key = "Enforced#{separator.is?(':') ? 'Colon' : 'HashRocket'}Style"
|
105
|
-
config.for_cop('
|
151
|
+
config.for_cop('Layout/AlignHash')[key] == 'separator'
|
106
152
|
end
|
107
153
|
|
108
|
-
def check_based_on_longest_key(
|
109
|
-
key_lengths =
|
110
|
-
|
154
|
+
def check_based_on_longest_key(hash_node, left_brace, left_parenthesis)
|
155
|
+
key_lengths = hash_node.keys.map do |key|
|
156
|
+
key.source_range.length
|
111
157
|
end
|
112
|
-
check_first(pairs.first, left_brace, left_parenthesis,
|
158
|
+
check_first(hash_node.pairs.first, left_brace, left_parenthesis,
|
113
159
|
key_lengths.max - key_lengths.first)
|
114
160
|
end
|
115
161
|
|
@@ -125,8 +171,11 @@ module RuboCop
|
|
125
171
|
end
|
126
172
|
|
127
173
|
def message(base_description)
|
128
|
-
format(
|
129
|
-
|
174
|
+
format(
|
175
|
+
MSG,
|
176
|
+
configured_indentation_width: configured_indentation_width,
|
177
|
+
base_description: base_description
|
178
|
+
)
|
130
179
|
end
|
131
180
|
end
|
132
181
|
end
|
@@ -0,0 +1,208 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module RuboCop
|
4
|
+
module Cop
|
5
|
+
module Layout
|
6
|
+
# This cops checks the indentation of the here document bodies. The bodies
|
7
|
+
# are indented one step.
|
8
|
+
# In Ruby 2.3 or newer, squiggly heredocs (`<<~`) should be used. If you
|
9
|
+
# use the older rubies, you should introduce some library to your project
|
10
|
+
# (e.g. ActiveSupport, Powerpack or Unindent).
|
11
|
+
# Note: When `Metrics/LineLength`'s `AllowHeredoc` is false(not default),
|
12
|
+
# this cop does not add any offenses for long here documents to
|
13
|
+
# avoid `Metrics/LineLength`'s offenses.
|
14
|
+
#
|
15
|
+
# @example
|
16
|
+
#
|
17
|
+
# # bad
|
18
|
+
# <<-RUBY
|
19
|
+
# something
|
20
|
+
# RUBY
|
21
|
+
#
|
22
|
+
# # good
|
23
|
+
# # When EnforcedStyle is squiggly, bad code is auto-corrected to the
|
24
|
+
# # following code.
|
25
|
+
# <<~RUBY
|
26
|
+
# something
|
27
|
+
# RUBY
|
28
|
+
#
|
29
|
+
# # good
|
30
|
+
# # When EnforcedStyle is active_support, bad code is auto-corrected to
|
31
|
+
# # the following code.
|
32
|
+
# <<-RUBY.strip_heredoc
|
33
|
+
# something
|
34
|
+
# RUBY
|
35
|
+
class IndentHeredoc < Cop
|
36
|
+
include Heredoc
|
37
|
+
include ConfigurableEnforcedStyle
|
38
|
+
include SafeMode
|
39
|
+
|
40
|
+
RUBY23_MSG = 'Use %<indentation_width>d spaces for indentation in a ' \
|
41
|
+
'heredoc by using `<<~` instead of ' \
|
42
|
+
'`%<current_indent_type>s`.'.freeze
|
43
|
+
LIBRARY_MSG = 'Use %<indentation_width>d spaces for indentation in a ' \
|
44
|
+
'heredoc by using %<method>s.'.freeze
|
45
|
+
STRIP_METHODS = {
|
46
|
+
unindent: 'unindent',
|
47
|
+
active_support: 'strip_heredoc',
|
48
|
+
powerpack: 'strip_indent'
|
49
|
+
}.freeze
|
50
|
+
|
51
|
+
def on_heredoc(node)
|
52
|
+
body = heredoc_body(node)
|
53
|
+
return if body =~ /\A\s*\z/
|
54
|
+
|
55
|
+
body_indent_level = indent_level(body)
|
56
|
+
|
57
|
+
if heredoc_indent_type(node) == '~'
|
58
|
+
expected_indent_level = base_indent_level(node) + indentation_width
|
59
|
+
return if expected_indent_level == body_indent_level
|
60
|
+
else
|
61
|
+
return unless body_indent_level.zero?
|
62
|
+
end
|
63
|
+
|
64
|
+
return if too_long_line?(node)
|
65
|
+
add_offense(node, location: :heredoc_body)
|
66
|
+
end
|
67
|
+
|
68
|
+
def autocorrect(node)
|
69
|
+
check_style!
|
70
|
+
|
71
|
+
case style
|
72
|
+
when :squiggly
|
73
|
+
correct_by_squiggly(node)
|
74
|
+
else
|
75
|
+
correct_by_library(node)
|
76
|
+
end
|
77
|
+
end
|
78
|
+
|
79
|
+
private
|
80
|
+
|
81
|
+
def style
|
82
|
+
style = super
|
83
|
+
return style unless style == :auto_detection
|
84
|
+
|
85
|
+
if target_ruby_version >= 2.3
|
86
|
+
:squiggly
|
87
|
+
elsif rails?
|
88
|
+
:active_support
|
89
|
+
end
|
90
|
+
end
|
91
|
+
|
92
|
+
def message(node)
|
93
|
+
case style
|
94
|
+
when :squiggly
|
95
|
+
current_indent_type = "<<#{heredoc_indent_type(node)}"
|
96
|
+
ruby23_message(indentation_width, current_indent_type)
|
97
|
+
when nil
|
98
|
+
method = "some library(e.g. ActiveSupport's `String#strip_heredoc`)"
|
99
|
+
library_message(indentation_width, method)
|
100
|
+
else
|
101
|
+
method = "`String##{STRIP_METHODS[style]}`"
|
102
|
+
library_message(indentation_width, method)
|
103
|
+
end
|
104
|
+
end
|
105
|
+
|
106
|
+
def library_message(indentation_width, method)
|
107
|
+
format(
|
108
|
+
LIBRARY_MSG,
|
109
|
+
indentation_width: indentation_width,
|
110
|
+
method: method
|
111
|
+
)
|
112
|
+
end
|
113
|
+
|
114
|
+
def ruby23_message(indentation_width, current_indent_type)
|
115
|
+
format(
|
116
|
+
RUBY23_MSG,
|
117
|
+
indentation_width: indentation_width,
|
118
|
+
current_indent_type: current_indent_type
|
119
|
+
)
|
120
|
+
end
|
121
|
+
|
122
|
+
def too_long_line?(node)
|
123
|
+
return false if config.for_cop('Metrics/LineLength')['AllowHeredoc']
|
124
|
+
body = heredoc_body(node)
|
125
|
+
|
126
|
+
expected_indent = base_indent_level(node) + indentation_width
|
127
|
+
actual_indent = indent_level(body)
|
128
|
+
increase_indent_level = expected_indent - actual_indent
|
129
|
+
|
130
|
+
max_line = body.each_line.map { |line| line.chomp.size }.max
|
131
|
+
|
132
|
+
max_line + increase_indent_level >= max_line_length
|
133
|
+
end
|
134
|
+
|
135
|
+
def max_line_length
|
136
|
+
config.for_cop('Metrics/LineLength')['Max']
|
137
|
+
end
|
138
|
+
|
139
|
+
def correct_by_squiggly(node)
|
140
|
+
return if target_ruby_version < 2.3
|
141
|
+
lambda do |corrector|
|
142
|
+
if heredoc_indent_type(node) == '~'
|
143
|
+
corrector.replace(node.loc.heredoc_body, indented_body(node))
|
144
|
+
else
|
145
|
+
heredoc_beginning = node.loc.expression.source
|
146
|
+
corrected = heredoc_beginning.sub(/<<-?/, '<<~')
|
147
|
+
corrector.replace(node.loc.expression, corrected)
|
148
|
+
end
|
149
|
+
end
|
150
|
+
end
|
151
|
+
|
152
|
+
def correct_by_library(node)
|
153
|
+
lambda do |corrector|
|
154
|
+
corrector.replace(node.loc.heredoc_body, indented_body(node))
|
155
|
+
corrected = ".#{STRIP_METHODS[style]}"
|
156
|
+
corrector.insert_after(node.loc.expression, corrected)
|
157
|
+
end
|
158
|
+
end
|
159
|
+
|
160
|
+
def check_style!
|
161
|
+
case style
|
162
|
+
when nil
|
163
|
+
raise Warning, "Auto-correction does not work for #{cop_name}. " \
|
164
|
+
'Please configure EnforcedStyle.'
|
165
|
+
when :squiggly
|
166
|
+
if target_ruby_version < 2.3
|
167
|
+
raise Warning, '`squiggly` style is selectable only on Ruby ' \
|
168
|
+
"2.3 or higher for #{cop_name}."
|
169
|
+
end
|
170
|
+
end
|
171
|
+
end
|
172
|
+
|
173
|
+
def indented_body(node)
|
174
|
+
body = heredoc_body(node)
|
175
|
+
body_indent_level = indent_level(body)
|
176
|
+
correct_indent_level = base_indent_level(node) + indentation_width
|
177
|
+
body.gsub(/^\s{#{body_indent_level}}/, ' ' * correct_indent_level)
|
178
|
+
end
|
179
|
+
|
180
|
+
def base_indent_level(node)
|
181
|
+
base_line_num = node.loc.expression.line
|
182
|
+
base_line = processed_source.lines[base_line_num - 1]
|
183
|
+
indent_level(base_line)
|
184
|
+
end
|
185
|
+
|
186
|
+
def indent_level(str)
|
187
|
+
indentations = str.lines
|
188
|
+
.map { |line| line[/^\s*/] }
|
189
|
+
.reject { |line| line == "\n" }
|
190
|
+
indentations.empty? ? 0 : indentations.min_by(&:size).size
|
191
|
+
end
|
192
|
+
|
193
|
+
# Returns '~', '-' or nil
|
194
|
+
def heredoc_indent_type(node)
|
195
|
+
node.source[/^<<([~-])/, 1]
|
196
|
+
end
|
197
|
+
|
198
|
+
def indentation_width
|
199
|
+
@config.for_cop('IndentationWidth')['Width'] || 2
|
200
|
+
end
|
201
|
+
|
202
|
+
def heredoc_body(node)
|
203
|
+
node.loc.heredoc_body.source.scrub
|
204
|
+
end
|
205
|
+
end
|
206
|
+
end
|
207
|
+
end
|
208
|
+
end
|