aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--tests/ajcTests.xml6
-rw-r--r--tests/bugs/AdviceExec.java31
-rw-r--r--weaver/src/org/aspectj/weaver/patterns/KindedPointcut.java2
-rw-r--r--weaver/src/org/aspectj/weaver/patterns/SignaturePattern.java2
4 files changed, 39 insertions, 2 deletions
diff --git a/tests/ajcTests.xml b/tests/ajcTests.xml
index 15864594a..ab1a6fe0d 100644
--- a/tests/ajcTests.xml
+++ b/tests/ajcTests.xml
@@ -5573,4 +5573,10 @@
<run class="test.Test3"/>
</ajc-test>
+ <ajc-test dir="bugs" pr="31423"
+ title="Pointcut adviceexecution() does not work">
+ <compile files="AdviceExec.java"/>
+ <run class="AdviceExec"/>
+ </ajc-test>
+
</suite>
diff --git a/tests/bugs/AdviceExec.java b/tests/bugs/AdviceExec.java
new file mode 100644
index 000000000..7d28f28fe
--- /dev/null
+++ b/tests/bugs/AdviceExec.java
@@ -0,0 +1,31 @@
+// for Bug#: 31423
+import org.aspectj.testing.Tester;
+
+
+public class AdviceExec {
+ public static void main(String[] args) {
+ Tester.checkEqual(Aspect1.ran, 2, "Aspect1 ran");
+ Tester.checkEqual(Aspect2.ran, 2, "Aspect2 ran");
+ }
+}
+
+aspect Aspect1 {
+ static int ran = 0;
+ before() : execution(* AdviceExec.*(..)) {
+ //System.out.println("Reached " + thisJoinPoint);
+ ran++;
+ }
+
+ void around(): execution(* AdviceExec.*(..)) {
+ ran++;
+ proceed();
+ }
+}
+
+aspect Aspect2 {
+ static int ran = 0;
+ before() : adviceexecution() && !within(Aspect2) {
+ //System.out.println("Reached " + thisJoinPoint);
+ ran++;
+ }
+}
diff --git a/weaver/src/org/aspectj/weaver/patterns/KindedPointcut.java b/weaver/src/org/aspectj/weaver/patterns/KindedPointcut.java
index 207f58259..6003e8f74 100644
--- a/weaver/src/org/aspectj/weaver/patterns/KindedPointcut.java
+++ b/weaver/src/org/aspectj/weaver/patterns/KindedPointcut.java
@@ -35,8 +35,6 @@ public class KindedPointcut extends Pointcut {
public boolean fastMatch(JavaClass jc) { return true; }
public FuzzyBoolean match(Shadow shadow) {
-
-
if (shadow.getKind() != kind) return FuzzyBoolean.NO;
if (!signature.matches(shadow.getSignature(), shadow.getIWorld())) return FuzzyBoolean.NO;
diff --git a/weaver/src/org/aspectj/weaver/patterns/SignaturePattern.java b/weaver/src/org/aspectj/weaver/patterns/SignaturePattern.java
index fe6f656c7..f6b091289 100644
--- a/weaver/src/org/aspectj/weaver/patterns/SignaturePattern.java
+++ b/weaver/src/org/aspectj/weaver/patterns/SignaturePattern.java
@@ -85,6 +85,8 @@ public class SignaturePattern extends PatternNode {
world.getLint().unresolvableMember.signal(member.toString(), getSourceLocation());
return false;
}
+ if (kind == Member.ADVICE) return true;
+
if (!modifiers.matches(sig.getModifiers())) return false;
if (kind == Member.STATIC_INITIALIZATION) {