01: /*
02: * The contents of this file are subject to the terms of the Common Development
03: * and Distribution License (the License). You may not use this file except in
04: * compliance with the License.
05: *
06: * You can obtain a copy of the License at http://www.netbeans.org/cddl.html
07: * or http://www.netbeans.org/cddl.txt.
08: *
09: * When distributing Covered Code, include this CDDL Header Notice in each file
10: * and include the License file at http://www.netbeans.org/cddl.txt.
11: * If applicable, add the following below the CDDL Header, with the fields
12: * enclosed by brackets [] replaced by your own identifying information:
13: * "Portions Copyrighted [year] [name of copyright owner]"
14: *
15: * The Original Software is NetBeans. The Initial Developer of the Original
16: * Software is Sun Microsystems, Inc. Portions Copyright 1997-2007 Sun
17: * Microsystems, Inc. All Rights Reserved.
18: */
19: package org.netbeans.modules.xslt.tmap.model.api;
20:
21: import org.netbeans.modules.xml.wsdl.model.ReferenceableWSDLComponent;
22: import org.netbeans.modules.xml.xam.Reference;
23:
24: /**
25: * This interface should be implemented by entities that refers to some other
26: * entities. They are contain reference to other OM element and when this
27: * element is changed in some way they should be changed. e.g. service contains
28: * reference to PartnerLInkType.
29: *
30: * @author Vitaly Bychkov
31: * @version 1.0
32: */
33: public interface ReferenceCollection {
34:
35: /**
36: *
37: * @return array of the references
38: */
39: Reference[] getReferences();
40:
41: /**
42: * Creates reference to specified WSDL OM referenceable element.
43: * @param <T> Referencable OM class.
44: * @param target Object for which needs to create reference.
45: * @param type Type of referenceable object.
46: * @return Reference to <code>target</code> object.
47: */
48: <T extends ReferenceableWSDLComponent> WSDLReference<T> createWSDLReference(
49: T target, Class<T> type);
50:
51: }
|