📄 classaccess.java
字号:
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(); isClassAccess_visited = -1; predNameType_visited = -1; type_visited = -1; type_computed = false; type_value = null; } @SuppressWarnings({"unchecked", "cast"}) public ClassAccess clone() throws CloneNotSupportedException { ClassAccess node = (ClassAccess)super.clone(); node.isClassAccess_visited = -1; node.predNameType_visited = -1; node.type_visited = -1; 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 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; } protected int isClassAccess_visited = -1; // Declared in ResolveAmbiguousNames.jrag at line 47 @SuppressWarnings({"unchecked", "cast"}) public boolean isClassAccess() { if(isClassAccess_visited == boundariesCrossed) throw new RuntimeException("Circular definition of attr: isClassAccess in class: "); isClassAccess_visited = boundariesCrossed; boolean isClassAccess_value = isClassAccess_compute(); isClassAccess_visited = -1; return isClassAccess_value; } private boolean isClassAccess_compute() { return true; } protected int predNameType_visited = -1; // Declared in SyntacticClassification.jrag at line 91 @SuppressWarnings({"unchecked", "cast"}) public NameType predNameType() { if(predNameType_visited == boundariesCrossed) throw new RuntimeException("Circular definition of attr: predNameType in class: "); predNameType_visited = boundariesCrossed; NameType predNameType_value = predNameType_compute(); predNameType_visited = -1; return predNameType_value; } private NameType predNameType_compute() { return NameType.TYPE_NAME; } protected int type_visited = -1; // Declared in TypeAnalysis.jrag at line 402 @SuppressWarnings({"unchecked", "cast"}) public TypeDecl type() { if(type_computed) return type_value; if(type_visited == boundariesCrossed) throw new RuntimeException("Circular definition of attr: type in class: "); type_visited = boundariesCrossed; int num = boundariesCrossed; boolean isFinal = this.is$Final(); type_value = type_compute(); if(isFinal && num == boundariesCrossed) type_computed = true; type_visited = -1; return type_value; } private TypeDecl type_compute() { return lookupType("java.lang", "Class"); }public ASTNode rewriteTo() { return super.rewriteTo();}}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -