blob: 6b83a70515bf3f6cd28af22e60bfa46408b05cde (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
import java.lang.annotation.*;
@Retention(RetentionPolicy.RUNTIME)
@interface Colored { String color(); }
public class CallAnnBinding6 {
public static void main(String[]argv) {
A b = new B();
b.m();
if (X.i!=1) throw new RuntimeException("Why did the advice not run?");
}
}
class A {
@Colored(color="RedA") public void m() {}
}
class B extends A {
@Colored(color="RedB") public void m() {}
}
aspect X {
public static int i = 0;
before(Colored c): call(* m*(..)) && !within(X) && @annotation(c) {
i++;
if (i==1) checkColor(1,c,"RedA");
if (i==11) throw new RuntimeException("Advice running more times than expected");
System.err.println(c.color());
}
public void checkColor(int run, Colored c,String exp) {
if (!c.color().equals(exp))
throw new RuntimeException("Advice execution #"+run+" expected "+exp+" but got "+c.color());
}
}
|