1. /*
  2. * The Apache Software License, Version 1.1
  3. *
  4. *
  5. * Copyright (c) 2002-2004 The Apache Software Foundation. All rights
  6. * reserved.
  7. *
  8. * Redistribution and use in source and binary forms, with or without
  9. * modification, are permitted provided that the following conditions
  10. * are met:
  11. *
  12. * 1. Redistributions of source code must retain the above copyright
  13. * notice, this list of conditions and the following disclaimer.
  14. *
  15. * 2. Redistributions in binary form must reproduce the above copyright
  16. * notice, this list of conditions and the following disclaimer in
  17. * the documentation and/or other materials provided with the
  18. * distribution.
  19. *
  20. * 3. The end-user documentation included with the redistribution,
  21. * if any, must include the following acknowledgment:
  22. * "This product includes software developed by the
  23. * Apache Software Foundation (http://www.apache.org/)."
  24. * Alternately, this acknowledgment may appear in the software itself,
  25. * if and wherever such third-party acknowledgments normally appear.
  26. *
  27. * 4. The names "Xerces" and "Apache Software Foundation" must
  28. * not be used to endorse or promote products derived from this
  29. * software without prior written permission. For written
  30. * permission, please contact apache@apache.org.
  31. *
  32. * 5. Products derived from this software may not be called "Apache",
  33. * nor may "Apache" appear in their name, without prior written
  34. * permission of the Apache Software Foundation.
  35. *
  36. * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
  37. * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  38. * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  39. * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
  40. * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  41. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  42. * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
  43. * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
  44. * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  45. * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
  46. * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  47. * SUCH DAMAGE.
  48. * ====================================================================
  49. *
  50. * This software consists of voluntary contributions made by many
  51. * individuals on behalf of the Apache Software Foundation and was
  52. * originally based on software copyright (c) 1999, International
  53. * Business Machines, Inc., http://www.apache.org. For more
  54. * information on the Apache Software Foundation, please see
  55. * <http://www.apache.org/>.
  56. */
  57. package com.sun.org.apache.xerces.internal.dom;
  58. import java.io.IOException;
  59. import java.io.NotSerializableException;
  60. import java.io.ObjectInputStream;
  61. import java.io.ObjectOutputStream;
  62. // REVISIT: This is a HACK! DO NOT MODIFY THIS import.
  63. // It allows us to expose DOM L3 implemenation via org.w3c.dom packages
  64. import org.w3c.dom.DOMConfiguration;
  65. import org.w3c.dom.UserDataHandler;
  66. import org.w3c.dom.*;
  67. /**
  68. * Our own document implementation, which knows how to create an element
  69. * with PSVI information.
  70. *
  71. * @author Sandy Gao, IBM
  72. *
  73. * @version $Id: PSVIDocumentImpl.java,v 1.9 2004/04/15 18:38:22 mrglavas Exp $
  74. */
  75. public class PSVIDocumentImpl extends DocumentImpl {
  76. /** Serialization version. */
  77. static final long serialVersionUID = -8822220250676434522L;
  78. /**
  79. * Create a document.
  80. */
  81. public PSVIDocumentImpl() {
  82. super();
  83. }
  84. /**
  85. * For DOM2 support.
  86. * The createDocument factory method is in DOMImplementation.
  87. */
  88. public PSVIDocumentImpl(DocumentType doctype) {
  89. super(doctype);
  90. }
  91. /**
  92. * Deep-clone a document, including fixing ownerDoc for the cloned
  93. * children. Note that this requires bypassing the WRONG_DOCUMENT_ERR
  94. * protection. I've chosen to implement it by calling importNode
  95. * which is DOM Level 2.
  96. *
  97. * @return org.w3c.dom.Node
  98. * @param deep boolean, iff true replicate children
  99. */
  100. public Node cloneNode(boolean deep) {
  101. PSVIDocumentImpl newdoc = new PSVIDocumentImpl();
  102. callUserDataHandlers(this, newdoc, UserDataHandler.NODE_CLONED);
  103. cloneNode(newdoc, deep);
  104. // experimental
  105. newdoc.mutationEvents = mutationEvents;
  106. return newdoc;
  107. } // cloneNode(boolean):Node
  108. /**
  109. * Retrieve information describing the abilities of this particular
  110. * DOM implementation. Intended to support applications that may be
  111. * using DOMs retrieved from several different sources, potentially
  112. * with different underlying representations.
  113. */
  114. public DOMImplementation getImplementation() {
  115. // Currently implemented as a singleton, since it's hardcoded
  116. // information anyway.
  117. return PSVIDOMImplementationImpl.getDOMImplementation();
  118. }
  119. /**
  120. * Create an element with PSVI information
  121. */
  122. public Element createElementNS(String namespaceURI, String qualifiedName)
  123. throws DOMException {
  124. return new PSVIElementNSImpl(this, namespaceURI, qualifiedName);
  125. }
  126. /**
  127. * Create an element with PSVI information
  128. */
  129. public Element createElementNS(String namespaceURI, String qualifiedName,
  130. String localpart) throws DOMException {
  131. return new PSVIElementNSImpl(this, namespaceURI, qualifiedName, localpart);
  132. }
  133. /**
  134. * Create an attribute with PSVI information
  135. */
  136. public Attr createAttributeNS(String namespaceURI, String qualifiedName)
  137. throws DOMException {
  138. return new PSVIAttrNSImpl(this, namespaceURI, qualifiedName);
  139. }
  140. /**
  141. * Create an attribute with PSVI information
  142. */
  143. public Attr createAttributeNS(String namespaceURI, String qualifiedName,
  144. String localName) throws DOMException {
  145. return new PSVIAttrNSImpl(this, namespaceURI, qualifiedName, localName);
  146. }
  147. /**
  148. *
  149. * The configuration used when <code>Document.normalizeDocument</code> is
  150. * invoked.
  151. * @since DOM Level 3
  152. */
  153. public DOMConfiguration getDomConfig(){
  154. super.getDomConfig();
  155. return fConfiguration;
  156. }
  157. // REVISIT: Forbid serialization of PSVI DOM until
  158. // we support object serialization of grammars -- mrglavas
  159. private void writeObject(ObjectOutputStream out)
  160. throws IOException {
  161. throw new NotSerializableException(getClass().getName());
  162. }
  163. private void readObject(ObjectInputStream in)
  164. throws IOException, ClassNotFoundException {
  165. throw new NotSerializableException(getClass().getName());
  166. }
  167. } // class PSVIDocumentImpl