#include <ast.h>
Inheritance diagram for ifNode::
Public Methods | |
ifNode (exprNode *expr, stmtNode *true_br, stmtNode *false_br, const Coord if_coord=Coord::Unknown, const Coord else_coord=Coord::Unknown) | |
Create a new if-else statement. More... | |
virtual | ~ifNode () |
Destroy a ifNode. 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_stmt (output_context &ct, Node *par) |
Output a statement. More... | |
Accessors | |
Methods to get and set fields in the class. | |
blockNode * | true_br () const |
blockNode * | get_true_br () |
void | true_br (blockNode *true_br) |
blockNode * | false_br () const |
blockNode * | get_false_br () |
void | false_br (blockNode *false_br) |
Coord | else_coord () const |
void | else_coord (const Coord the_coord) |
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 blockNode * | _false_br |
the false branch statement. More... | |
Coord | _else_coord |
the position of the "else" keyword in the source file. More... |
This class represents an "if" statement. The selection expression serves as the condition and the child statement inherited from selectionNode is the true branch. It adds a child statement for the false branch. The false branch may be null, indicating that the statement has no "else" branch.
The NodeType is If.
|
Create a new if-else statement. The new if-else statement has the given condition expression, and true and false branches. Pass null for the false branch to create an if without an else.
|
|
Destroy a ifNode.
|
|
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. |
|
|
|
|
|
|
|
|
|
|
|
|
|
Output a statement.
Reimplemented from stmtNode. |
|
|
|
|
|
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 position of the "else" keyword in the source file.
|
|
the false branch statement.
|