diff options
author | wisberg <wisberg> | 2002-12-16 18:51:06 +0000 |
---|---|---|
committer | wisberg <wisberg> | 2002-12-16 18:51:06 +0000 |
commit | 144143c2970a1e874d74cdbd0f8c622d4282a3c3 (patch) | |
tree | b12383d3d9e76c7e1f25f7fbec83051ef17f81fb /tests/new/ArgsInCflowCf.java | |
parent | fafae443719b26159ab2d7dac1c9b46b5e00b671 (diff) | |
download | aspectj-144143c2970a1e874d74cdbd0f8c622d4282a3c3.tar.gz aspectj-144143c2970a1e874d74cdbd0f8c622d4282a3c3.zip |
initial version
Diffstat (limited to 'tests/new/ArgsInCflowCf.java')
-rw-r--r-- | tests/new/ArgsInCflowCf.java | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/tests/new/ArgsInCflowCf.java b/tests/new/ArgsInCflowCf.java new file mode 100644 index 000000000..21ec256b6 --- /dev/null +++ b/tests/new/ArgsInCflowCf.java @@ -0,0 +1,37 @@ + +import org.aspectj.testing.*; + +/** PR#660 name binding in around cflow */ +public class ArgsInCflowCf { + public static void main(String[] args) { + Tester.check(3==foo(1), "3==foo(1)"); + Tester.checkAllEvents(); + } + static int foo(int x) {return bar(x+1);} + static int bar(int x) {return x+1;} + + static { + Tester.expectEvent("1-2"); + } +} + +aspect Test { + int around(int x, int y) : // ERR not final + cflow(call(int foo(int)) && args(x)) + && call(int bar(int)) && args(y) { + Tester.event(x + "-" + y); + return proceed(x,y); + } + int around(final int x, int y) : + cflow(call(int foo(int)) && args(x)) + && call(int bar(int)) && args(y) { + Tester.event(x + "-" + y); + return proceed(y,y); // ERR simple refs + } + int around(final int x, int y) : + cflow(call(int foo(int)) && args(x)) + && call(int bar(int)) && args(y) { + Tester.event(x + "-" + y); + return proceed(x+1,y+1); // ERR simple refs + } +} |