#include <ast.h>
Inheritance diagram for caseNode::
Public Methods | |
caseNode (exprNode *expr, stmtNode *stmt, switchNode *container, const Coord coord=Coord::Unknown) | |
Create a new case statement. More... | |
caseNode (exprNode *expr, stmtNode *stmt, const Coord coord=Coord::Unknown) | |
Create a new case statement without a switch. More... | |
virtual | ~caseNode () |
Destroy a caseNode. 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 * | expr () const |
exprNode * | get_expr () |
void | expr (exprNode *expr) |
switchNode * | container () const |
void | container (switchNode *container) |
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 * | _expr |
the label expression. More... | |
REF switchNode * | _container |
the containing switch statement. More... |
This class represents a case within a switch statement. Like the labelNode, it has a child statement. However, the label is an expression. The language requires the expression to be a compile-time constant expression, but there are currently no checks for this. In addition, this node keeps a reference to the enclosing switchNode.
The defaultNode has been folded into this class. If the case has no expression, then it is the default.
The NodeType is Case
|
Create a new case statement. The new statement has the given label expression, child statement and containing switch statement.
|
|
Create a new case statement without a switch. The new statement has the given label expression and child statement, but no explicit switchNode container. This is computed later using the set_container_walker.
|
|
Destroy a caseNode.
|
|
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 containing switch statement. Unless explicitly specified, this field is initially null. After parsing, these references are computed by calling the set_container_walker. |
|
the label expression. This should be a compile-time constant expression |