Class: RuboCop::AST::KeywordSplatNode
| Relationships & Source Files | |
| Super Chains via Extension / Inclusion / Inheritance | |
|
Class Chain:
self,
Node,
NodePattern::Macros,
Parser::AST::Node
|
|
|
Instance Chain:
|
|
| Inherits: |
RuboCop::AST::Node
|
| Defined in: | lib/rubocop/ast/node/keyword_splat_node.rb |
Overview
A node extension for kwsplat and forwarded_kwrestarg nodes. This will be used in
place of a plain node when the builder constructs the AST, making its methods available to
all kwsplat and forwarded_kwrestarg nodes within RuboCop.
Constant Summary
-
DOUBLE_SPLAT =
private
# File 'lib/rubocop/ast/node/keyword_splat_node.rb', line 11'**'
Node - Inherited
ASSIGNMENTS, BASIC_CONDITIONALS, BASIC_LITERALS, COMPARISON_OPERATORS, COMPOSITE_LITERALS, CONDITIONALS, EMPTY_CHILDREN, EMPTY_PROPERTIES, EQUALS_ASSIGNMENTS, FALSEY_LITERALS, GROUP_FOR_TYPE, IMMUTABLE_LITERALS, KEYWORDS, LITERALS, LITERAL_RECURSIVE_METHODS, LITERAL_RECURSIVE_TYPES, LOOP_TYPES, MUTABLE_LITERALS, OPERATOR_KEYWORDS, POST_CONDITION_LOOP_TYPES, REFERENCES, SHORTHAND_ASSIGNMENTS, SPECIAL_KEYWORDS, TRUTHY_LITERALS, VARIABLES
Class Method Summary
Node - Inherited
| .new, | |
| .def_recursive_literal_predicate | Define a |
NodePattern::Macros - Extended
| def_node_matcher | Define a method which applies a pattern to an AST node. |
| def_node_search | Define a method which recurses over the descendants of an AST node, checking whether any of them match the provided pattern. |
Instance Attribute Summary
-
#colon? ⇒ false
readonly
This is used for duck typing with
pairnodes which also appear ashashelements. -
#hash_rocket? ⇒ false
readonly
This is used for duck typing with
pairnodes which also appear ashashelements. -
#kwsplat_type? ⇒ true
readonly
This provides
forwarded_kwrestargnode to return true to be compatible withkwsplatnode.
Node - Inherited
| #any_block_type?, #any_def_type?, #any_match_pattern_type?, #any_str_type?, #any_sym_type?, #argument?, #argument_type?, #assignment?, #basic_conditional?, #basic_literal?, #boolean_type?, #call_type?, #chained?, #complete?, #conditional?, #empty_source?, #equals_asgn?, #falsey_literal?, #guard_clause?, #immutable_literal?, #keyword?, #literal?, | |||
| #loop_keyword? |
|
||
| #multiline? | Predicates. |
||
| #mutable_literal?, #numeric_type?, #operator_keyword?, | |||
| #parent | Returns the parent node, or |
||
| #parent?, #parenthesized_call?, #post_condition_loop?, | |||
| #pure? | Some expressions are evaluated for their value, some for their side effects, and some for both. |
||
| #range_type?, #reference?, #root?, | |||
| #send_type? | Most nodes are of 'send' type, so this method is defined separately to make this check as fast as possible. |
||
| #shorthand_asgn?, #single_line?, #special_keyword?, #truthy_literal?, | |||
| #value_used? | Some expressions are evaluated for their value, some for their side effects, and some for both If we know that an expression is useful only for its side effects, that means we can transform it in ways which preserve the side effects, but change the return value So, does the return value of this node matter? If we changed it to |
||
| #variable?, #begin_value_used?, #case_if_value_used?, #for_value_used?, #while_until_value_used? | |||
Instance Method Summary
-
#node_parts ⇒ Array<KeywordSplatNode>
Custom destructuring method.
-
#operator ⇒ String
Returns the operator for the
kwsplatas a string.
HashElementNode - Included
| #delimiter_delta | Returns the delta between this element’s delimiter and the argument’s. |
| #key | Returns the key of this |
| #key_delta | Returns the delta between this pair’s key and the argument pair’s. |
| #same_line? | Checks whether this |
| #value | Returns the value of this |
| #value_delta | Returns the delta between this element’s value and the argument’s. |
Node - Inherited
| #ancestors | Returns an array of ancestor nodes. |
||
| #assignment_or_similar? | Some cops treat the shovel operator as a kind of assignment. |
||
| #class_constructor?, #class_definition?, #complete!, #const_name, #defined_module, #defined_module_name, | |||
| #each_ancestor | Calls the given block for each ancestor node from parent to root. |
||
| #first_line, #global_const?, #lambda?, #lambda_or_proc?, #last_line, | |||
| #left_sibling | Use is discouraged, this is a potentially slow method and can lead to even slower algorithms. |
||
| #left_siblings | Use is discouraged, this is a potentially slow method and can lead to even slower algorithms. |
||
| #line_count, | |||
| #loc? | Shortcut to safely check if a location is present. |
||
| #loc_is? | Shortcut to safely test a particular location, even if this location does not exist or is |
||
| #match_guard_clause?, #module_definition?, | |||
| #node_parts | Common destructuring method. |
||
| #nonempty_line_count, | |||
| #parent_module_name | Searching the AST. |
||
| #proc?, #receiver, #recursive_basic_literal?, #recursive_literal?, | |||
| #right_sibling | Use is discouraged, this is a potentially slow method and can lead to even slower algorithms. |
||
| #right_siblings | Use is discouraged, this is a potentially slow method and can lead to even slower algorithms. |
||
| #sibling_index | Returns the index of the receiver node in its siblings. |
||
| #source |
|
||
| #source_length, #source_range, #str_content, #struct_constructor?, | |||
| #type? | Determine if the node is one of several node types in a single query Allows specific single node types, as well as "grouped" types (e.g. |
||
| #updated | Override Node#updated so that |
||
| #defined_module0, #new_class_or_module_block?, #parent_module_name_for_block, #parent_module_name_for_sclass, #parent_module_name_part, #visit_ancestors | |||
Descendence - Included
| #child_nodes | Returns an array of child nodes. |
| #descendants | Returns an array of descendant nodes. |
| #each_child_node | Calls the given block for each child node. |
| #each_descendant | Calls the given block for each descendant node with depth first order. |
| #each_node | Calls the given block for the receiver and each descendant node in depth-first order. |
Sexp - Included
Constructor Details
This class inherits a constructor from RuboCop::AST::Node
Instance Attribute Details
#colon? ⇒ false (readonly)
This is used for duck typing with pair nodes which also appear as
hash elements.
# File 'lib/rubocop/ast/node/keyword_splat_node.rb', line 26
def colon? false end
#hash_rocket? ⇒ false (readonly)
This is used for duck typing with pair nodes which also appear as
hash elements.
# File 'lib/rubocop/ast/node/keyword_splat_node.rb', line 18
def hash_rocket? false end
#kwsplat_type? ⇒ true (readonly)
This provides forwarded_kwrestarg node to return true to be compatible with kwsplat node.
# File 'lib/rubocop/ast/node/keyword_splat_node.rb', line 48
def kwsplat_type? true end
Instance Method Details
#node_parts ⇒ Array<KeywordSplatNode>
Custom destructuring method. This is used to normalize the branches
for pair and kwsplat nodes, to add duck typing to hash elements.
# File 'lib/rubocop/ast/node/keyword_splat_node.rb', line 41
def node_parts [self, self] end
#operator ⇒ String
Returns the operator for the kwsplat as a string.
# File 'lib/rubocop/ast/node/keyword_splat_node.rb', line 33
def operator DOUBLE_SPLAT end