summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--tests/bugs1612/pr351592/Caching.aj20
-rw-r--r--tests/bugs1612/pr351592/Fib.java12
-rw-r--r--tests/bugs1612/pr351592/FibCaching.aj8
-rw-r--r--tests/bugs1612/pr351592/Test.java9
-rw-r--r--tests/bugs1612/pr351592_2/Caching.aj22
-rw-r--r--tests/bugs1612/pr351592_2/Fib.java8
-rw-r--r--tests/bugs1612/pr351592_2/FibCaching.aj8
-rw-r--r--tests/bugs1612/pr351592_2/Test.java8
8 files changed, 95 insertions, 0 deletions
diff --git a/tests/bugs1612/pr351592/Caching.aj b/tests/bugs1612/pr351592/Caching.aj
new file mode 100644
index 000000000..711c3a82e
--- /dev/null
+++ b/tests/bugs1612/pr351592/Caching.aj
@@ -0,0 +1,20 @@
+package caching;
+
+import java.util.HashMap;
+import java.util.Map;
+
+public aspect Caching {
+ private Map<Integer,Integer> cache = new HashMap<Integer,Integer>();
+
+ Integer around(Integer a): execution(* Fib.calc*(*)) && args(a) {
+ if(cache.containsKey(a)){
+ System.out.println("Using cached value for: " + a);
+ return cache.get(a);
+ }
+ else {
+ Integer result = proceed(a);
+ cache.put(a, result);
+ return result;
+ }
+ }
+}
diff --git a/tests/bugs1612/pr351592/Fib.java b/tests/bugs1612/pr351592/Fib.java
new file mode 100644
index 000000000..569ca46af
--- /dev/null
+++ b/tests/bugs1612/pr351592/Fib.java
@@ -0,0 +1,12 @@
+package caching;
+
+public class Fib {
+ public static int calc(int n){
+ if (n < 2) return 1;
+ return calc(n-1) + calc(n-2);
+ }
+ public static Integer calc2(Integer n){
+ if (n < 2) return 1;
+ return calc2(n-1) + calc2(n-2);
+ }
+}
diff --git a/tests/bugs1612/pr351592/FibCaching.aj b/tests/bugs1612/pr351592/FibCaching.aj
new file mode 100644
index 000000000..609fd1f06
--- /dev/null
+++ b/tests/bugs1612/pr351592/FibCaching.aj
@@ -0,0 +1,8 @@
+//package caching;
+//
+//public aspect FibCaching extends Caching<Integer,Integer> {
+//
+// pointcut cached() : execution(Integer Fib.calc(Integer));
+//
+//}
+
diff --git a/tests/bugs1612/pr351592/Test.java b/tests/bugs1612/pr351592/Test.java
new file mode 100644
index 000000000..071255820
--- /dev/null
+++ b/tests/bugs1612/pr351592/Test.java
@@ -0,0 +1,9 @@
+package caching;
+
+public class Test {
+
+ public static void main(String[] args) {
+ System.out.println(Fib.calc(30));
+ System.out.println(Fib.calc2(30));
+ }
+}
diff --git a/tests/bugs1612/pr351592_2/Caching.aj b/tests/bugs1612/pr351592_2/Caching.aj
new file mode 100644
index 000000000..7a2764e55
--- /dev/null
+++ b/tests/bugs1612/pr351592_2/Caching.aj
@@ -0,0 +1,22 @@
+package caching;
+
+import java.util.HashMap;
+import java.util.Map;
+
+public abstract aspect Caching<K,V> {
+ private Map<K,V> cache = new HashMap<K,V>();
+
+ abstract pointcut cached();
+
+ V around(K a): cached() && args(a) {
+ if(cache.containsKey(a)){
+ System.out.println("Using cached value for: " + a);
+ return cache.get(a);
+ }
+ else {
+ V result = proceed(a);
+ cache.put(a, result);
+ return result;
+ }
+ }
+}
diff --git a/tests/bugs1612/pr351592_2/Fib.java b/tests/bugs1612/pr351592_2/Fib.java
new file mode 100644
index 000000000..c78635557
--- /dev/null
+++ b/tests/bugs1612/pr351592_2/Fib.java
@@ -0,0 +1,8 @@
+package caching;
+
+public class Fib {
+ public static int calc(int n){
+ if (n < 2) return 1;
+ return calc(n-1) + calc(n-2);
+ }
+}
diff --git a/tests/bugs1612/pr351592_2/FibCaching.aj b/tests/bugs1612/pr351592_2/FibCaching.aj
new file mode 100644
index 000000000..6e1b1da79
--- /dev/null
+++ b/tests/bugs1612/pr351592_2/FibCaching.aj
@@ -0,0 +1,8 @@
+package caching;
+
+public aspect FibCaching extends Caching<Integer,Integer> {
+
+ pointcut cached() : execution(int Fib.calc(int));
+
+}
+
diff --git a/tests/bugs1612/pr351592_2/Test.java b/tests/bugs1612/pr351592_2/Test.java
new file mode 100644
index 000000000..1c9c8d275
--- /dev/null
+++ b/tests/bugs1612/pr351592_2/Test.java
@@ -0,0 +1,8 @@
+package caching;
+
+public class Test {
+
+ public static void main(String[] args) {
+ System.out.println(Fib.calc(30));
+ }
+}