01: /*
02: * <copyright>
03: *
04: * Copyright 1997-2004 BBNT Solutions, LLC
05: * under sponsorship of the Defense Advanced Research Projects
06: * Agency (DARPA).
07: *
08: * You can redistribute this software and/or modify it under the
09: * terms of the Cougaar Open Source License as published on the
10: * Cougaar Open Source Website (www.cougaar.org).
11: *
12: * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
13: * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
14: * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
15: * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
16: * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
17: * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
18: * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
19: * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
20: * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
21: * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
22: * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
23: *
24: * </copyright>
25: */
26:
27: package org.cougaar.mts.std;
28:
29: import java.net.URI;
30:
31: import org.cougaar.core.mts.MessageAddress;
32: import org.cougaar.mts.base.NameSupport;
33: import org.cougaar.mts.base.NameSupportDelegateImplBase;
34: import org.cougaar.mts.base.StandardAspect;
35:
36: /**
37: * This debugging Aspect logs URIs and stubs of local and remote
38: * references, respectively.
39: */
40: public class StubDumperAspect extends StandardAspect {
41:
42: public StubDumperAspect() {
43: super ();
44: }
45:
46: public Object getDelegate(Object delegate, Class type) {
47: if (type == NameSupport.class) {
48: return new NameSupportDelegate((NameSupport) delegate);
49: } else {
50: return null;
51: }
52: }
53:
54: public class NameSupportDelegate extends
55: NameSupportDelegateImplBase {
56:
57: public NameSupportDelegate(NameSupport nameSupport) {
58: super (nameSupport);
59: }
60:
61: public void registerAgentInNameServer(URI reference,
62: MessageAddress address, String protocol) {
63: super .registerAgentInNameServer(reference, address,
64: protocol);
65:
66: loggingService.info("\nRegistering " + address + " for "
67: + protocol + " = [" + reference + "]");
68: }
69:
70: public URI lookupAddressInNameServer(MessageAddress address,
71: String protocol) {
72: URI result = super .lookupAddressInNameServer(address,
73: protocol);
74: loggingService.info("\nLookup " + address + " for "
75: + protocol + " = [" + result + "]");
76: return result;
77: }
78:
79: }
80:
81: }
|