blob: b4a97ee31897bd16609989eded657280fa78fdb5 (
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
|
/*
Copyright (c) Xerox Corporation 1998-2002. All rights reserved.
Use and copying of this software and preparation of derivative works based
upon this software are permitted. Any distribution of this software or
derivative works must comply with all applicable United States export control
laws.
This software is made available AS IS, and Xerox Corporation makes no warranty
about the software, its performance or its conformity to any specification.
|<--- this code is formatted to fit into 80 columns --->|
|<--- this code is formatted to fit into 80 columns --->|
|<--- this code is formatted to fit into 80 columns --->|
*/
package tracing.version1;
/**
*
* This class connects the tracing functions in the Trace class with
* the constructors and methods in the application classes.
*
*/
import tracing.TwoDShape;
import tracing.Circle;
import tracing.Square;
import tracing.ExampleMain;
aspect TraceMyClasses {
/**
* Application classes.
*/
pointcut myClass(): within(TwoDShape) || within(Circle) || within(Square);
/**
* The constructors in those classes.
*/
pointcut myConstructor(): myClass() && execution(new(..));
/**
* The methods of those classes.
*/
pointcut myMethod(): myClass() && execution(* *(..));
/**
* Prints trace messages before and after executing constructors.
*/
before (): myConstructor() {
Trace.traceEntry("" + thisJoinPointStaticPart.getSignature());
}
after(): myConstructor() {
Trace.traceExit("" + thisJoinPointStaticPart.getSignature());
}
/**
* Prints trace messages before and after executing methods.
*/
before (): myMethod() {
Trace.traceEntry("" + thisJoinPointStaticPart.getSignature());
}
after(): myMethod() {
Trace.traceExit("" + thisJoinPointStaticPart.getSignature());
}
/**
* A main function for testing the trace aspect.
*/
public static void main(String[] args) {
Trace.TRACELEVEL = 2;
Trace.initStream(System.err);
ExampleMain.main(args);
}
}
|