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
pair
nodes which also appear ashash
elements. -
#hash_rocket? ⇒ false
readonly
This is used for duck typing with
pair
nodes which also appear ashash
elements. -
#kwsplat_type? ⇒ true
readonly
This provides
forwarded_kwrestarg
node to return true to be compatible withkwsplat
node.
Node
- Inherited
#any_block_type?, #any_def_type?, #any_match_pattern_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
kwsplat
as 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