summaryrefslogtreecommitdiffstats
path: root/weaver/src
diff options
context:
space:
mode:
Diffstat (limited to 'weaver/src')
-rw-r--r--weaver/src/org/aspectj/weaver/bcel/BcelWeaver.java16
-rw-r--r--weaver/src/org/aspectj/weaver/patterns/PointcutRewriter.java27
2 files changed, 31 insertions, 12 deletions
diff --git a/weaver/src/org/aspectj/weaver/bcel/BcelWeaver.java b/weaver/src/org/aspectj/weaver/bcel/BcelWeaver.java
index 45b1bb869..3549d4872 100644
--- a/weaver/src/org/aspectj/weaver/bcel/BcelWeaver.java
+++ b/weaver/src/org/aspectj/weaver/bcel/BcelWeaver.java
@@ -683,7 +683,21 @@ public class BcelWeaver implements IWeaver {
// the effects of itds (on within for example), interfaces, the fact that
// join points can have multiple signatures and so on.
private boolean couldEverMatchSameJoinPoints(Pointcut left, Pointcut right) {
- if ((left instanceof OrPointcut) || (right instanceof OrPointcut)) return true;
+
+ if (left instanceof OrPointcut) {
+ OrPointcut leftOrPointcut = (OrPointcut)left;
+ if (couldEverMatchSameJoinPoints(leftOrPointcut.getLeft(),right)) return true;
+ if (couldEverMatchSameJoinPoints(leftOrPointcut.getRight(),right)) return true;
+ return false;
+ }
+
+ if (right instanceof OrPointcut) {
+ OrPointcut rightOrPointcut = (OrPointcut)right;
+ if (couldEverMatchSameJoinPoints(left,rightOrPointcut.getLeft())) return true;
+ if (couldEverMatchSameJoinPoints(left,rightOrPointcut.getRight())) return true;
+ return false;
+ }
+
// look for withins
WithinPointcut leftWithin = (WithinPointcut) findFirstPointcutIn(left,WithinPointcut.class);
WithinPointcut rightWithin = (WithinPointcut) findFirstPointcutIn(right,WithinPointcut.class);
diff --git a/weaver/src/org/aspectj/weaver/patterns/PointcutRewriter.java b/weaver/src/org/aspectj/weaver/patterns/PointcutRewriter.java
index f6383e575..fed2d7046 100644
--- a/weaver/src/org/aspectj/weaver/patterns/PointcutRewriter.java
+++ b/weaver/src/org/aspectj/weaver/patterns/PointcutRewriter.java
@@ -27,19 +27,20 @@ public class PointcutRewriter {
private static final boolean WATCH_PROGRESS = false;
public Pointcut rewrite(Pointcut pc) {
- if (WATCH_PROGRESS) System.out.println(pc);
+ if (WATCH_PROGRESS) System.out.println("Initial pointcut is ==> " + pc);
Pointcut result = distributeNot(pc);
- if (WATCH_PROGRESS) System.out.println("==> " + result);
+ if (WATCH_PROGRESS) System.out.println("Distributing NOT gives ==> " + result);
result = pullUpDisjunctions(result);
- if (WATCH_PROGRESS) System.out.println("==> " + result);
+ if (WATCH_PROGRESS) System.out.println("Pull up disjunctions gives ==> " + result);
result = simplifyAnds(result);
- if (WATCH_PROGRESS) System.out.println("==> " + result);
+ if (WATCH_PROGRESS) System.out.println("Simplifying ANDs gives ==> " + result);
result = sortOrs(result);
- if (WATCH_PROGRESS) System.out.println("==> " + result);
+ if (WATCH_PROGRESS) System.out.println("Sorting ORs gives ==> " + result);
return result;
}
+
// !!X => X
// !(X && Y) => !X || !Y
// !(X || Y) => !X && !Y
@@ -95,16 +96,20 @@ public class PointcutRewriter {
// (A || B) && C => (A && C) || (B && C)
Pointcut leftLeft = ((OrPointcut)left).getLeft();
Pointcut leftRight = ((OrPointcut)left).getRight();
- return new OrPointcut(
- new AndPointcut(leftLeft,right),
- new AndPointcut(leftRight,right));
+ return pullUpDisjunctions(
+ new OrPointcut(
+ new AndPointcut(leftLeft,right),
+ new AndPointcut(leftRight,right))
+ );
} else if (isOr(right) && !isOr(left)) {
// A && (B || C) => (A && B) || (A && C)
Pointcut rightLeft = ((OrPointcut)right).getLeft();
Pointcut rightRight = ((OrPointcut)right).getRight();
- return new OrPointcut(
- new AndPointcut(left,rightLeft),
- new AndPointcut(left,rightRight));
+ return pullUpDisjunctions(
+ new OrPointcut(
+ new AndPointcut(left,rightLeft),
+ new AndPointcut(left,rightRight))
+ );
} else {
return new AndPointcut(left,right);