instanceofexpr.java

来自「JDK1.4编译器后端」· Java 代码 · 共 213 行

JAVA
213
字号

package AST;
import java.util.HashSet;import java.util.LinkedHashSet;import java.io.FileNotFoundException;import java.io.File;import java.util.*;import beaver.*;import java.util.ArrayList;import java.util.zip.*;import java.io.*;public class InstanceOfExpr extends Expr implements Cloneable {
    public void flushCache() {        super.flushCache();        type_computed = false;        type_value = null;    }     @SuppressWarnings({"unchecked", "cast"})  public InstanceOfExpr clone() throws CloneNotSupportedException {        InstanceOfExpr node = (InstanceOfExpr)super.clone();        node.type_computed = false;        node.type_value = null;        node.in$Circle(false);        node.is$Final(false);    return node;    }     @SuppressWarnings({"unchecked", "cast"})  public InstanceOfExpr copy() {      try {          InstanceOfExpr node = (InstanceOfExpr)clone();          if(children != null) node.children = (ASTNode[])children.clone();          return node;      } catch (CloneNotSupportedException e) {      }      System.err.println("Error: Could not clone node of type " + getClass().getName() + "!");      return null;    }     @SuppressWarnings({"unchecked", "cast"})  public InstanceOfExpr fullCopy() {        InstanceOfExpr res = (InstanceOfExpr)copy();        for(int i = 0; i < getNumChildNoTransform(); i++) {          ASTNode node = getChildNoTransform(i);          if(node != null) node = node.fullCopy();          res.setChild(node, i);        }        return res;    }    // Declared in PrettyPrint.jadd at line 437  public void toString(StringBuffer s) {    getExpr().toString(s);    s.append(" instanceof ");    getTypeAccess().toString(s);  }    // Declared in TypeCheck.jrag at line 235  // 15.20.2  public void typeCheck() {    TypeDecl relationalExpr = getExpr().type();    TypeDecl referenceType = getTypeAccess().type();    if(!relationalExpr.isUnknown()) {      if(!relationalExpr.isReferenceType() && !relationalExpr.isNull())        error("The relational expression in instance of must be reference or null type");      if(!referenceType.isReferenceType())        error("The reference expression in instance of must be reference type");      if(!relationalExpr.castingConversionTo(referenceType))        error("The type " + relationalExpr.typeName() + " of the relational expression " +           getExpr() +  " can not be cast into the type " + referenceType.typeName());      if(getExpr().isTypeAccess())        error("The relational expression " + getExpr() + " must not be a type name");    }  }    // Declared in CreateBCode.jrag at line 1149  public void createBCode(CodeGeneration gen) {    getExpr().createBCode(gen);    gen.emitInstanceof(getTypeAccess().type());  }    // Declared in java.ast at line 3    // Declared in java.ast line 188
    public InstanceOfExpr() {        super();

    }    // Declared in java.ast at line 10
    // Declared in java.ast line 188    public InstanceOfExpr(Expr p0, Access p1) {        setChild(p0, 0);        setChild(p1, 1);    }    // Declared in java.ast at line 15  protected int numChildren() {
    return 2;
  }    // Declared in java.ast at line 18
  public boolean mayHaveRewrite() { return false; }    // Declared in java.ast at line 2    // Declared in java.ast line 188    public void setExpr(Expr node) {        setChild(node, 0);    }    // Declared in java.ast at line 5    public Expr getExpr() {        return (Expr)getChild(0);    }    // Declared in java.ast at line 9    public Expr getExprNoTransform() {        return (Expr)getChildNoTransform(0);    }    // Declared in java.ast at line 2    // Declared in java.ast line 188    public void setTypeAccess(Access node) {        setChild(node, 1);    }    // Declared in java.ast at line 5    public Access getTypeAccess() {        return (Access)getChild(1);    }    // Declared in java.ast at line 9    public Access getTypeAccessNoTransform() {        return (Access)getChildNoTransform(1);    }    // Declared in ConstantExpression.jrag at line 476 @SuppressWarnings({"unchecked", "cast"})     public boolean isConstant() {        boolean isConstant_value = isConstant_compute();        return isConstant_value;    }    private boolean isConstant_compute() {  return false;  }    // Declared in DefiniteAssignment.jrag at line 347 @SuppressWarnings({"unchecked", "cast"})     public boolean isDAafterFalse(Variable v) {        boolean isDAafterFalse_Variable_value = isDAafterFalse_compute(v);        return isDAafterFalse_Variable_value;    }    private boolean isDAafterFalse_compute(Variable v) {  return isDAafter(v);  }    // Declared in DefiniteAssignment.jrag at line 348 @SuppressWarnings({"unchecked", "cast"})     public boolean isDAafterTrue(Variable v) {        boolean isDAafterTrue_Variable_value = isDAafterTrue_compute(v);        return isDAafterTrue_Variable_value;    }    private boolean isDAafterTrue_compute(Variable v) {  return isDAafter(v);  }    // Declared in DefiniteAssignment.jrag at line 411 @SuppressWarnings({"unchecked", "cast"})     public boolean isDAafter(Variable v) {        boolean isDAafter_Variable_value = isDAafter_compute(v);        return isDAafter_Variable_value;    }    private boolean isDAafter_compute(Variable v) {  return getExpr().isDAafter(v);  }    // Declared in DefiniteAssignment.jrag at line 852 @SuppressWarnings({"unchecked", "cast"})     public boolean isDUafter(Variable v) {        boolean isDUafter_Variable_value = isDUafter_compute(v);        return isDUafter_Variable_value;    }    private boolean isDUafter_compute(Variable v) {  return getExpr().isDUafter(v);  }    protected boolean type_computed = false;    protected TypeDecl type_value;    // Declared in TypeAnalysis.jrag at line 362 @SuppressWarnings({"unchecked", "cast"})     public TypeDecl type() {        if(type_computed)            return type_value;        int num = boundariesCrossed;        boolean isFinal = this.is$Final();        type_value = type_compute();        if(isFinal && num == boundariesCrossed)            type_computed = true;        return type_value;    }    private TypeDecl type_compute() {  return typeBoolean();  }    // Declared in SyntacticClassification.jrag at line 89    public NameType Define_NameType_nameType(ASTNode caller, ASTNode child) {        if(caller == getTypeAccessNoTransform()) {            return NameType.TYPE_NAME;        }        return getParent().Define_NameType_nameType(this, caller);    }public ASTNode rewriteTo() {    return super.rewriteTo();}}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?