2 * Copyright 2001-2006 Internet2
\r
4 * Licensed under the Apache License, Version 2.0 (the "License");
\r
5 * you may not use this file except in compliance with the License.
\r
6 * You may obtain a copy of the License at
\r
8 * http://www.apache.org/licenses/LICENSE-2.0
\r
10 * Unless required by applicable law or agreed to in writing, software
\r
11 * distributed under the License is distributed on an "AS IS" BASIS,
\r
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
\r
13 * See the License for the specific language governing permissions and
\r
14 * limitations under the License.
\r
18 * @file UnknownElement.h
\r
20 * Basic implementations suitable for use as defaults for unrecognized content
\r
23 #if !defined(__xmltooling_unkelement_h__)
\r
24 #define __xmltooling_unkelement_h__
\r
26 #include "internal.h"
\r
27 #include "AbstractDOMCachingXMLObject.h"
\r
28 #include "XMLObjectBuilder.h"
\r
29 #include "io/Marshaller.h"
\r
30 #include "io/Unmarshaller.h"
\r
34 #if defined (_MSC_VER)
\r
35 #pragma warning( push )
\r
36 #pragma warning( disable : 4250 4251 )
\r
39 namespace xmltooling {
\r
42 * Implementation class for unrecognized DOM elements.
\r
43 * Purpose is to wrap the DOM and do any necessary caching/reconstruction
\r
44 * when a DOM has to cross into a new document.
\r
46 class XMLTOOL_DLLLOCAL UnknownElementImpl : public AbstractDOMCachingXMLObject
\r
50 * Overridden to ensure XML content of DOM isn't lost.
\r
52 * @see DOMCachingXMLObject::releaseDOM()
\r
57 * @see XMLObject::clone()
\r
59 XMLObject* clone() const;
\r
63 * When needed, we can serialize the DOM into XML form and preserve it here.
\r
68 void serialize(std::string& s) const;
\r
69 friend class XMLTOOL_API UnknownElementMarshaller;
\r
73 * Factory for UnknownElementImpl objects
\r
75 class XMLTOOL_DLLLOCAL UnknownElementBuilder : public virtual XMLObjectBuilder
\r
79 * @see XMLObjectBuilder::buildObject()
\r
81 XMLObject* buildObject() const {
\r
82 return new UnknownElementImpl();
\r
87 * Marshaller for UnknownElementImpl objects
\r
89 class XMLTOOL_DLLLOCAL UnknownElementMarshaller : public virtual Marshaller
\r
93 * @see Marshaller::marshall(XMLObject*,DOMDocument*)
\r
95 DOMElement* marshall(XMLObject* xmlObject, DOMDocument* document=NULL) const;
\r
98 * @see Marshaller::marshall(XMLObject*,DOMElement*)
\r
100 DOMElement* marshall(XMLObject* xmlObject, DOMElement* parentElement) const;
\r
103 void setDocumentElement(DOMDocument* document, DOMElement* element) const {
\r
104 DOMElement* documentRoot = document->getDocumentElement();
\r
106 document->replaceChild(documentRoot, element);
\r
108 document->appendChild(element);
\r
113 * Marshaller for UnknownElementImpl objects
\r
115 class XMLTOOL_DLLLOCAL UnknownElementUnmarshaller : public virtual Unmarshaller
\r
119 * @see Unmarshaller::unmarshall()
\r
121 XMLObject* unmarshall(DOMElement* element, bool bindDocument=false) const;
\r
125 #if defined (_MSC_VER)
\r
126 #pragma warning( pop )
\r
129 #endif /* __xmltooling_unkelement_h__ */
\r