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.components.interfaces.Apu;
29: import org.jicarilla.container.tck.components.interfaces.HotdogBuyer;
30: import org.jicarilla.lang.CascadingRuntimeException;
31:
32: import java.lang.reflect.Method;
33:
34: /**
35: *
36: *
37: * @author <a href="lsimons at jicarilla dot org">Leo Simons</a>
38: * @version $Id: AbstractApu.java,v 1.4 2004/03/23 13:37:54 lsimons Exp $
39: */
40: public abstract class AbstractApu extends AbstractComponent implements
41: Apu {
42: // ----------------------------------------------------------------------
43: // Poor-Man's Invocation Logging
44: // ----------------------------------------------------------------------
45: public final static Method sellHotDog;
46: static {
47: try {
48: sellHotDog = AbstractApu.class.getMethod("sellHotDog",
49: new Class[] { HotdogBuyer.class });
50: } catch (NoSuchMethodException e) {
51: throw new CascadingRuntimeException(e.getMessage(), e);
52: }
53: }
54:
55: public void sellHotDog(HotdogBuyer customer) {
56: super .log(sellHotDog, customer);
57: customer.buyHotdog(new Hotdog());
58: }
59:
60: public class Hotdog {
61: }
62: }
|