aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--weaver/src/org/aspectj/weaver/bcel/LazyClassGen.java40
1 files changed, 39 insertions, 1 deletions
diff --git a/weaver/src/org/aspectj/weaver/bcel/LazyClassGen.java b/weaver/src/org/aspectj/weaver/bcel/LazyClassGen.java
index 085a83e7f..69ea1812b 100644
--- a/weaver/src/org/aspectj/weaver/bcel/LazyClassGen.java
+++ b/weaver/src/org/aspectj/weaver/bcel/LazyClassGen.java
@@ -1055,7 +1055,21 @@ public final class LazyClassGen {
new ObjectType(sig.getSignatureType()),
new Type[] { Type.STRING,Type.STRING,Type.STRING,Type.STRING,Type.STRING,Type.STRING,Type.STRING },
Constants.INVOKEVIRTUAL));
- } else if (sig.getKind().equals(Member.HANDLER)) {
+ } else if (sig.getKind().equals(Member.MONITORENTER)) {
+ list.append(new PUSH(getConstantPoolGen(),makeString(sig.getDeclaringType())));
+ list.append(fact.createInvoke(factoryType.getClassName(),
+ sig.getSignatureMakerName(),
+ new ObjectType(sig.getSignatureType()),
+ new Type[] { Type.STRING},
+ Constants.INVOKEVIRTUAL));
+ } else if (sig.getKind().equals(Member.MONITOREXIT)) {
+ list.append(new PUSH(getConstantPoolGen(),makeString(sig.getDeclaringType())));
+ list.append(fact.createInvoke(factoryType.getClassName(),
+ sig.getSignatureMakerName(),
+ new ObjectType(sig.getSignatureType()),
+ new Type[] { Type.STRING},
+ Constants.INVOKEVIRTUAL));
+ } else if (sig.getKind().equals(Member.HANDLER)) {
BcelWorld w = shadow.getWorld();
list.append(new PUSH(getConstantPoolGen(),makeString(sig.getDeclaringType())));
list.append(new PUSH(getConstantPoolGen(),makeString(sig.getParameterTypes())));
@@ -1312,6 +1326,30 @@ public final class LazyClassGen {
}
return false;
}
+
+ public boolean isAtLeastJava5() {
+ return (myGen.getMajor()>=Constants.MAJOR_1_5);
+ }
+ /**
+ * Return the next available field name with the specified 'prefix', e.g.
+ * for prefix 'class$' where class$0, class$1 exist then return class$2
+ */
+ public String allocateField(String prefix) {
+ int highestAllocated = -1;
+ Field[] fs = getFieldGens();
+ for (int i = 0; i < fs.length; i++) {
+ Field field = fs[i];
+ if (field.getName().startsWith(prefix)) {
+ try {
+ int num = Integer.parseInt(field.getName().substring(prefix.length()));
+ if (num>highestAllocated) highestAllocated = num;
+ } catch (NumberFormatException nfe) {
+ // something wrong with the number on the end of that field...
+ }
+ }
+ }
+ return prefix+Integer.toString(highestAllocated+1);
+ }
}