01: /* ====================================================================
02: The Jicarilla Software License
03:
04: Copyright (c) 2003 Leo Simons.
05: All rights reserved.
06:
07: Permission is hereby granted, free of charge, to any person obtaining
08: a copy of this software and associated documentation files (the
09: "Software"), to deal in the Software without restriction, including
10: without limitation the rights to use, copy, modify, merge, publish,
11: distribute, sublicense, and/or sell copies of the Software, and to
12: permit persons to whom the Software is furnished to do so, subject to
13: the following conditions:
14:
15: The above copyright notice and this permission notice shall be
16: included in all copies or substantial portions of the Software.
17:
18: THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
19: EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
20: MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
21: IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
22: CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
23: TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
24: SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
25: ==================================================================== */
26: package org.jicarilla.container.tck.components;
27:
28: import org.jicarilla.container.tck.util.DefaultInvocationRecorder;
29: import org.jicarilla.container.tck.util.InvocationRecorder;
30: import org.jicarilla.container.tck.util.InvocationRecorderProvider;
31: import org.jicarilla.container.tck.util.MemberInvocation;
32:
33: import java.lang.reflect.Method;
34:
35: /**
36: *
37: *
38: * @author <a href="lsimons at jicarilla dot org">Leo Simons</a>
39: * @version $Id: AbstractComponent.java,v 1.3 2004/01/18 19:32:04 lsimons Exp $
40: */
41: public class AbstractComponent implements InvocationRecorderProvider {
42: // ----------------------------------------------------------------------
43: // Poor-Man's Invocation Logging
44: // ----------------------------------------------------------------------
45: protected final InvocationRecorder logger = new DefaultInvocationRecorder();
46: protected static InvocationRecorder aggregateLogger = new DefaultInvocationRecorder();
47:
48: public InvocationRecorder getLogger() {
49: return logger;
50: }
51:
52: public final void log(Method m, Object[] args) {
53: MemberInvocation invocation = new MemberInvocation(this , this ,
54: m, args);
55: log(invocation);
56: }
57:
58: public final void log(Method m, Object arg) {
59: MemberInvocation invocation = new MemberInvocation(this , this ,
60: m, new Object[] { arg });
61: log(invocation);
62: }
63:
64: public final void log(Method m) {
65: MemberInvocation invocation = new MemberInvocation(this , this ,
66: m, new Object[0]);
67: log(invocation);
68: }
69:
70: protected void log(MemberInvocation invocation) {
71: logger.log(invocation);
72: aggregateLogger.log(invocation);
73: }
74:
75: public final static void resetLogger() {
76: aggregateLogger = new DefaultInvocationRecorder();
77: }
78:
79: public final static InvocationRecorder getAggregateLogger() {
80: return aggregateLogger;
81: }
82: }
|