/castor-1.3.2/schema/src/main/java/org/exolab/castor/xml/schema/Annotation.java

# · Java · 145 lines · 40 code · 15 blank · 90 comment · 8 complexity · cb5318767beee846fc6c586913d366cd MD5 · raw file

  1. /**
  2. * Redistribution and use of this software and associated documentation
  3. * ("Software"), with or without modification, are permitted provided
  4. * that the following conditions are met:
  5. *
  6. * 1. Redistributions of source code must retain copyright
  7. * statements and notices. Redistributions must also contain a
  8. * copy of this document.
  9. *
  10. * 2. Redistributions in binary form must reproduce the
  11. * above copyright notice, this list of conditions and the
  12. * following disclaimer in the documentation and/or other
  13. * materials provided with the distribution.
  14. *
  15. * 3. The name "Exolab" must not be used to endorse or promote
  16. * products derived from this Software without prior written
  17. * permission of Intalio, Inc. For written permission,
  18. * please contact info@exolab.org.
  19. *
  20. * 4. Products derived from this Software may not be called "Exolab"
  21. * nor may "Exolab" appear in their names without prior written
  22. * permission of Intalio, Inc. Exolab is a registered
  23. * trademark of Intalio, Inc.
  24. *
  25. * 5. Due credit should be given to the Exolab Project
  26. * (http://www.exolab.org/).
  27. *
  28. * THIS SOFTWARE IS PROVIDED BY INTALIO, INC. AND CONTRIBUTORS
  29. * ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT
  30. * NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
  31. * FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
  32. * INTALIO, INC. OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
  33. * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
  34. * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
  35. * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  36. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
  37. * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  38. * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
  39. * OF THE POSSIBILITY OF SUCH DAMAGE.
  40. *
  41. * Copyright 1999 (C) Intalio, Inc. All Rights Reserved.
  42. *
  43. * $Id: Annotation.java 7996 2008-12-16 08:25:44Z wguttmn $
  44. */
  45. package org.exolab.castor.xml.schema;
  46. import org.exolab.castor.xml.ValidationException;
  47. import java.util.Enumeration;
  48. import java.util.Vector;
  49. /**
  50. * A class representing the XML Schema Annotation.
  51. * @author <a href="mailto:kvisco@intalio.com">Keith Visco</a>
  52. * @version $Revision: 7996 $ $Date: 2005-12-13 14:58:48 -0700 (Tue, 13 Dec 2005) $
  53. **/
  54. public class Annotation extends Structure {
  55. /** SerialVersionUID */
  56. private static final long serialVersionUID = 2838816224303555598L;
  57. /**
  58. * List of {@literal <appinfo/>} objects.
  59. **/
  60. private Vector<AppInfo> _appInfos = new Vector<AppInfo>();
  61. /**
  62. * List of <documentation/> objects.
  63. **/
  64. private Vector<Documentation> _documentations = new Vector<Documentation>();
  65. /**
  66. * Adds the given {@link AppInfo} to this annotation.
  67. * @param appInfo the AppInfo to add
  68. **/
  69. public void addAppInfo(final AppInfo appInfo) {
  70. if (appInfo != null) {
  71. _appInfos.addElement(appInfo);
  72. }
  73. }
  74. /**
  75. * Adds the given Documentation to this Annotation.
  76. * @param documentation the documentation to add to this Annotation
  77. **/
  78. public void addDocumentation(final Documentation documentation) {
  79. if (documentation != null) {
  80. _documentations.addElement(documentation);
  81. }
  82. }
  83. /**
  84. * Returns an enumeration of all {@link AppInfo} elements for this Annotation.
  85. * @return an enumeration of all {@link AppInfo} elements for this Annotation
  86. **/
  87. public Enumeration<AppInfo> getAppInfo() {
  88. return _appInfos.elements();
  89. }
  90. /**
  91. * Returns an enumeration of all documentation elements for this Annotation.
  92. * @return an enumeration of all documentation elements for this Annotation
  93. **/
  94. public Enumeration<Documentation> getDocumentation() {
  95. return _documentations.elements();
  96. }
  97. /**
  98. * Removes the given AppInfo from this Annotation.
  99. * @param appInfo the AppInfo to remove
  100. **/
  101. public void removeAppInfo(final AppInfo appInfo) {
  102. if (appInfo != null) {
  103. _appInfos.removeElement(appInfo);
  104. }
  105. }
  106. /**
  107. * Removes the given {@link Documentation} from this Annotation.
  108. * @param documentation the Documentation to remove
  109. **/
  110. public void removeDocumentation(final Documentation documentation) {
  111. if (documentation != null) {
  112. _documentations.removeElement(documentation);
  113. }
  114. }
  115. /**
  116. * Returns the type of this Schema Structure.
  117. * @return the type of this Schema Structure
  118. **/
  119. public short getStructureType() {
  120. return Structure.ANNOTATION;
  121. }
  122. /**
  123. * Checks the validity of this Schema definition.
  124. * @exception ValidationException when this Schema definition
  125. * is invalid.
  126. **/
  127. public void validate() throws ValidationException {
  128. // -- do nothing
  129. }
  130. }