methodaccess.java

来自「JDK1.4编译器后端」· Java 代码 · 共 808 行 · 第 1/2 页

JAVA
808
字号
    }    // Declared in java.ast at line 2    // Declared in java.ast line 17    public void setArgList(List<Expr> list) {        setChild(list, 0);    }    // Declared in java.ast at line 6    private int getNumArg = 0;    // Declared in java.ast at line 7    public int getNumArg() {        return getArgList().getNumChild();    }    // Declared in java.ast at line 11     @SuppressWarnings({"unchecked", "cast"})  public Expr getArg(int i) {        return (Expr)getArgList().getChild(i);    }    // Declared in java.ast at line 15    public void addArg(Expr node) {        List<Expr> list = getArgList();        list.addChild(node);    }    // Declared in java.ast at line 20    public void setArg(Expr node, int i) {        List<Expr> list = getArgList();        list.setChild(node, i);    }    // Declared in java.ast at line 24    public List<Expr> getArgs() {        return getArgList();    }    // Declared in java.ast at line 27    public List<Expr> getArgsNoTransform() {        return getArgListNoTransform();    }    // Declared in java.ast at line 31     @SuppressWarnings({"unchecked", "cast"})  public List<Expr> getArgList() {        return (List<Expr>)getChild(0);    }    // Declared in java.ast at line 35     @SuppressWarnings({"unchecked", "cast"})  public List<Expr> getArgListNoTransform() {        return (List<Expr>)getChildNoTransform(0);    }    protected java.util.Map computeDAbefore_int_Variable_values;    // Declared in DefiniteAssignment.jrag at line 414 @SuppressWarnings({"unchecked", "cast"})     public boolean computeDAbefore(int i, Variable v) {        java.util.List _parameters = new java.util.ArrayList(2);        _parameters.add(new Integer(i));        _parameters.add(v);if(computeDAbefore_int_Variable_values == null) computeDAbefore_int_Variable_values = new java.util.HashMap(4);        if(computeDAbefore_int_Variable_values.containsKey(_parameters))            return ((Boolean)computeDAbefore_int_Variable_values.get(_parameters)).booleanValue();        int num = boundariesCrossed;        boolean isFinal = this.is$Final();        boolean computeDAbefore_int_Variable_value = computeDAbefore_compute(i, v);        if(isFinal && num == boundariesCrossed)            computeDAbefore_int_Variable_values.put(_parameters, Boolean.valueOf(computeDAbefore_int_Variable_value));        return computeDAbefore_int_Variable_value;    }    private boolean computeDAbefore_compute(int i, Variable v) {  return i == 0 ? isDAbefore(v) : getArg(i-1).isDAafter(v);  }    // Declared in DefiniteAssignment.jrag at line 416 @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 getNumArg() == 0 ? isDAbefore(v) : getArg(getNumArg()-1).isDAafter(v);  }    protected boolean exceptionCollection_computed = false;    protected Collection exceptionCollection_value;    // Declared in ExceptionHandling.jrag at line 51 @SuppressWarnings({"unchecked", "cast"})     public Collection exceptionCollection() {        if(exceptionCollection_computed)            return exceptionCollection_value;        int num = boundariesCrossed;        boolean isFinal = this.is$Final();        exceptionCollection_value = exceptionCollection_compute();        if(isFinal && num == boundariesCrossed)            exceptionCollection_computed = true;        return exceptionCollection_value;    }    private Collection exceptionCollection_compute() {    //System.out.println("Computing exceptionCollection for " + name());    HashSet set = new HashSet();    Iterator iter = decls().iterator();    if(!iter.hasNext())      return set;    MethodDecl m = (MethodDecl)iter.next();    //System.out.println("Processing first found method " + m.signature() + " in " + m.hostType().fullName());    for(int i = 0; i < m.getNumException(); i++) {      TypeDecl exceptionType = m.getException(i).type();      set.add(exceptionType);    }    while(iter.hasNext()) {      HashSet first = new HashSet();      first.addAll(set);      HashSet second = new HashSet();      m = (MethodDecl)iter.next();      //System.out.println("Processing the next method " + m.signature() + " in " + m.hostType().fullName());      for(int i = 0; i < m.getNumException(); i++) {        TypeDecl exceptionType = m.getException(i).type();        second.add(exceptionType);      }      set = new HashSet();      for(Iterator i1 = first.iterator(); i1.hasNext(); ) {        TypeDecl firstType = (TypeDecl)i1.next();         for(Iterator i2 = second.iterator(); i2.hasNext(); ) {          TypeDecl secondType = (TypeDecl)i2.next();          if(firstType.instanceOf(secondType)) {            set.add(firstType);          }          else if(secondType.instanceOf(firstType)) {            set.add(secondType);          }        }      }    }    return set;  }    // Declared in LookupMethod.jrag at line 66 @SuppressWarnings({"unchecked", "cast"})     public MethodDecl singleCandidateDecl() {        MethodDecl singleCandidateDecl_value = singleCandidateDecl_compute();        return singleCandidateDecl_value;    }    private MethodDecl singleCandidateDecl_compute() {    MethodDecl result = null;    for(Iterator iter = lookupMethod(name()).iterator(); iter.hasNext(); ) {      MethodDecl m = (MethodDecl)iter.next();      if(result == null)        result = m;      else if(m.getNumParameter() == getNumArg() && result.getNumParameter() != getNumArg())        result = m;    }    return result;  }    protected boolean decls_computed = false;    protected SimpleSet decls_value;    // Declared in LookupMethod.jrag at line 78 @SuppressWarnings({"unchecked", "cast"})     public SimpleSet decls() {        if(decls_computed)            return decls_value;        int num = boundariesCrossed;        boolean isFinal = this.is$Final();        decls_value = decls_compute();        if(isFinal && num == boundariesCrossed)            decls_computed = true;        return decls_value;    }    private SimpleSet decls_compute() {    SimpleSet maxSpecific = SimpleSet.emptySet;    for(Iterator iter = lookupMethod(name()).iterator(); iter.hasNext(); ) {      MethodDecl decl = (MethodDecl)iter.next();      if(applicable(decl) && accessible(decl)) {        if(maxSpecific.isEmpty())          maxSpecific = maxSpecific.add(decl);        else {          if(decl.moreSpecificThan((MethodDecl)maxSpecific.iterator().next()))            maxSpecific = SimpleSet.emptySet.add(decl);          else if(!((MethodDecl)maxSpecific.iterator().next()).moreSpecificThan(decl))            maxSpecific = maxSpecific.add(decl);        }      }    }    if(isQualified() ? qualifier().staticContextQualifier() : inStaticContext())      maxSpecific = removeInstanceMethods(maxSpecific);    return maxSpecific;  }    protected boolean decl_computed = false;    protected MethodDecl decl_value;    // Declared in LookupMethod.jrag at line 97 @SuppressWarnings({"unchecked", "cast"})     public MethodDecl decl() {        if(decl_computed)            return decl_value;        int num = boundariesCrossed;        boolean isFinal = this.is$Final();        decl_value = decl_compute();        if(isFinal && num == boundariesCrossed)            decl_computed = true;        return decl_value;    }    private MethodDecl decl_compute() {    SimpleSet decls = decls();    if(decls.size() == 1)      return (MethodDecl)decls.iterator().next();    // 8.4.6.4 - only return the first method in case of multply inherited abstract methods    boolean allAbstract = true;    for(Iterator iter = decls.iterator(); iter.hasNext() && allAbstract; ) {      MethodDecl m = (MethodDecl)iter.next();      if(!m.isAbstract() && !m.hostType().isObject())        allAbstract = false;    }    if(decls.size() > 1 && allAbstract)      return (MethodDecl)decls.iterator().next();    return unknownMethod();  }    // Declared in LookupMethod.jrag at line 164 @SuppressWarnings({"unchecked", "cast"})     public boolean accessible(MethodDecl m) {        boolean accessible_MethodDecl_value = accessible_compute(m);        return accessible_MethodDecl_value;    }    private boolean accessible_compute(MethodDecl m) {    if(!isQualified())      return true;    if(!m.accessibleFrom(hostType()))      return false;    // the method is not accessible if the type is not accessible    if(!qualifier().type().accessibleFrom(hostType()))      return false;    // 6.6.2.1 -  include qualifier type for protected access    if(m.isProtected() && !m.hostPackage().equals(hostPackage()) && !m.isStatic() && !qualifier().isSuperAccess()) {      TypeDecl C = m.hostType();      TypeDecl S = hostType().subclassWithinBody(C);      TypeDecl Q = qualifier().type();      if(S == null || !Q.instanceOf(S))        return false;    }    return true;  }    // Declared in NameCheck.jrag at line 60 @SuppressWarnings({"unchecked", "cast"})     public boolean validArgs() {        boolean validArgs_value = validArgs_compute();        return validArgs_value;    }    private boolean validArgs_compute() {    for(int i = 0; i < getNumArg(); i++)      if(getArg(i).type().isUnknown())        return false;    return true;  }    // Declared in PrettyPrint.jadd at line 782 @SuppressWarnings({"unchecked", "cast"})     public String dumpString() {        String dumpString_value = dumpString_compute();        return dumpString_value;    }    private String dumpString_compute() {  return getClass().getName() + " [" + getID() + "]";  }    // Declared in QualifiedNames.jrag at line 18 @SuppressWarnings({"unchecked", "cast"})     public String name() {        String name_value = name_compute();        return name_value;    }    private String name_compute() {  return getID();  }    // Declared in ResolveAmbiguousNames.jrag at line 19 @SuppressWarnings({"unchecked", "cast"})     public boolean isMethodAccess() {        boolean isMethodAccess_value = isMethodAccess_compute();        return isMethodAccess_value;    }    private boolean isMethodAccess_compute() {  return true;  }    // Declared in SyntacticClassification.jrag at line 113 @SuppressWarnings({"unchecked", "cast"})     public NameType predNameType() {        NameType predNameType_value = predNameType_compute();        return predNameType_value;    }    private NameType predNameType_compute() {  return NameType.AMBIGUOUS_NAME;  }    // Declared in TypeAnalysis.jrag at line 285 @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 decl().type();  }    // Declared in ExceptionHandling.jrag at line 29 @SuppressWarnings({"unchecked", "cast"})     public boolean handlesException(TypeDecl exceptionType) {        boolean handlesException_TypeDecl_value = getParent().Define_boolean_handlesException(this, null, exceptionType);        return handlesException_TypeDecl_value;    }    // Declared in LookupMethod.jrag at line 15 @SuppressWarnings({"unchecked", "cast"})     public MethodDecl unknownMethod() {        MethodDecl unknownMethod_value = getParent().Define_MethodDecl_unknownMethod(this, null);        return unknownMethod_value;    }    // Declared in TypeHierarchyCheck.jrag at line 123 @SuppressWarnings({"unchecked", "cast"})     public boolean inExplicitConstructorInvocation() {        boolean inExplicitConstructorInvocation_value = getParent().Define_boolean_inExplicitConstructorInvocation(this, null);        return inExplicitConstructorInvocation_value;    }    // Declared in LookupVariable.jrag at line 130    public SimpleSet Define_SimpleSet_lookupVariable(ASTNode caller, ASTNode child, String name) {        if(caller == getArgListNoTransform()) {      int childIndex = caller.getIndexOfChild(child);            return unqualifiedScope().lookupVariable(name);        }        return getParent().Define_SimpleSet_lookupVariable(this, caller, name);    }    // Declared in LookupMethod.jrag at line 28    public Collection Define_Collection_lookupMethod(ASTNode caller, ASTNode child, String name) {        if(caller == getArgListNoTransform()) {      int childIndex = caller.getIndexOfChild(child);            return unqualifiedScope().lookupMethod(name);        }        return getParent().Define_Collection_lookupMethod(this, caller, name);    }    // Declared in LookupType.jrag at line 87    public boolean Define_boolean_hasPackage(ASTNode caller, ASTNode child, String packageName) {        if(caller == getArgListNoTransform()) {      int childIndex = caller.getIndexOfChild(child);            return unqualifiedScope().hasPackage(packageName);        }        return getParent().Define_boolean_hasPackage(this, caller, packageName);    }    // Declared in TypeHierarchyCheck.jrag at line 17    public String Define_String_methodHost(ASTNode caller, ASTNode child) {        if(true) {      int childIndex = this.getIndexOfChild(caller);            return unqualifiedScope().methodHost();        }        return getParent().Define_String_methodHost(this, caller);    }    // Declared in SyntacticClassification.jrag at line 120    public NameType Define_NameType_nameType(ASTNode caller, ASTNode child) {        if(caller == getArgListNoTransform()) {      int childIndex = caller.getIndexOfChild(child);            return NameType.EXPRESSION_NAME;        }        return getParent().Define_NameType_nameType(this, caller);    }    // Declared in DefiniteAssignment.jrag at line 413    public boolean Define_boolean_isDAbefore(ASTNode caller, ASTNode child, Variable v) {        if(caller == getArgListNoTransform()) {      int i = caller.getIndexOfChild(child);            return computeDAbefore(i, v);        }        return getParent().Define_boolean_isDAbefore(this, caller, v);    }    // Declared in LookupType.jrag at line 165    public SimpleSet Define_SimpleSet_lookupType(ASTNode caller, ASTNode child, String name) {        if(caller == getArgListNoTransform()) {      int childIndex = caller.getIndexOfChild(child);            return unqualifiedScope().lookupType(name);        }        return getParent().Define_SimpleSet_lookupType(this, caller, name);    }public ASTNode rewriteTo() {    return super.rewriteTo();}}

⌨️ 快捷键说明

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