rubocop 0.83.0 → 0.84.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (138) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +2 -2
  3. data/config/default.yml +20 -3
  4. data/lib/rubocop.rb +6 -59
  5. data/lib/rubocop/ast_aliases.rb +8 -0
  6. data/lib/rubocop/cli/command/show_cops.rb +2 -6
  7. data/lib/rubocop/config.rb +1 -3
  8. data/lib/rubocop/config_loader.rb +3 -9
  9. data/lib/rubocop/config_loader_resolver.rb +2 -6
  10. data/lib/rubocop/cop/autocorrect_logic.rb +1 -2
  11. data/lib/rubocop/cop/corrector.rb +1 -3
  12. data/lib/rubocop/cop/correctors/alignment_corrector.rb +2 -6
  13. data/lib/rubocop/cop/correctors/parentheses_corrector.rb +1 -3
  14. data/lib/rubocop/cop/correctors/space_corrector.rb +1 -3
  15. data/lib/rubocop/cop/gemspec/ordered_dependencies.rb +1 -3
  16. data/lib/rubocop/cop/generator.rb +1 -1
  17. data/lib/rubocop/cop/ignored_node.rb +1 -3
  18. data/lib/rubocop/cop/layout/empty_lines_around_access_modifier.rb +2 -6
  19. data/lib/rubocop/cop/layout/empty_lines_around_attribute_accessor.rb +62 -4
  20. data/lib/rubocop/cop/layout/first_argument_indentation.rb +0 -2
  21. data/lib/rubocop/cop/layout/first_array_element_indentation.rb +1 -3
  22. data/lib/rubocop/cop/layout/first_method_argument_line_break.rb +1 -3
  23. data/lib/rubocop/cop/layout/heredoc_argument_closing_parenthesis.rb +2 -6
  24. data/lib/rubocop/cop/layout/indentation_width.rb +1 -3
  25. data/lib/rubocop/cop/layout/multiline_block_layout.rb +1 -3
  26. data/lib/rubocop/cop/layout/multiline_method_argument_line_breaks.rb +1 -3
  27. data/lib/rubocop/cop/layout/space_around_method_call_operator.rb +2 -6
  28. data/lib/rubocop/cop/layout/space_before_comment.rb +1 -3
  29. data/lib/rubocop/cop/layout/space_inside_array_literal_brackets.rb +1 -3
  30. data/lib/rubocop/cop/layout/space_inside_reference_brackets.rb +2 -6
  31. data/lib/rubocop/cop/lint/ambiguous_operator.rb +4 -2
  32. data/lib/rubocop/cop/lint/deprecated_open_ssl_constant.rb +133 -0
  33. data/lib/rubocop/cop/lint/erb_new_arguments.rb +2 -6
  34. data/lib/rubocop/cop/lint/parentheses_as_grouped_expression.rb +11 -3
  35. data/lib/rubocop/cop/lint/percent_string_array.rb +1 -3
  36. data/lib/rubocop/cop/lint/suppressed_exception.rb +12 -1
  37. data/lib/rubocop/cop/lint/syntax.rb +1 -3
  38. data/lib/rubocop/cop/lint/useless_access_modifier.rb +1 -3
  39. data/lib/rubocop/cop/migration/department_name.rb +5 -9
  40. data/lib/rubocop/cop/mixin/alignment.rb +1 -3
  41. data/lib/rubocop/cop/mixin/array_min_size.rb +2 -6
  42. data/lib/rubocop/cop/mixin/check_line_breakable.rb +4 -12
  43. data/lib/rubocop/cop/mixin/configurable_enforced_style.rb +1 -3
  44. data/lib/rubocop/cop/mixin/configurable_formatting.rb +1 -3
  45. data/lib/rubocop/cop/mixin/multiline_element_indentation.rb +1 -3
  46. data/lib/rubocop/cop/mixin/surrounding_space.rb +1 -3
  47. data/lib/rubocop/cop/mixin/trailing_comma.rb +1 -3
  48. data/lib/rubocop/cop/naming/file_name.rb +1 -3
  49. data/lib/rubocop/cop/registry.rb +2 -6
  50. data/lib/rubocop/cop/severity.rb +1 -3
  51. data/lib/rubocop/cop/style/and_or.rb +2 -2
  52. data/lib/rubocop/cop/style/attr.rb +1 -3
  53. data/lib/rubocop/cop/style/block_delimiters.rb +2 -8
  54. data/lib/rubocop/cop/style/conditional_assignment.rb +1 -3
  55. data/lib/rubocop/cop/style/double_negation.rb +41 -4
  56. data/lib/rubocop/cop/style/empty_literal.rb +1 -3
  57. data/lib/rubocop/cop/style/frozen_string_literal_comment.rb +2 -4
  58. data/lib/rubocop/cop/style/hash_syntax.rb +12 -5
  59. data/lib/rubocop/cop/style/method_call_with_args_parentheses/require_parentheses.rb +1 -3
  60. data/lib/rubocop/cop/style/method_call_without_args_parentheses.rb +1 -3
  61. data/lib/rubocop/cop/style/one_line_conditional.rb +2 -6
  62. data/lib/rubocop/cop/style/redundant_parentheses.rb +2 -6
  63. data/lib/rubocop/cop/style/safe_navigation.rb +2 -6
  64. data/lib/rubocop/cop/style/slicing_with_range.rb +1 -1
  65. data/lib/rubocop/cop/style/special_global_vars.rb +2 -6
  66. data/lib/rubocop/cop/style/ternary_parentheses.rb +1 -3
  67. data/lib/rubocop/cop/style/trailing_underscore_variable.rb +2 -6
  68. data/lib/rubocop/cop/variable_force.rb +3 -9
  69. data/lib/rubocop/cop/variable_force/branch.rb +2 -6
  70. data/lib/rubocop/cop/variable_force/variable.rb +2 -6
  71. data/lib/rubocop/ext/processed_source.rb +18 -0
  72. data/lib/rubocop/formatter/base_formatter.rb +0 -4
  73. data/lib/rubocop/formatter/disabled_config_formatter.rb +4 -12
  74. data/lib/rubocop/formatter/formatter_set.rb +1 -3
  75. data/lib/rubocop/options.rb +2 -8
  76. data/lib/rubocop/remote_config.rb +1 -3
  77. data/lib/rubocop/result_cache.rb +1 -3
  78. data/lib/rubocop/rspec/cop_helper.rb +1 -3
  79. data/lib/rubocop/rspec/expect_offense.rb +3 -9
  80. data/lib/rubocop/rspec/shared_contexts.rb +54 -16
  81. data/lib/rubocop/runner.rb +8 -10
  82. data/lib/rubocop/target_finder.rb +2 -6
  83. data/lib/rubocop/version.rb +5 -3
  84. metadata +19 -56
  85. data/lib/rubocop/ast/builder.rb +0 -85
  86. data/lib/rubocop/ast/node.rb +0 -637
  87. data/lib/rubocop/ast/node/alias_node.rb +0 -24
  88. data/lib/rubocop/ast/node/and_node.rb +0 -29
  89. data/lib/rubocop/ast/node/args_node.rb +0 -29
  90. data/lib/rubocop/ast/node/array_node.rb +0 -70
  91. data/lib/rubocop/ast/node/block_node.rb +0 -121
  92. data/lib/rubocop/ast/node/break_node.rb +0 -17
  93. data/lib/rubocop/ast/node/case_match_node.rb +0 -56
  94. data/lib/rubocop/ast/node/case_node.rb +0 -56
  95. data/lib/rubocop/ast/node/class_node.rb +0 -31
  96. data/lib/rubocop/ast/node/def_node.rb +0 -82
  97. data/lib/rubocop/ast/node/defined_node.rb +0 -17
  98. data/lib/rubocop/ast/node/ensure_node.rb +0 -17
  99. data/lib/rubocop/ast/node/float_node.rb +0 -12
  100. data/lib/rubocop/ast/node/for_node.rb +0 -53
  101. data/lib/rubocop/ast/node/forward_args_node.rb +0 -18
  102. data/lib/rubocop/ast/node/hash_node.rb +0 -109
  103. data/lib/rubocop/ast/node/if_node.rb +0 -175
  104. data/lib/rubocop/ast/node/int_node.rb +0 -12
  105. data/lib/rubocop/ast/node/keyword_splat_node.rb +0 -45
  106. data/lib/rubocop/ast/node/mixin/basic_literal_node.rb +0 -16
  107. data/lib/rubocop/ast/node/mixin/binary_operator_node.rb +0 -43
  108. data/lib/rubocop/ast/node/mixin/collection_node.rb +0 -15
  109. data/lib/rubocop/ast/node/mixin/conditional_node.rb +0 -45
  110. data/lib/rubocop/ast/node/mixin/hash_element_node.rb +0 -125
  111. data/lib/rubocop/ast/node/mixin/method_dispatch_node.rb +0 -269
  112. data/lib/rubocop/ast/node/mixin/method_identifier_predicates.rb +0 -114
  113. data/lib/rubocop/ast/node/mixin/modifier_node.rb +0 -17
  114. data/lib/rubocop/ast/node/mixin/numeric_node.rb +0 -21
  115. data/lib/rubocop/ast/node/mixin/parameterized_node.rb +0 -61
  116. data/lib/rubocop/ast/node/mixin/predicate_operator_node.rb +0 -35
  117. data/lib/rubocop/ast/node/module_node.rb +0 -24
  118. data/lib/rubocop/ast/node/or_node.rb +0 -29
  119. data/lib/rubocop/ast/node/pair_node.rb +0 -63
  120. data/lib/rubocop/ast/node/range_node.rb +0 -18
  121. data/lib/rubocop/ast/node/regexp_node.rb +0 -33
  122. data/lib/rubocop/ast/node/resbody_node.rb +0 -24
  123. data/lib/rubocop/ast/node/retry_node.rb +0 -17
  124. data/lib/rubocop/ast/node/return_node.rb +0 -24
  125. data/lib/rubocop/ast/node/self_class_node.rb +0 -24
  126. data/lib/rubocop/ast/node/send_node.rb +0 -17
  127. data/lib/rubocop/ast/node/str_node.rb +0 -16
  128. data/lib/rubocop/ast/node/super_node.rb +0 -21
  129. data/lib/rubocop/ast/node/symbol_node.rb +0 -12
  130. data/lib/rubocop/ast/node/until_node.rb +0 -35
  131. data/lib/rubocop/ast/node/when_node.rb +0 -53
  132. data/lib/rubocop/ast/node/while_node.rb +0 -35
  133. data/lib/rubocop/ast/node/yield_node.rb +0 -21
  134. data/lib/rubocop/ast/sexp.rb +0 -16
  135. data/lib/rubocop/ast/traversal.rb +0 -202
  136. data/lib/rubocop/node_pattern.rb +0 -887
  137. data/lib/rubocop/processed_source.rb +0 -213
  138. data/lib/rubocop/token.rb +0 -114
@@ -1,17 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module RuboCop
4
- module AST
5
- # A node extension for `retry` nodes. This will be used in place of a
6
- # plain node when the builder constructs the AST, making its methods
7
- # available to all `retry` nodes within RuboCop.
8
- class RetryNode < Node
9
- include MethodDispatchNode
10
- include ParameterizedNode
11
-
12
- def arguments
13
- []
14
- end
15
- end
16
- end
17
- end
@@ -1,24 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module RuboCop
4
- module AST
5
- # A node extension for `return` nodes. This will be used in place of a
6
- # plain node when the builder constructs the AST, making its methods
7
- # available to all `return` nodes within RuboCop.
8
- class ReturnNode < Node
9
- include MethodDispatchNode
10
- include ParameterizedNode
11
-
12
- # Returns the arguments of the `return`.
13
- #
14
- # @return [Array] The arguments of the `return`.
15
- def arguments
16
- if node_parts.one? && node_parts.first.begin_type?
17
- node_parts.first.children
18
- else
19
- node_parts
20
- end
21
- end
22
- end
23
- end
24
- end
@@ -1,24 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module RuboCop
4
- module AST
5
- # A node extension for `sclass` nodes. This will be used in place of a
6
- # plain node when the builder constructs the AST, making its methods
7
- # available to all `sclass` nodes within RuboCop.
8
- class SelfClassNode < Node
9
- # The identifer for this `sclass` node. (Always `self`.)
10
- #
11
- # @return [Node] the identifer of the class
12
- def identifier
13
- node_parts[0]
14
- end
15
-
16
- # The body of this `sclass` node.
17
- #
18
- # @return [Node, nil] the body of the class
19
- def body
20
- node_parts[1]
21
- end
22
- end
23
- end
24
- end
@@ -1,17 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module RuboCop
4
- module AST
5
- # A node extension for `send` 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 `send` nodes within RuboCop.
8
- class SendNode < Node
9
- include ParameterizedNode
10
- include MethodDispatchNode
11
-
12
- def_node_matcher :attribute_accessor?, <<~PATTERN
13
- (send nil? ${:attr_reader :attr_writer :attr_accessor :attr} $...)
14
- PATTERN
15
- end
16
- end
17
- end
@@ -1,16 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module RuboCop
4
- module AST
5
- # A node extension for `str`, `dstr`, and `xstr` nodes. This will be used
6
- # in place of a plain node when the builder constructs the AST, making
7
- # its methods available to all `str` nodes within RuboCop.
8
- class StrNode < Node
9
- include BasicLiteralNode
10
-
11
- def heredoc?
12
- loc.is_a?(Parser::Source::Map::Heredoc)
13
- end
14
- end
15
- end
16
- end
@@ -1,21 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module RuboCop
4
- module AST
5
- # A node extension for `super`- and `zsuper` nodes. This will be used in
6
- # place of a plain node when the builder constructs the AST, making its
7
- # methods available to all `super`- and `zsuper` nodes within RuboCop.
8
- class SuperNode < Node
9
- include ParameterizedNode
10
- include MethodDispatchNode
11
-
12
- # Custom destructuring method. This can be used to normalize
13
- # destructuring for different variations of the node.
14
- #
15
- # @return [Array] the different parts of the `super` node
16
- def node_parts
17
- [nil, :super, *to_a]
18
- end
19
- end
20
- end
21
- end
@@ -1,12 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module RuboCop
4
- module AST
5
- # A node extension for `sym` nodes. This will be used in place of a
6
- # plain node when the builder constructs the AST, making its methods
7
- # available to all `sym` nodes within RuboCop.
8
- class SymbolNode < Node
9
- include BasicLiteralNode
10
- end
11
- end
12
- end
@@ -1,35 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module RuboCop
4
- module AST
5
- # A node extension for `until` 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 `until` nodes within RuboCop.
8
- class UntilNode < Node
9
- include ConditionalNode
10
- include ModifierNode
11
-
12
- # Returns the keyword of the `until` statement as a string.
13
- #
14
- # @return [String] the keyword of the `until` statement
15
- def keyword
16
- 'until'
17
- end
18
-
19
- # Returns the inverse keyword of the `until` node as a string.
20
- # Returns `while` for `until` nodes and vice versa.
21
- #
22
- # @return [String] the inverse keyword of the `until` statement
23
- def inverse_keyword
24
- 'while'
25
- end
26
-
27
- # Checks whether the `until` node has a `do` keyword.
28
- #
29
- # @return [Boolean] whether the `until` node has a `do` keyword
30
- def do?
31
- loc.begin&.is?('do')
32
- end
33
- end
34
- end
35
- end
@@ -1,53 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module RuboCop
4
- module AST
5
- # A node extension for `when` 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 `when` nodes within RuboCop.
8
- class WhenNode < Node
9
- # Returns an array of all the conditions in the `when` branch.
10
- #
11
- # @return [Array<Node>] an array of condition nodes
12
- def conditions
13
- node_parts[0...-1]
14
- end
15
-
16
- # Calls the given block for each condition node in the `when` branch.
17
- # If no block is given, an `Enumerator` is returned.
18
- #
19
- # @return [self] if a block is given
20
- # @return [Enumerator] if no block is given
21
- def each_condition
22
- return conditions.to_enum(__method__) unless block_given?
23
-
24
- conditions.each do |condition|
25
- yield condition
26
- end
27
-
28
- self
29
- end
30
-
31
- # Returns the index of the `when` branch within the `case` statement.
32
- #
33
- # @return [Integer] the index of the `when` branch
34
- def branch_index
35
- parent.when_branches.index(self)
36
- end
37
-
38
- # Checks whether the `when` node has a `then` keyword.
39
- #
40
- # @return [Boolean] whether the `when` node has a `then` keyword
41
- def then?
42
- loc.begin&.is?('then')
43
- end
44
-
45
- # Returns the body of the `when` node.
46
- #
47
- # @return [Node, nil] the body of the `when` node
48
- def body
49
- node_parts[-1]
50
- end
51
- end
52
- end
53
- end
@@ -1,35 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module RuboCop
4
- module AST
5
- # A node extension for `while` 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 `while` nodes within RuboCop.
8
- class WhileNode < Node
9
- include ConditionalNode
10
- include ModifierNode
11
-
12
- # Returns the keyword of the `while` statement as a string.
13
- #
14
- # @return [String] the keyword of the `while` statement
15
- def keyword
16
- 'while'
17
- end
18
-
19
- # Returns the inverse keyword of the `while` node as a string.
20
- # Returns `until` for `while` nodes and vice versa.
21
- #
22
- # @return [String] the inverse keyword of the `while` statement
23
- def inverse_keyword
24
- 'until'
25
- end
26
-
27
- # Checks whether the `until` node has a `do` keyword.
28
- #
29
- # @return [Boolean] whether the `until` node has a `do` keyword
30
- def do?
31
- loc.begin&.is?('do')
32
- end
33
- end
34
- end
35
- end
@@ -1,21 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module RuboCop
4
- module AST
5
- # A node extension for `yield` 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 `yield` nodes within RuboCop.
8
- class YieldNode < Node
9
- include ParameterizedNode
10
- include MethodDispatchNode
11
-
12
- # Custom destructuring method. This can be used to normalize
13
- # destructuring for different variations of the node.
14
- #
15
- # @return [Array] the different parts of the `send` node
16
- def node_parts
17
- [nil, :yield, *to_a]
18
- end
19
- end
20
- end
21
- end
@@ -1,16 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module RuboCop
4
- module AST
5
- # This module provides a shorthand method to create a {Node} like
6
- # `Parser::AST::Sexp`.
7
- #
8
- # @see https://www.rubydoc.info/gems/ast/AST/Sexp
9
- module Sexp
10
- # Creates a {Node} with type `type` and children `children`.
11
- def s(type, *children)
12
- Node.new(type, children)
13
- end
14
- end
15
- end
16
- end
@@ -1,202 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- # rubocop:disable Metrics/ModuleLength
4
- module RuboCop
5
- module AST
6
- # Provides methods for traversing an AST.
7
- # Does not transform an AST; for that, use Parser::AST::Processor.
8
- # Override methods to perform custom processing. Remember to call `super`
9
- # if you want to recursively process descendant nodes.
10
- module Traversal
11
- def walk(node)
12
- return if node.nil?
13
-
14
- send(:"on_#{node.type}", node)
15
- nil
16
- end
17
-
18
- NO_CHILD_NODES = %i[true false nil int float complex
19
- rational str sym regopt self lvar
20
- ivar cvar gvar nth_ref back_ref cbase
21
- arg restarg blockarg shadowarg
22
- kwrestarg zsuper lambda redo retry
23
- forward_args forwarded_args
24
- match_var match_nil_pattern empty_else].freeze
25
- ONE_CHILD_NODE = %i[splat kwsplat block_pass not break next
26
- preexe postexe match_current_line defined?
27
- arg_expr pin match_rest if_guard unless_guard
28
- match_with_trailing_comma].freeze
29
- MANY_CHILD_NODES = %i[dstr dsym xstr regexp array hash pair
30
- mlhs masgn or_asgn and_asgn
31
- undef alias args super yield or and
32
- while_post until_post iflipflop eflipflop
33
- match_with_lvasgn begin kwbegin return
34
- in_match match_alt
35
- match_as array_pattern array_pattern_with_tail
36
- hash_pattern const_pattern].freeze
37
- SECOND_CHILD_ONLY = %i[lvasgn ivasgn cvasgn gvasgn optarg kwarg
38
- kwoptarg].freeze
39
-
40
- NO_CHILD_NODES.each do |type|
41
- module_eval("def on_#{type}(node); end", __FILE__, __LINE__)
42
- end
43
-
44
- ONE_CHILD_NODE.each do |type|
45
- module_eval(<<~RUBY, __FILE__, __LINE__ + 1)
46
- def on_#{type}(node)
47
- if (child = node.children[0])
48
- send(:"on_\#{child.type}", child)
49
- end
50
- end
51
- RUBY
52
- end
53
-
54
- MANY_CHILD_NODES.each do |type|
55
- module_eval(<<~RUBY, __FILE__, __LINE__ + 1)
56
- def on_#{type}(node)
57
- node.children.each { |child| send(:"on_\#{child.type}", child) }
58
- nil
59
- end
60
- RUBY
61
- end
62
-
63
- SECOND_CHILD_ONLY.each do |type|
64
- # Guard clause is for nodes nested within mlhs
65
- module_eval(<<~RUBY, __FILE__, __LINE__ + 1)
66
- def on_#{type}(node)
67
- if (child = node.children[1])
68
- send(:"on_\#{child.type}", child)
69
- end
70
- end
71
- RUBY
72
- end
73
-
74
- def on_const(node)
75
- return unless (child = node.children[0])
76
-
77
- send(:"on_#{child.type}", child)
78
- end
79
-
80
- def on_casgn(node)
81
- children = node.children
82
- if (child = children[0]) # always const???
83
- send(:"on_#{child.type}", child)
84
- end
85
- return unless (child = children[2])
86
-
87
- send(:"on_#{child.type}", child)
88
- end
89
-
90
- def on_class(node)
91
- children = node.children
92
- child = children[0] # always const???
93
- send(:"on_#{child.type}", child)
94
- if (child = children[1])
95
- send(:"on_#{child.type}", child)
96
- end
97
- return unless (child = children[2])
98
-
99
- send(:"on_#{child.type}", child)
100
- end
101
-
102
- def on_def(node)
103
- children = node.children
104
- on_args(children[1])
105
- return unless (child = children[2])
106
-
107
- send(:"on_#{child.type}", child)
108
- end
109
-
110
- def on_send(node)
111
- node.children.each_with_index do |child, i|
112
- next if i == 1
113
-
114
- send(:"on_#{child.type}", child) if child
115
- end
116
- nil
117
- end
118
-
119
- alias on_csend on_send
120
-
121
- def on_op_asgn(node)
122
- children = node.children
123
- child = children[0]
124
- send(:"on_#{child.type}", child)
125
- child = children[2]
126
- send(:"on_#{child.type}", child)
127
- end
128
-
129
- def on_defs(node)
130
- children = node.children
131
- child = children[0]
132
- send(:"on_#{child.type}", child)
133
- on_args(children[2])
134
- return unless (child = children[3])
135
-
136
- send(:"on_#{child.type}", child)
137
- end
138
-
139
- def on_if(node)
140
- children = node.children
141
- child = children[0]
142
- send(:"on_#{child.type}", child)
143
- if (child = children[1])
144
- send(:"on_#{child.type}", child)
145
- end
146
- return unless (child = children[2])
147
-
148
- send(:"on_#{child.type}", child)
149
- end
150
-
151
- def on_while(node)
152
- children = node.children
153
- child = children[0]
154
- send(:"on_#{child.type}", child)
155
- return unless (child = children[1])
156
-
157
- send(:"on_#{child.type}", child)
158
- end
159
-
160
- alias on_until on_while
161
- alias on_module on_while
162
- alias on_sclass on_while
163
-
164
- def on_block(node)
165
- children = node.children
166
- child = children[0]
167
- send(:"on_#{child.type}", child) # can be send, zsuper...
168
- on_args(children[1])
169
- return unless (child = children[2])
170
-
171
- send(:"on_#{child.type}", child)
172
- end
173
-
174
- def on_case(node)
175
- node.children.each do |child|
176
- send(:"on_#{child.type}", child) if child
177
- end
178
- nil
179
- end
180
-
181
- alias on_rescue on_case
182
- alias on_resbody on_case
183
- alias on_ensure on_case
184
- alias on_for on_case
185
- alias on_when on_case
186
- alias on_case_match on_case
187
- alias on_in_pattern on_case
188
- alias on_irange on_case
189
- alias on_erange on_case
190
-
191
- def on_numblock(node)
192
- children = node.children
193
- child = children[0]
194
- send(:"on_#{child.type}", child)
195
- return unless (child = children[2])
196
-
197
- send(:"on_#{child.type}", child)
198
- end
199
- end
200
- end
201
- end
202
- # rubocop:enable Metrics/ModuleLength