aboutsummaryrefslogtreecommitdiffstats
path: root/tests/new/IfdefsAndAdvice.java
blob: 620070e2602adadcb672bdecf29181cce8186772 (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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
/* We would like to use some performance benchmarking as a way to determine
    if ajc is or is not generating the code for dynamic join points in all 
    cases except for m4().  However, HotSpot is too smart for us today, and
    manages to optimize this away.  Since the point of this code is that
    such an optimization is possible, I'm not sure that we can write a test case
    for this...

   So, this test case doesn't do all that good a job.
*/

import org.aspectj.testing.Tester;

public class IfdefsAndAdvice {
    public static void main(String[] args) {
	double t1 = timeIt(1);
	double t2 = timeIt(2);
	double t3 = timeIt(3);
	double t4 = timeIt(4);

	//System.out.println(t1 + ":" + t2 + ":" + t3 + ":" + t4); 
    }

    public static double timeIt(int m) {
	callIt(m);
	callIt(m);

	final int N = 1000;

	long startTime = System.currentTimeMillis();
	for (int i = 0; i < N; i++) { callIt(m); }
	long stopTime = System.currentTimeMillis();

	return (stopTime - startTime)/1000.0;
    }

    public static void callIt(int m) {
	switch(m) {
	case 1: m1(1,2,3,4,5,6,7,8,9,10);
	case 2: m2(1,2,3,4,5,6,7,8,9,10);
	case 3: m3(1,2,3,4,5,6,7,8,9,10);
	case 4: m4(1,2,3,4,5,6,7,8,9,10);
	}
    }


    public static int m1(int i1, int i2, int i3, int i4, int i5, int i6, int i7, int i8, int i9, int i10) {
	return i1+i2+i3+i4+i5+i6+i7+i8+i9+i10;
    }
    public static int m2(int i1, int i2, int i3, int i4, int i5, int i6, int i7, int i8, int i9, int i10) {
	return i1+i2+i3+i4+i5+i6+i7+i8+i9+i10;
    }
    public static int m3(int i1, int i2, int i3, int i4, int i5, int i6, int i7, int i8, int i9, int i10) {
	return i1+i2+i3+i4+i5+i6+i7+i8+i9+i10;
    }
    public static int m4(int i1, int i2, int i3, int i4, int i5, int i6, int i7, int i8, int i9, int i10) {
	return i1+i2+i3+i4+i5+i6+i7+i8+i9+i10;
    }
}

aspect A {
    static final boolean DEBUG = false;

    before (): execution(int m1(..)) {
	if (DEBUG) {
	    Object args = thisJoinPoint.getThis();
	} else {
	    String sig = thisJoinPoint.toString();
	}
    }

    before (): execution(int m2(..)) {
	if (DEBUG) {
	    Object args = thisJoinPoint.getThis();
	} 
    }

    before (): execution(int m3(..)) {
	if (!DEBUG) {
	    String sig = thisJoinPoint.toString();
	} else {
	    Object args = thisJoinPoint.getThis();
	}
    }

    before (): execution(int m4(..)) {
	if (!DEBUG) {
	    Object args = thisJoinPoint.getThis();
	} else {
	    String sig = thisJoinPoint.toString();
	}
    }
}