diff options
Diffstat (limited to 'weaver')
4 files changed, 34 insertions, 20 deletions
diff --git a/weaver/src/org/aspectj/weaver/CrosscuttingMembers.java b/weaver/src/org/aspectj/weaver/CrosscuttingMembers.java index 24c21cc6a..ab60e6897 100644 --- a/weaver/src/org/aspectj/weaver/CrosscuttingMembers.java +++ b/weaver/src/org/aspectj/weaver/CrosscuttingMembers.java @@ -96,9 +96,7 @@ public class CrosscuttingMembers { declareDominates.add(declare); } else if (declare instanceof DeclareParents) { DeclareParents dp = (DeclareParents)declare; - for (Iterator i = dp.getParents().collectAccessTypeMungers(world).iterator(); i.hasNext(); ) { - addTypeMunger(world.concreteTypeMunger((PrivilegedAccessMunger)i.next(), inAspect)); - } + exposeTypes(dp.getParents().getExactTypes()); declareParents.add(dp); } else if (declare instanceof DeclareSoft) { DeclareSoft d = (DeclareSoft)declare; @@ -111,6 +109,21 @@ public class CrosscuttingMembers { } } + public void exposeTypes(Collection typesToExpose) { + for (Iterator i = typesToExpose.iterator(); i.hasNext(); ) { + exposeType((TypeX)i.next()); + } + } + + public void exposeType(TypeX typeToExpose) { + if (typeToExpose == ResolvedTypeX.MISSING) return; + + ResolvedMember member = new ResolvedMember( + Member.STATIC_INITIALIZATION, typeToExpose, 0, ResolvedTypeX.VOID, "", TypeX.NONE); + addTypeMunger(world.concreteTypeMunger( + new PrivilegedAccessMunger(member), inAspect)); + } + public void addPrivilegedAccesses(Collection accessedMembers) { for (Iterator i = accessedMembers.iterator(); i.hasNext(); ) { addPrivilegedAccess( (ResolvedMember)i.next() ); diff --git a/weaver/src/org/aspectj/weaver/patterns/ArgsPointcut.java b/weaver/src/org/aspectj/weaver/patterns/ArgsPointcut.java index 986d15eee..a95471350 100644 --- a/weaver/src/org/aspectj/weaver/patterns/ArgsPointcut.java +++ b/weaver/src/org/aspectj/weaver/patterns/ArgsPointcut.java @@ -34,13 +34,8 @@ public class ArgsPointcut extends NameBindingPointcut { } public FuzzyBoolean match(Shadow shadow) { - int n = shadow.getArgCount(); - TypeX[] argTypes = new TypeX[n]; - for (int i=0; i < n; i++) { - argTypes[i] = shadow.getArgType(i); - } FuzzyBoolean ret = - arguments.matches(shadow.getIWorld().resolve(argTypes), TypePattern.DYNAMIC); + arguments.matches(shadow.getIWorld().resolve(shadow.getArgTypes()), TypePattern.DYNAMIC); return ret; } @@ -81,15 +76,18 @@ public class ArgsPointcut extends NameBindingPointcut { public Pointcut concretize1(ResolvedTypeX inAspect, IntMap bindings) { - return new ArgsPointcut(arguments.resolveReferences(bindings)); + TypePatternList args = arguments.resolveReferences(bindings); + if (inAspect.crosscuttingMembers != null) { + inAspect.crosscuttingMembers.exposeTypes(args.getExactTypes()); + } + return new ArgsPointcut(args); } private Test findResidueNoEllipsis(Shadow shadow, ExposedState state, TypePattern[] patterns) { int len = shadow.getArgCount(); //System.err.println("boudn to : " + len + ", " + patterns.length); if (patterns.length != len) { - throw new RuntimeException("this should never happen"); - //return Literal.FALSE; //??? this should never happen + return Literal.FALSE; } Test ret = Literal.TRUE; @@ -110,6 +108,9 @@ public class ArgsPointcut extends NameBindingPointcut { } public Test findResidue(Shadow shadow, ExposedState state) { + if (arguments.matches(shadow.getIWorld().resolve(shadow.getArgTypes()), TypePattern.DYNAMIC).alwaysFalse()) { + return Literal.FALSE; + } int ellipsisCount = arguments.ellipsisCount; if (ellipsisCount == 0) { return findResidueNoEllipsis(shadow, state, arguments.getTypePatterns()); diff --git a/weaver/src/org/aspectj/weaver/patterns/ThisOrTargetPointcut.java b/weaver/src/org/aspectj/weaver/patterns/ThisOrTargetPointcut.java index 1351ac075..e59116e44 100644 --- a/weaver/src/org/aspectj/weaver/patterns/ThisOrTargetPointcut.java +++ b/weaver/src/org/aspectj/weaver/patterns/ThisOrTargetPointcut.java @@ -103,7 +103,12 @@ public class ThisOrTargetPointcut extends NameBindingPointcut { } public Pointcut concretize1(ResolvedTypeX inAspect, IntMap bindings) { - return new ThisOrTargetPointcut(isThis, type.remapAdviceFormals(bindings)); + TypePattern newType = type.remapAdviceFormals(bindings); + if (inAspect.crosscuttingMembers != null) { + inAspect.crosscuttingMembers.exposeType(newType.getExactType()); + } + + return new ThisOrTargetPointcut(isThis, newType); } } diff --git a/weaver/src/org/aspectj/weaver/patterns/TypePatternList.java b/weaver/src/org/aspectj/weaver/patterns/TypePatternList.java index c3a741578..3e4c0e25f 100644 --- a/weaver/src/org/aspectj/weaver/patterns/TypePatternList.java +++ b/weaver/src/org/aspectj/weaver/patterns/TypePatternList.java @@ -232,16 +232,11 @@ public class TypePatternList extends PatternNode { return typePatterns; } - public Collection collectAccessTypeMungers(World world) { + public Collection getExactTypes() { ArrayList ret = new ArrayList(); for (int i=0; i<typePatterns.length; i++) { TypeX t = typePatterns[i].getExactType(); - ResolvedTypeX rt = t.resolve(world); - if (!Modifier.isPublic(rt.getModifiers())) { - ret.add(new PrivilegedAccessMunger(new ResolvedMember( - Member.STATIC_INITIALIZATION, rt, 0, ResolvedTypeX.VOID, "", TypeX.NONE - ))); - } + if (t != ResolvedTypeX.MISSING) ret.add(t); } return ret; } |