#include <ast.h>
Inheritance diagram for forNode::
Public Methods | |
forNode (exprNode *init, exprNode *cond, exprNode *next, stmtNode *body, const Coord coord=Coord::Unknown) | |
Create a new for loop. More... | |
virtual | ~forNode () |
Destroy a forNode. 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. | |
exprNode * | init () const |
exprNode * | get_init () |
void | init (exprNode *init) |
exprNode * | next () const |
exprNode * | get_next () |
void | next (exprNode *next) |
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 * | _init |
the initial expression (or null, if there is none). More... | |
TREE exprNode * | _next |
the next expression (or null, if there is none). More... |
This class represents the for-loop statement (three expressions, plus the body). The condition expression still functions as the condition (the middle expression). It also adds two expressions, one for the initial condition (the first expression) and one for the "next" operation (the third expression). The decomposition looks like this:
for ( i = 0; i < N ; i++ ) { ...blah... }
The initial expression is "i = 0", the condition expression is "i < N" and the next expression is "i++". When any of these components are missing, the corresponding data members are null.
The NodeType is For.
|
Create a new for loop. The new for loop has the given expressions and body. To leave out any of the expressions, pass null.
|
|
Destroy a forNode.
|
|
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 initial expression (or null, if there is none).
|
|
the next expression (or null, if there is none).
|