aboutsummaryrefslogtreecommitdiffstats
path: root/docs/dist/doc/examples/telecom/Timing.java
blob: 29eba02eaf6a75ba2abc57f68d3489efebb5348c (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
/*
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.
*/

package telecom;

/**
 * The Timing aspect is concerned with the duration
 * of connections and with customer's cumulative
 * connection time.
 */
public aspect Timing {

    /**
     * Every Customer has a total connection time
     */
    public long Customer.totalConnectTime = 0;

    public long getTotalConnectTime(Customer cust) {
        return cust.totalConnectTime;
    }
    /**
     * Every connection has a timer
     */
    private Timer Connection.timer = new Timer();
    public Timer getTimer(Connection conn) { return conn.timer; }

    /**
     * Start the timer when call completed
     */
    after (Connection c): target(c) && call(void Connection.complete()) {
        getTimer(c).start();
    }

    /**
     * When to stop the timer
     */
    pointcut endTiming(Connection c): target(c) &&
        call(void Connection.drop());

    /**
     * Stop the timer when call dropped and update the involved parties
     */
    after(Connection c): endTiming(c) {
        getTimer(c).stop();
        c.getCaller().totalConnectTime += getTimer(c).getTime();
        c.getReceiver().totalConnectTime += getTimer(c).getTime();
    }
}