diff options
Diffstat (limited to 'weaver')
-rw-r--r-- | weaver/src/org/aspectj/weaver/Shadow.java | 8 | ||||
-rw-r--r-- | weaver/src/org/aspectj/weaver/bcel/BcelClassWeaver.java | 31 | ||||
-rw-r--r-- | weaver/src/org/aspectj/weaver/bcel/BcelShadow.java | 11 | ||||
-rw-r--r-- | weaver/src/org/aspectj/weaver/bcel/Utility.java | 3 |
4 files changed, 45 insertions, 8 deletions
diff --git a/weaver/src/org/aspectj/weaver/Shadow.java b/weaver/src/org/aspectj/weaver/Shadow.java index 22f86deb9..fd5c37fa7 100644 --- a/weaver/src/org/aspectj/weaver/Shadow.java +++ b/weaver/src/org/aspectj/weaver/Shadow.java @@ -50,13 +50,19 @@ public abstract class Shadow { public final boolean hasTarget() { return !(getSignature().isStatic() || (getKind() == ConstructorCall) - || (getKind() == PreInitialization)); + || (getKind() == PreInitialization)); } public final TypeX getTargetType() { if (!hasTarget()) return ResolvedTypeX.MISSING; return getSignature().getDeclaringType(); } + + public TypeX[] getArgTypes() { + if (getKind() == FieldSet) return new TypeX[] { getSignature().getReturnType() }; + return getSignature().getParameterTypes(); + } + public TypeX getArgType(int arg) { if (getKind() == FieldSet) return getSignature().getReturnType(); return getSignature().getParameterTypes()[arg]; diff --git a/weaver/src/org/aspectj/weaver/bcel/BcelClassWeaver.java b/weaver/src/org/aspectj/weaver/bcel/BcelClassWeaver.java index 74d2ace0f..a56b7d139 100644 --- a/weaver/src/org/aspectj/weaver/bcel/BcelClassWeaver.java +++ b/weaver/src/org/aspectj/weaver/bcel/BcelClassWeaver.java @@ -13,6 +13,7 @@ package org.aspectj.weaver.bcel; +import java.lang.reflect.Modifier; import java.util.*; import org.apache.bcel.Constants; @@ -764,10 +765,34 @@ class BcelClassWeaver implements IClassWeaver { Instruction i = ih.getInstruction(); if (i instanceof FieldInstruction) { FieldInstruction fi = (FieldInstruction) i; + + + if (i instanceof PUTFIELD || i instanceof PUTSTATIC) { - match( - BcelShadow.makeFieldSet(world, mg, ih, enclosingShadow), - shadowAccumulator); + // check for sets of constant fields. We first check the previous + // instruction. If the previous instruction is a LD_WHATEVER (push + // constant on the stack) then we must resolve the field to determine + // if it's final. If it is final, then we don't generate a shadow. + InstructionHandle prevHandle = ih.getPrev(); + Instruction prevI = prevHandle.getInstruction(); + if (Utility.isConstantPushInstruction(prevI)) { + Member field = world.makeFieldSignature(clazz, (FieldInstruction) i); + ResolvedMember resolvedField = field.resolve(world); + if (resolvedField == null) { + // we can't find the field, so it's not a join point. + } else if (Modifier.isFinal(resolvedField.getModifiers())) { + // it's final, so it's the set of a final constant, so it's + // not a join point according to 1.0.6 and 1.1. + } else { + match( + BcelShadow.makeFieldSet(world, mg, ih, enclosingShadow), + shadowAccumulator); + } + } else { + match( + BcelShadow.makeFieldSet(world, mg, ih, enclosingShadow), + shadowAccumulator); + } } else { match( BcelShadow.makeFieldGet(world, mg, ih, enclosingShadow), diff --git a/weaver/src/org/aspectj/weaver/bcel/BcelShadow.java b/weaver/src/org/aspectj/weaver/bcel/BcelShadow.java index acc8f96f1..5f77b50ef 100644 --- a/weaver/src/org/aspectj/weaver/bcel/BcelShadow.java +++ b/weaver/src/org/aspectj/weaver/bcel/BcelShadow.java @@ -162,9 +162,12 @@ public class BcelShadow extends Shadow { retargetFrom(dupHandle, nextHandle); retargetFrom(endHandle, nextHandle); } else { - // XXX we want to fail gracefully here. This should not be picked out as a join point, - // probably. So change BcelClassWeaver.match appropriately. - throw new RuntimeException("Unhandled kind of new"); + endHandle = newHandle; + nextHandle = endHandle.getNext(); + retargetFrom(newHandle, nextHandle); + // add a POP here... we found a NEW w/o a dup or anything else, so + // we must be in statement context. + getRange().insert(getFactory().POP, Range.OutsideAfter); } // assert (dupHandle.getInstruction() instanceof DUP); @@ -1669,7 +1672,7 @@ public class BcelShadow extends Shadow { * ??? rewrite this to do less array munging, please */ private LazyMethodGen createMethodGen(String newMethodName) { - Type[] parameterTypes = world.makeBcelTypes(getSignature().getParameterTypes()); + Type[] parameterTypes = world.makeBcelTypes(getArgTypes()); int modifiers = Modifier.FINAL; // XXX some bug diff --git a/weaver/src/org/aspectj/weaver/bcel/Utility.java b/weaver/src/org/aspectj/weaver/bcel/Utility.java index 9da48c01f..dc8dde9b8 100644 --- a/weaver/src/org/aspectj/weaver/bcel/Utility.java +++ b/weaver/src/org/aspectj/weaver/bcel/Utility.java @@ -439,4 +439,7 @@ public class Utility { return ret; } + public static boolean isConstantPushInstruction(Instruction i) { + return (i instanceof ConstantPushInstruction) || (i instanceof LDC); + } } |