diff options
author | aclement <aclement> | 2006-02-22 14:58:25 +0000 |
---|---|---|
committer | aclement <aclement> | 2006-02-22 14:58:25 +0000 |
commit | 82854f5681752d87be7500828509e6c86c4f7345 (patch) | |
tree | 765807d7da013b1febf4720c61e70a0bc294aaaf /bcel-builder | |
parent | 3fa1bddb79a5e20a38cb39555e932df46f3d4dfa (diff) | |
download | aspectj-82854f5681752d87be7500828509e6c86c4f7345.tar.gz aspectj-82854f5681752d87be7500828509e6c86c4f7345.zip |
optimization: cache info
Diffstat (limited to 'bcel-builder')
-rw-r--r-- | bcel-builder/src/org/aspectj/apache/bcel/generic/FieldOrMethod.java | 51 |
1 files changed, 36 insertions, 15 deletions
diff --git a/bcel-builder/src/org/aspectj/apache/bcel/generic/FieldOrMethod.java b/bcel-builder/src/org/aspectj/apache/bcel/generic/FieldOrMethod.java index 1883d67c1..548be1f20 100644 --- a/bcel-builder/src/org/aspectj/apache/bcel/generic/FieldOrMethod.java +++ b/bcel-builder/src/org/aspectj/apache/bcel/generic/FieldOrMethod.java @@ -62,7 +62,7 @@ import org.aspectj.apache.bcel.classfile.ConstantUtf8; * Super class for InvokeInstruction and FieldInstruction, since they have * some methods in common! * - * @version $Id: FieldOrMethod.java,v 1.4 2005/09/19 15:12:36 aclement Exp $ + * @version $Id: FieldOrMethod.java,v 1.5 2006/02/22 14:58:25 aclement Exp $ * @author <A HREF="mailto:markus.dahm@berlin.de">M. Dahm</A> */ public abstract class FieldOrMethod extends CPInstruction implements LoadClass { @@ -72,6 +72,15 @@ public abstract class FieldOrMethod extends CPInstruction implements LoadClass { */ FieldOrMethod() {} + private boolean dontKnowSignature=true; + private String signature; + + private boolean dontKnowName =true; + private String name; + + private boolean dontKnowClassname =true; + private String classname; + /** * @param index to constant pool */ @@ -82,30 +91,42 @@ public abstract class FieldOrMethod extends CPInstruction implements LoadClass { /** @return signature of referenced method/field. */ public String getSignature(ConstantPoolGen cpg) { - ConstantPool cp = cpg.getConstantPool(); - ConstantCP cmr = (ConstantCP)cp.getConstant(index); - ConstantNameAndType cnat = (ConstantNameAndType)cp.getConstant(cmr.getNameAndTypeIndex()); - - return ((ConstantUtf8)cp.getConstant(cnat.getSignatureIndex())).getBytes(); + if (dontKnowSignature) { + ConstantPool cp = cpg.getConstantPool(); + ConstantCP cmr = (ConstantCP)cp.getConstant(index); + ConstantNameAndType cnat = (ConstantNameAndType)cp.getConstant(cmr.getNameAndTypeIndex()); + + signature = ((ConstantUtf8)cp.getConstant(cnat.getSignatureIndex())).getBytes(); + dontKnowSignature=false; + } + return signature; } /** @return name of referenced method/field. */ public String getName(ConstantPoolGen cpg) { - ConstantPool cp = cpg.getConstantPool(); - ConstantCP cmr = (ConstantCP)cp.getConstant(index); - ConstantNameAndType cnat = (ConstantNameAndType)cp.getConstant(cmr.getNameAndTypeIndex()); - return ((ConstantUtf8)cp.getConstant(cnat.getNameIndex())).getBytes(); + if (dontKnowName) { + ConstantPool cp = cpg.getConstantPool(); + ConstantCP cmr = (ConstantCP)cp.getConstant(index); + ConstantNameAndType cnat = (ConstantNameAndType)cp.getConstant(cmr.getNameAndTypeIndex()); + name = ((ConstantUtf8)cp.getConstant(cnat.getNameIndex())).getBytes(); + dontKnowName = false; + } + return name; } /** @return name of the referenced class/interface */ public String getClassName(ConstantPoolGen cpg) { - ConstantPool cp = cpg.getConstantPool(); - ConstantCP cmr = (ConstantCP)cp.getConstant(index); - String str = cp.getConstantString(cmr.getClassIndex(), org.aspectj.apache.bcel.Constants.CONSTANT_Class); - if (str.charAt(0)=='[') return str; - else return str.replace('/', '.'); + if (dontKnowClassname) { + ConstantPool cp = cpg.getConstantPool(); + ConstantCP cmr = (ConstantCP)cp.getConstant(index); + String str = cp.getConstantString(cmr.getClassIndex(), org.aspectj.apache.bcel.Constants.CONSTANT_Class); + if (str.charAt(0)=='[') classname= str; + else classname= str.replace('/', '.'); + dontKnowClassname = false; + } + return classname; } /** @return type of the referenced class/interface |