|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object scale.common.Root scale.clef.Node scale.clef.expr.Expression scale.clef.expr.CallOp
public abstract class CallOp
A class which represents a generic routine call expression.
$Id: CallOp.java,v 1.44 2007-08-28 17:58:20 burrill Exp $
Copyright 2008 by the
Scale Compiler Group,
Department of Computer Science
University of Massachusetts,
Amherst MA. 01003, USA
All Rights Reserved.
The result type is specified via the constructor and should be the result of the procedure call.
Constructor Summary | |
---|---|
CallOp(Type returnType,
Expression routine,
Vector<Expression> argList)
|
Method Summary | |
---|---|
boolean |
containsDeclaration(Declaration decl)
Return true if this expression contains a reference to the variable. |
boolean |
equivalent(java.lang.Object exp)
Return true if the two expressions are equivalent. |
Expression |
getArg(int i)
Return the i -th argument to the call. |
Node |
getChild(int i)
Return the specified AST child of this node. |
void |
getDeclList(java.util.AbstractCollection<Declaration> varList)
Add all declarations referenced in this expression to the collection. |
int |
getNumArgs()
Return the number of arguments to the call. |
ProcedureType |
getProcedureInfo()
Return the procedure type node of the callee. |
Expression |
getRoutine()
Return the expression that specifies what is called. |
boolean |
isSimpleOp()
Return true if compilation of this expression will not result in the generation of a CFG node . |
int |
numChildren()
Return the number of AST children of this node. |
void |
setArg(Expression arg,
int i)
set the i -th argument to the call. |
protected void |
setArgList(Vector<Expression> argList)
Specify the arguments of the call. |
protected void |
setRoutine(Expression routine)
Specify the expression that specifies what is called. |
void |
visit(Predicate p)
Process a node by calling its associated routine. |
Methods inherited from class scale.clef.expr.Expression |
---|
canonical, getConstantValue, getCoreType, getDisplayColorHint, getDisplayLabel, getDisplayShapeHint, getPointedToCore, getType, hasTrueFalseResult, setType, toStringSpecial |
Methods inherited from class scale.clef.Node |
---|
getDecl, getSourceLineNumber, setAnnotationLevel, setReportLevel, setSourceLineNumber, toString, toString, toStringChildren |
Methods inherited from class scale.common.Root |
---|
addAnnotation, allAnnotations, allMatchingAnnotations, getAnnotation, getDisplayName, getDisplayString, getNodeCount, getNodeID, hasAnnotation, hasEqualAnnotation, hashCode, removeAnnotation, removeAnnotations, toStringAnnotations, toStringClass, trace, trace, trace |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, notify, notifyAll, wait, wait, wait |
Constructor Detail |
---|
public CallOp(Type returnType, Expression routine, Vector<Expression> argList)
Method Detail |
---|
public boolean equivalent(java.lang.Object exp)
equivalent
in class Expression
public void visit(Predicate p)
Node
Each class has a visit(Predicate p)
method. For
example, in class ABC
:
public void visit(Predicate p) { p.visitABC(this); }and the class that implements
Predicate
has a method
public void visitABC(Node n) { ABC a = (ABC) n; ... }Thus, the class that implements
Predicate
can call
n.visit(this);where
n
is a Node
sub-class without
determining which specific sub-class n
is.
The visit pattern basically avoids implementing a large
switch
statement or defining different methods
in each class for some purpose.
visit
in class Expression
Predicate
public final Expression getRoutine()
public final Expression getArg(int i)
i
-th argument to the call.
public final void setArg(Expression arg, int i)
i
-th argument to the call.
public final int getNumArgs()
protected final void setRoutine(Expression routine)
protected final void setArgList(Vector<Expression> argList)
public final ProcedureType getProcedureInfo()
public Node getChild(int i)
getChild
in class Node
public int numChildren()
numChildren
in class Node
public boolean isSimpleOp()
Expression
CFG node
.
For example, (a && b)
may require a branch
to represent and
i++
requires a store
.
isSimpleOp
in class Expression
public boolean containsDeclaration(Declaration decl)
containsDeclaration
in class Expression
public void getDeclList(java.util.AbstractCollection<Declaration> varList)
Expression
getDeclList
in class Expression
|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |