KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > com > jcorporate > expresso > kernel > EmbeddedComponent


1 /* ====================================================================
2  * The Jcorporate Apache Style Software License, Version 1.2 05-07-2002
3  *
4  * Copyright (c) 1995-2002 Jcorporate Ltd. All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without
7  * modification, are permitted provided that the following conditions
8  * are met:
9  *
10  * 1. Redistributions of source code must retain the above copyright
11  * notice, this list of conditions and the following disclaimer.
12  *
13  * 2. Redistributions in binary form must reproduce the above copyright
14  * notice, this list of conditions and the following disclaimer in
15  * the documentation and/or other materials provided with the
16  * distribution.
17  *
18  * 3. The end-user documentation included with the redistribution,
19  * if any, must include the following acknowledgment:
20  * "This product includes software developed by Jcorporate Ltd.
21  * (http://www.jcorporate.com/)."
22  * Alternately, this acknowledgment may appear in the software itself,
23  * if and wherever such third-party acknowledgments normally appear.
24  *
25  * 4. "Jcorporate" and product names such as "Expresso" must
26  * not be used to endorse or promote products derived from this
27  * software without prior written permission. For written permission,
28  * please contact info@jcorporate.com.
29  *
30  * 5. Products derived from this software may not be called "Expresso",
31  * or other Jcorporate product names; nor may "Expresso" or other
32  * Jcorporate product names appear in their name, without prior
33  * written permission of Jcorporate Ltd.
34  *
35  * 6. No product derived from this software may compete in the same
36  * market space, i.e. framework, without prior written permission
37  * of Jcorporate Ltd. For written permission, please contact
38  * partners@jcorporate.com.
39  *
40  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
41  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
42  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
43  * DISCLAIMED. IN NO EVENT SHALL JCORPORATE LTD OR ITS CONTRIBUTORS
44  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
45  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
46  * TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
47  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
48  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
49  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
50  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
51  * SUCH DAMAGE.
52  * ====================================================================
53  *
54  * This software consists of voluntary contributions made by many
55  * individuals on behalf of the Jcorporate Ltd. Contributions back
56  * to the project(s) are encouraged when you make modifications.
57  * Please send them to support@jcorporate.com. For more information
58  * on Jcorporate Ltd. and its products, please see
59  * <http://www.jcorporate.com/>.
60  *
61  * Portions of this software are based upon other open source
62  * products and are subject to their respective licenses.
63  */

64
65 package com.jcorporate.expresso.kernel;
66
67 import com.jcorporate.expresso.kernel.metadata.ComponentMetadata;
68
69 import java.util.Iterator JavaDoc;
70
71 /**
72  * An <code>Embedded Component</code> is a component that is (1) Not a container
73  * and (2) it's metadata is embedded within the metadata of its parent. This
74  * allows for the guarantee that if one component is installed that it can bring
75  * its required components with it. An example is PersistenceManager
76  *
77  * @author Michael Rimov
78  * @see com.jcorporate.expresso.core.dataobjects.PersistenceManager
79  */

80
81 abstract public class EmbeddedComponent implements ExpressoComponent {
82
83     /**
84      * Cached metadata once we've looked it up from the parent
85      */

86     private ComponentMetadata myMetadata = null;
87
88     /**
89      * Parent Container Reference
90      */

91
92     private Containable myParent = null;
93
94
95     /**
96      * Default Do Nothing Constructor
97      */

98     public EmbeddedComponent() {
99     }
100
101     /**
102      * Because we look up our metadata in the parent component, we have to
103      * somehow know WHAT component's metadata is ours. Sub classes need to
104      * override this one-liner and return the name of the metadata we're
105      * looking for.
106      *
107      * @return java.lang.String
108      */

109     abstract public String JavaDoc getMetadataName();
110
111     /**
112      * Returns the metadata by retrieving the appropriate metadata from the parent
113      *
114      * @return ComponentMetadata for this component.
115      * @throws IllegalArgumentException if the parent cannot be queried for the
116      * appropriate metadata
117      */

118     public synchronized ComponentMetadata getMetaData() {
119         if (myMetadata == null) {
120             ExpressoComponent ec = (ExpressoComponent) this.getParent();
121             ComponentMetadata parentMetadata = ec.getMetaData();
122
123             for (Iterator JavaDoc i = parentMetadata.getChildren().iterator(); i.hasNext();) {
124                 ComponentMetadata oneChild = (ComponentMetadata) i.next();
125                 if (this.getMetadataName().equals(oneChild.getName())) {
126                     myMetadata = oneChild;
127                     break;
128                 }
129             }
130
131             if (myMetadata == null) {
132                 throw new IllegalArgumentException JavaDoc("Unable to find metadata " +
133                         "in parent corresponding to component named: "
134                         + this.getMetadataName());
135             }
136         }
137
138         return myMetadata;
139     }
140
141
142     /**
143      * Retrieve the parent component [if any]. May return null.
144      *
145      * @return ExpressoComponent or null
146      */

147     public synchronized Containable getParent() {
148         return myParent;
149     }
150
151     /**
152      * Called by the parent upon initial Expresso component creation so that the
153      * child component can find it's container.
154      *
155      * @param parent the 'containing' component.
156      */

157     public synchronized void setParent(Containable parent) {
158         myParent = parent;
159     }
160
161
162 }
Popular Tags