1 /**
2 * Redistribution and use of this software and associated documentation ("Software"), with or
3 * without modification, are permitted provided that the following conditions are met:
4 *
5 * 1. Redistributions of source code must retain copyright statements and notices. Redistributions
6 * must also contain a copy of this document.
7 *
8 * 2. Redistributions in binary form must reproduce the above copyright notice, this list of
9 * conditions and the following disclaimer in the documentation and/or other materials provided with
10 * the distribution.
11 *
12 * 3. The name "Exolab" must not be used to endorse or promote products derived from this Software
13 * without prior written permission of Intalio, Inc. For written permission, please contact
14 * info@exolab.org.
15 *
16 * 4. Products derived from this Software may not be called "Exolab" nor may "Exolab" appear in
17 * their names without prior written permission of Intalio, Inc. Exolab is a registered trademark of
18 * Intalio, Inc.
19 *
20 * 5. Due credit should be given to the Exolab Project (http://www.exolab.org/).
21 *
22 * THIS SOFTWARE IS PROVIDED BY INTALIO, INC. AND CONTRIBUTORS ``AS IS'' AND ANY EXPRESSED OR
23 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
24 * FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTALIO, INC. OR ITS
25 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
28 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY
29 * WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30 *
31 * Copyright 1999-2003 (C) Intalio, Inc. All Rights Reserved.
32 *
33 * $Id$
34 */
35
36 package org.exolab.castor.xml.schema;
37
38 import java.util.HashMap;
39 import java.util.HashSet;
40 import java.util.Map;
41 import java.util.Set;
42
43 import org.castor.core.nature.PropertyHolder;
44
45
46 /**
47 * A class which represents the AppInfo element
48 *
49 * @author <a href="mailto:kvisco@intalio.com">Keith Visco</a>
50 * @version $Revision$ $Date: 2005-12-13 14:58:48 -0700 (Tue, 13 Dec 2005) $
51 * @see AnnotationItem
52 */
53 public class AppInfo extends AnnotationItem implements PropertyHolder {
54 /** SerialVersionUID */
55 private static final long serialVersionUID = -8678983924238645714L;
56
57 /**
58 * Map holding the available natures.
59 */
60 private Set<String> _natures = new HashSet<String>();
61
62 /**
63 * Map holding the properties set and read by natures.
64 */
65 private Map<String, Object> _properties = new HashMap<String, Object>();
66
67 /**
68 * Creates a new AppInfo
69 */
70 public AppInfo() {
71 super();
72
73 }
74
75 /**
76 * Returns the type of this Schema Structure
77 *
78 * @return the type of this Schema Structure
79 */
80 public short getStructureType() {
81 return Structure.APPINFO;
82 }
83
84 /**
85 * @see org.exolab.castor.builder.info.nature.PropertyHolder# getProperty(java.lang.String)
86 * @param name of the property
87 * @return value of the property
88 */
89 public Object getProperty(final String name) {
90 return _properties.get(name);
91 }
92
93 /**
94 * @see org.exolab.castor.builder.info.nature.PropertyHolder# setProperty(java.lang.String,
95 * java.lang.Object)
96 * @param name of the property
97 * @param value of the property
98 */
99 public void setProperty(final String name, final Object value) {
100 _properties.put(name, value);
101 }
102
103 /**
104 * @see org.exolab.castor.builder.info.nature.NatureExtendable# addNature(java.lang.String)
105 * @param nature ID of the Nature
106 */
107 public void addNature(final String nature) {
108 _natures.add(nature);
109 }
110
111 /**
112 * @see org.exolab.castor.builder.info.nature.NatureExtendable# hasNature(java.lang.String)
113 * @param nature ID of the Nature
114 * @return true if the Nature ID was added.
115 */
116 public boolean hasNature(final String nature) {
117 return _natures.contains(nature);
118 }
119
120
121 }