OpenVDB
12.0.0
|
Expressions are comprised of full or potentially partial parts of a full statement that may not necessary make up an entire valid statement on their own. For example, while a Binary Operator such as "3 + 5;"" is a valid statement on its own, the full statement "3 + 5 + 6;" must be broken down into two expressions which together form the statement as well as determining precedence. More...
#include <openvdb_ax/ast/AST.h>
Inherits Statement.
Inherited by ArrayPack, ArrayUnpack, AssignExpression, BinaryOperator, Cast, CommaOperator, Crement, FunctionCall, TernaryOperator, UnaryOperator, ValueBase, and Variable.
Public Types | |
using | UniquePtr = std::unique_ptr< Expression > |
enum | NodeType { TreeNode, StatementListNode, BlockNode, ConditionalStatementNode, CommaOperatorNode, LoopNode, KeywordNode, AssignExpressionNode, CrementNode, UnaryOperatorNode, BinaryOperatorNode, TernaryOperatorNode, CastNode, AttributeNode, FunctionCallNode, ExternalVariableNode, DeclareLocalNode, ArrayPackNode, ArrayUnpackNode, LocalNode, ValueBoolNode, ValueInt16Node, ValueInt32Node, ValueInt64Node, ValueFloatNode, ValueDoubleNode, ValueStrNode } |
An enumerated list of node types for all concrete node types. These can be used for faster evaluation of a given concrete node using the virtual function table via Node::nodetype() rather than performing a dynamic_cast/calling Node::isType. More... | |
using | Ptr = std::shared_ptr< Node > |
Public Member Functions | |
~Expression () override=default | |
virtual Expression * | copy () const override=0 |
The deep copy method for a Node. More... | |
const Statement * | basetype () const override |
Virtual method for accessing a node's base class. Note that if this is called explicitly on an instance of ast::Node (the top most base class) a nullptr is returned. This is primarily used by the Visitor to support hierarchical visits. More... | |
Name/Type | |
virtual NodeType | nodetype () const =0 |
Virtual method for accessing node type information. More... | |
virtual const char * | nodename () const =0 |
Virtual method for accessing node name information. More... | |
virtual const char * | subname () const =0 |
Virtual method for accessing node name information. More... | |
template<typename NodeT > | |
bool | isType () const |
Query whether or not this node is of a specific (derived) type. This method should be used to check if a node is of a particular abstract type. When checking concrete types, it's generally more efficient to check the return value of Node::nodetype() More... | |
Child Queries | |
virtual size_t | children () const =0 |
Virtual method for accessing child information. Returns the number of children a given AST node owns. More... | |
virtual const Node * | child (const size_t index) const =0 |
Virtual method for accessing child information. Returns a const pointer to a child node at the given index. If the index is out of range, a nullptr is returned. More... | |
int64_t | childidx () const |
Returns the child index of this node in relation to its parent, or -1 if no valid index is found (usually representing the top most node (i.e. Tree) More... | |
Replacement | |
bool | replace (Node *node) |
In place replacement. Attempts to replace this node at its specific location within its Abstract Syntax Tree. On a successful replacement, this node is destroyed, the provided node is inserted in its place and ownership is transferred to the parent node. No further calls to this node can be made on successful replacements. More... | |
virtual bool | replacechild (const size_t index, Node *node) |
Virtual method that attempted to replace a child at a given index with a provided node type. More... | |
Parent | |
const Node * | parent () const |
Access a const pointer to this nodes parent. More... | |
void | setParent (Node *parent) |
Set this node's parent. This is used during construction of an AST and should not be used. More... | |
Expressions are comprised of full or potentially partial parts of a full statement that may not necessary make up an entire valid statement on their own. For example, while a Binary Operator such as "3 + 5;"" is a valid statement on its own, the full statement "3 + 5 + 6;" must be broken down into two expressions which together form the statement as well as determining precedence.
using UniquePtr = std::unique_ptr<Expression> |
|
inherited |
An enumerated list of node types for all concrete node types. These can be used for faster evaluation of a given concrete node using the virtual function table via Node::nodetype() rather than performing a dynamic_cast/calling Node::isType.
|
overridedefault |
|
inlineoverridevirtual |
Virtual method for accessing a node's base class. Note that if this is called explicitly on an instance of ast::Node (the top most base class) a nullptr is returned. This is primarily used by the Visitor to support hierarchical visits.
Reimplemented from Statement.
Reimplemented in Value< std::string >, Value< T >, Local, ExternalVariable, Attribute, ArrayPack, ArrayUnpack, FunctionCall, Cast, UnaryOperator, Crement, AssignExpression, TernaryOperator, BinaryOperator, CommaOperator, ValueBase, and Variable.
|
pure virtualinherited |
Virtual method for accessing child information. Returns a const pointer to a child node at the given index. If the index is out of range, a nullptr is returned.
index | The child index to query |
Implemented in DeclareLocal, ArrayPack, ArrayUnpack, Keyword, FunctionCall, Cast, UnaryOperator, Crement, AssignExpression, TernaryOperator, BinaryOperator, ConditionalStatement, Loop, CommaOperator, Tree, Block, StatementList, ValueBase, and Variable.
|
inlineinherited |
Returns the child index of this node in relation to its parent, or -1 if no valid index is found (usually representing the top most node (i.e. Tree)
|
pure virtualinherited |
Virtual method for accessing child information. Returns the number of children a given AST node owns.
Implemented in DeclareLocal, ArrayPack, ArrayUnpack, Keyword, FunctionCall, Cast, UnaryOperator, Crement, AssignExpression, TernaryOperator, BinaryOperator, ConditionalStatement, Loop, CommaOperator, Tree, Block, StatementList, ValueBase, and Variable.
|
overridepure virtual |
The deep copy method for a Node.
Implements Statement.
Implemented in Value< std::string >, Value< T >, Local, ExternalVariable, Attribute, ArrayPack, ArrayUnpack, FunctionCall, Cast, UnaryOperator, Crement, AssignExpression, TernaryOperator, BinaryOperator, CommaOperator, ValueBase, and Variable.
|
inlineinherited |
Query whether or not this node is of a specific (derived) type. This method should be used to check if a node is of a particular abstract type. When checking concrete types, it's generally more efficient to check the return value of Node::nodetype()
NodeT | The node type to query against. |
|
pure virtualinherited |
Virtual method for accessing node name information.
Implemented in Value< std::string >, Value< T >, DeclareLocal, Local, ExternalVariable, Attribute, ArrayPack, ArrayUnpack, Keyword, FunctionCall, Cast, UnaryOperator, Crement, AssignExpression, TernaryOperator, BinaryOperator, ConditionalStatement, Loop, CommaOperator, Tree, Block, and StatementList.
|
pure virtualinherited |
Virtual method for accessing node type information.
Implemented in Value< std::string >, Value< T >, DeclareLocal, Local, ExternalVariable, Attribute, ArrayPack, ArrayUnpack, Keyword, FunctionCall, Cast, UnaryOperator, Crement, AssignExpression, TernaryOperator, BinaryOperator, ConditionalStatement, Loop, CommaOperator, Tree, Block, and StatementList.
|
inlineinherited |
Access a const pointer to this nodes parent.
|
inlineinherited |
In place replacement. Attempts to replace this node at its specific location within its Abstract Syntax Tree. On a successful replacement, this node is destroyed, the provided node is inserted in its place and ownership is transferred to the parent node. No further calls to this node can be made on successful replacements.
node | The node to insert on a successful replacement. |
|
inlinevirtualinherited |
Virtual method that attempted to replace a child at a given index with a provided node type.
index | The child index where a replacement should be attempted |
node | The node to insert on a successful replacement. |
Reimplemented in DeclareLocal, ArrayPack, ArrayUnpack, FunctionCall, Cast, UnaryOperator, Crement, AssignExpression, TernaryOperator, BinaryOperator, ConditionalStatement, Loop, CommaOperator, Block, and StatementList.
|
inlineinherited |
Set this node's parent. This is used during construction of an AST and should not be used.
parent | The parent to set |
|
pure virtualinherited |
Virtual method for accessing node name information.
Implemented in Value< std::string >, Value< T >, DeclareLocal, Local, ExternalVariable, Attribute, ArrayPack, ArrayUnpack, Keyword, FunctionCall, Cast, UnaryOperator, Crement, AssignExpression, TernaryOperator, BinaryOperator, ConditionalStatement, Loop, CommaOperator, Tree, Block, and StatementList.