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/errors/AspectInheritance2.java | |
parent | fafae443719b26159ab2d7dac1c9b46b5e00b671 (diff) | |
download | aspectj-144143c2970a1e874d74cdbd0f8c622d4282a3c3.tar.gz aspectj-144143c2970a1e874d74cdbd0f8c622d4282a3c3.zip |
initial version
Diffstat (limited to 'tests/errors/AspectInheritance2.java')
-rw-r--r-- | tests/errors/AspectInheritance2.java | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/tests/errors/AspectInheritance2.java b/tests/errors/AspectInheritance2.java new file mode 100644 index 000000000..eb443ff2d --- /dev/null +++ b/tests/errors/AspectInheritance2.java @@ -0,0 +1,39 @@ +public class AspectInheritance2 { + public static void main(String[] args) { + } +} + + +abstract aspect Base { + abstract pointcut targets(int i, C c); + + after(int i, C c): targets(i, c) { + // + } +} + +aspect FullConcrete extends Base { + pointcut targets(int i, SubC subc): //ERROR param types must match exactly + call(void SubC.m(double)) && target(subc) && args(i); +} + +aspect ForgetfulConcrete extends Base { //ERROR must concretize abstracts +} + +aspect ExplictAbstractConcrete extends Base { + pointcut targets(int i, C c); + + abstract pointcut newTargets(); //ERROR no abstracts allowed in concrete +} + +aspect PrivateConcrete extends Base { + private pointcut targets(int i, C c): //ERROR can't reduce visibility of decs + call(void C.m(int)) && target(c) && args(i); +} + + +class C { + public void m(int i) { } +} + +class SubC extends C {} |