#include <ast.h>
Inheritance diagram for ternaryNode::
Public Methods | |
ternaryNode (exprNode *cond, exprNode *true_br, exprNode *false_br, const Coord qmark_coord=Coord::Unknown, const Coord colon_coord=Coord::Unknown) | |
Create a new ternary expression. More... | |
virtual | ~ternaryNode () |
Destroy a ternaryNode. More... | |
virtual void | eval () |
Constant expression evaluator. More... | |
virtual void | dataflow (FlowVal *v, FlowProblem &fp) |
Run the dataflow analyzer. More... | |
virtual Node * | clone () const |
Clone the input node. More... | |
virtual void | output_expr (output_context &ct, Node *par, int prec, Assoc assoc) |
Output a expression. More... | |
virtual int | precedence (Assoc &assoc) |
Associativity and precedence. More... | |
Accessors | |
Methods to get and set fields in the class. | |
exprNode * | cond () const |
exprNode * | get_cond () |
void | cond (exprNode *cond) |
exprNode * | true_br () const |
exprNode * | get_true_br () |
void | true_br (exprNode *true_br) |
exprNode * | false_br () const |
exprNode * | get_false_br () |
void | false_br (exprNode *false_br) |
AST Traversal | |
virtual void | visit (Visitor *the_visitor) |
Dispatch a Visitor. More... | |
virtual void | walk (Walker &the_walker) |
Dispatch a Walker. More... | |
virtual Node * | change (Changer &the_changer, bool redispatch=false) |
Dispatch a Changer. More... | |
Private Attributes | |
TREE exprNode * | _cond |
the ternary condition expression. More... | |
TREE exprNode * | _true_br |
the true branch expression. More... | |
TREE exprNode * | _false_br |
the false branch expression. More... | |
Coord | _colon_coord |
the location of the colon in the source code. More... |
This class represents the ternary operator ( expr ? expr : expr ).
The NodeType is Ternary.
|
Create a new ternary expression. The new ternary expression has the given condition, true and false expressions.
|
|
Destroy a ternaryNode.
|
|
Dispatch a Changer. This abstract method works much the walker, but allows the tree to be changed.
Reimplemented from Node. |
|
Clone the input node. This is not a "deep" clone, so be careful. For a deep clone, use the clone_changer class.
Reimplemented from Node. |
|
|
|
|
|
Run the dataflow analyzer. Each subclass overrides this method to define it's semantics for dataflow analysis. It alters the input flow value to reflect the effect of the node within the given flow problem, calling dataflow() on it's subtrees as necessary. See the dataflow analysis documentation for more information.
Reimplemented from Node. |
|
Constant expression evaluator. This method attempts to evaluate an expression at compile-time. This only yields a meaningful value when the leaves of the given expression are constants, enums, or other compile-time values (e.g., sizeof). The resulting value is stored on each exprNode, in the _value field. Each exprNode sublcass implements this method, calling it recursively when necessary. Reimplemented from exprNode. |
|
|
|
|
|
|
|
|
|
|
|
Output a expression.
Reimplemented from exprNode. |
|
Associativity and precedence. Determine the associativity and precedence of the expression. Each exprNode subclass overrides this method to provide the specific results. The default is highest precedence and left-associative.
Reimplemented from exprNode. |
|
|
|
|
|
Dispatch a Visitor. This abstract method is the entry point for the visitor design pattern. Each node subclass defines a visit() method that calls the appropriate at_ method in the visitor. For more information see the Visitor documentation.
Reimplemented from Node. |
|
Dispatch a Walker. This abstract method works much like the visitor, but instead walks the entire underlying subtree calling the appropriate at_ method at each node. For more information see the Walker documentation.
Reimplemented from Node. |
|
the location of the colon in the source code.
|
|
the ternary condition expression.
|
|
the false branch expression.
|
|
the true branch expression.
|