classaccess.java

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

JAVA
159
字号

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 ClassAccess extends Access implements Cloneable {
    public void flushCache() {        super.flushCache();        type_computed = false;        type_value = null;    }     @SuppressWarnings({"unchecked", "cast"})  public ClassAccess clone() throws CloneNotSupportedException {        ClassAccess node = (ClassAccess)super.clone();        node.type_computed = false;        node.type_value = null;        node.in$Circle(false);        node.is$Final(false);    return node;    }     @SuppressWarnings({"unchecked", "cast"})  public ClassAccess copy() {      try {          ClassAccess node = (ClassAccess)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 ClassAccess fullCopy() {        ClassAccess res = (ClassAccess)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 NameCheck.jrag at line 172  public void nameCheck() {    if(isQualified() && !qualifier().isTypeAccess())      error("class literal may only contain type names");  }    // Declared in PrettyPrint.jadd at line 536  public void toString(StringBuffer s) {    s.append("class");  }    // Declared in CreateBCode.jrag at line 1545  public void createBCode(CodeGeneration gen) {    if(prevExpr().type().isPrimitiveType() || prevExpr().type().isVoid()) {      TypeDecl typeDecl = lookupType("java.lang", prevExpr().type().primitiveClassName());      SimpleSet c = typeDecl.memberFields("TYPE");      FieldDeclaration f = (FieldDeclaration)c.iterator().next();      f.emitLoadField(gen, typeDecl);    }    else {      FieldDeclaration f = hostType().topLevelType().createStaticClassField(prevExpr().type().referenceClassFieldName());      // add method to perform lookup as a side-effect      MethodDecl m = hostType().topLevelType().createStaticClassMethod();      int next_label = hostType().constantPool().newLabel();      int end_label = hostType().constantPool().newLabel();      f.emitLoadField(gen, hostType());      gen.emitBranchNonNull(next_label);            // emit string literal            StringLiteral.push(gen, prevExpr().type().jvmName());      m.emitInvokeMethod(gen, hostType());      gen.emitDup();      f.emitStoreField(gen, hostType());      gen.emitGoto(end_label);      gen.addLabel(next_label);      gen.changeStackDepth(-1);      f.emitLoadField(gen, hostType());      gen.addLabel(end_label);    }  }    // Declared in Transformations.jrag at line 159  // remote collection / demand driven creation of accessor  public void transformation() {    super.transformation();    // touch static class method before any accessors to make it first in method    if(isQualified() && qualifier().type().isReferenceType()) {      hostType().topLevelType().createStaticClassMethod();      FieldDeclaration f = hostType().topLevelType().createStaticClassField(prevExpr().type().referenceClassFieldName());    }      }    // Declared in java.ast at line 3    // Declared in java.ast line 36
    public ClassAccess() {        super();

    }    // Declared in java.ast at line 9
  protected int numChildren() {
    return 0;
  }    // Declared in java.ast at line 12
  public boolean mayHaveRewrite() { return false; }    // Declared in ResolveAmbiguousNames.jrag at line 47 @SuppressWarnings({"unchecked", "cast"})     public boolean isClassAccess() {        boolean isClassAccess_value = isClassAccess_compute();        return isClassAccess_value;    }    private boolean isClassAccess_compute() {  return true;  }    // Declared in SyntacticClassification.jrag at line 91 @SuppressWarnings({"unchecked", "cast"})     public NameType predNameType() {        NameType predNameType_value = predNameType_compute();        return predNameType_value;    }    private NameType predNameType_compute() {  return NameType.TYPE_NAME;  }    // Declared in TypeAnalysis.jrag at line 402 @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 lookupType("java.lang", "Class");  }public ASTNode rewriteTo() {    return super.rewriteTo();}}

⌨️ 快捷键说明

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