aboutsummaryrefslogtreecommitdiffstats
path: root/tests/bugs/pr72531
diff options
context:
space:
mode:
authoracolyer <acolyer>2004-08-24 21:10:56 +0000
committeracolyer <acolyer>2004-08-24 21:10:56 +0000
commit82eae551311afbd3a942d54e55b1c569c5f975b8 (patch)
tree8a716f4fe9e62354f60594b34185cd6fe53de541 /tests/bugs/pr72531
parentcfaa79ae72fba6619700f259fd4b05eaed6d3988 (diff)
downloadaspectj-82eae551311afbd3a942d54e55b1c569c5f975b8.tar.gz
aspectj-82eae551311afbd3a942d54e55b1c569c5f975b8.zip
fix for Bugzilla Bug 72531
declare warning warns at wrong points
Diffstat (limited to 'tests/bugs/pr72531')
-rw-r--r--tests/bugs/pr72531/de/rohith/HelloWorld.java11
-rw-r--r--tests/bugs/pr72531/de/rohith/HelloWorldAspect.java31
-rw-r--r--tests/bugs/pr72531/de/rohith/PrinterWorld.java25
3 files changed, 67 insertions, 0 deletions
diff --git a/tests/bugs/pr72531/de/rohith/HelloWorld.java b/tests/bugs/pr72531/de/rohith/HelloWorld.java
new file mode 100644
index 000000000..f2687aab9
--- /dev/null
+++ b/tests/bugs/pr72531/de/rohith/HelloWorld.java
@@ -0,0 +1,11 @@
+package de.rohith;
+public class HelloWorld {
+
+ public static void main(String[] args) {
+ PrinterWorld p = new PrinterWorld();
+ p.print();
+ Integer i = p.returnInt();
+ Integer[] intArray = p.returnArrayWithCloning();
+ Integer[] array2 = p.returnArrayWithoutCloning();
+ }
+}
diff --git a/tests/bugs/pr72531/de/rohith/HelloWorldAspect.java b/tests/bugs/pr72531/de/rohith/HelloWorldAspect.java
new file mode 100644
index 000000000..cbe1dc707
--- /dev/null
+++ b/tests/bugs/pr72531/de/rohith/HelloWorldAspect.java
@@ -0,0 +1,31 @@
+package de.rohith;
+import java.lang.Object;
+
+public aspect HelloWorldAspect {
+
+ private int callDepth = -1;
+
+ public HelloWorldAspect() {
+ }
+
+ pointcut hello(): !within(HelloWorldAspect);
+
+ pointcut method(): execution(public (*[]) de..*(..));
+
+ pointcut cloning(): call(* java.lang.Object.clone());
+
+ declare warning: method() && hello(): "*[] returning method called" ;
+
+ Object[] around(): cflow(method()) && cloning() && hello() {
+ print("", thisEnclosingJoinPointStaticPart);
+ Object[] ret = proceed();
+ return (Object[])ret.clone();
+ }
+
+ private void print(String prefix, Object message) {
+ for (int i = 0, spaces = callDepth * 2; i < spaces; i++) {
+ System.out.print(" ");
+ }
+ System.out.println(prefix + message);
+ }
+}
diff --git a/tests/bugs/pr72531/de/rohith/PrinterWorld.java b/tests/bugs/pr72531/de/rohith/PrinterWorld.java
new file mode 100644
index 000000000..cf4277643
--- /dev/null
+++ b/tests/bugs/pr72531/de/rohith/PrinterWorld.java
@@ -0,0 +1,25 @@
+package de.rohith;
+public class PrinterWorld {
+ private Integer[] intArray = new Integer[2];
+ public PrinterWorld() {
+
+ }
+ public void print() {
+ System.out.println("Hello World!");
+ }
+
+ public Integer returnInt() {
+ return new Integer(3);
+ }
+
+ public Integer[] returnArrayWithCloning() {
+ for (int i = 0; i < intArray.length; i++) {
+ intArray[i] = new Integer(i++);
+ }
+ return (Integer[])intArray.clone();
+ }
+
+ public Integer[] returnArrayWithoutCloning() {
+ return intArray;
+ }
+}