2 * Copyright 2001-2005 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
17 #include <cxxtest/TestSuite.h>
\r
18 #include <xmltooling/AbstractDOMCachingXMLObject.h>
\r
19 #include <xmltooling/exceptions.h>
\r
20 #include <xmltooling/XMLObjectBuilder.h>
\r
21 #include <xmltooling/XMLToolingConfig.h>
\r
22 #include <xmltooling/io/AbstractXMLObjectMarshaller.h>
\r
23 #include <xmltooling/io/AbstractXMLObjectUnmarshaller.h>
\r
24 #include <xmltooling/util/ParserPool.h>
\r
25 #include <xmltooling/util/XMLObjectChildrenList.h>
\r
26 #include <xmltooling/util/XMLHelper.h>
\r
28 using namespace xmltooling;
\r
29 using namespace std;
\r
31 extern ParserPool* validatingPool;
\r
32 extern ParserPool* nonvalidatingPool;
\r
33 extern string data_path;
\r
35 #if defined (_MSC_VER)
\r
36 #pragma warning( push )
\r
37 #pragma warning( disable : 4250 4251 )
\r
40 class SimpleXMLObjectUnmarshaller;
\r
42 class SimpleXMLObject : public AbstractDOMCachingXMLObject
\r
45 static const XMLCh NAMESPACE[];
\r
46 static const XMLCh NAMESPACE_PREFIX[];
\r
47 static const XMLCh LOCAL_NAME[];
\r
48 static const XMLCh ID_ATTRIB_NAME[];
\r
50 SimpleXMLObject() : AbstractDOMCachingXMLObject(NAMESPACE, LOCAL_NAME, NAMESPACE_PREFIX), m_id(NULL), m_value(NULL) {}
\r
51 virtual ~SimpleXMLObject() {
\r
52 XMLString::release(&m_id);
\r
53 XMLString::release(&m_value);
\r
56 const XMLCh* getId() const { return m_id; }
\r
57 void setId(const XMLCh* id) { m_id=prepareForAssignment(m_id,id); }
\r
59 const XMLCh* getValue() const { return m_value; }
\r
60 void setValue(const XMLCh* value) { m_value=prepareForAssignment(m_value,value); }
\r
62 // TODO: Leave non-const, but wrap STL container to intercept adds.
\r
63 ListOf(SimpleXMLObject) getSimpleXMLObjects() {
\r
64 return ListOf(SimpleXMLObject)(this, m_simples, m_children, m_children.end());
\r
67 SimpleXMLObject* clone() const {
\r
68 auto_ptr<XMLObject> domClone(AbstractDOMCachingXMLObject::clone());
\r
69 SimpleXMLObject* ret=dynamic_cast<SimpleXMLObject*>(domClone.get());
\r
75 ret=new SimpleXMLObject();
\r
77 ret->setValue(m_value);
\r
78 xmltooling::clone(m_children, ret->m_children);
\r
85 vector<SimpleXMLObject*> m_simples;
\r
87 friend class SimpleXMLObjectUnmarshaller;
\r
90 class SimpleXMLObjectBuilder : public XMLObjectBuilder
\r
93 XMLObject* buildObject() const {
\r
94 return new SimpleXMLObject();
\r
98 class SimpleXMLObjectMarshaller : public AbstractXMLObjectMarshaller
\r
101 SimpleXMLObjectMarshaller() : AbstractXMLObjectMarshaller(SimpleXMLObject::NAMESPACE, SimpleXMLObject::LOCAL_NAME) {}
\r
104 void marshallAttributes(const XMLObject& xmlObject, DOMElement* domElement) const {
\r
105 const SimpleXMLObject& simpleXMLObject = dynamic_cast<const SimpleXMLObject&>(xmlObject);
\r
107 if(simpleXMLObject.getId()) {
\r
108 domElement->setAttributeNS(NULL, SimpleXMLObject::ID_ATTRIB_NAME, simpleXMLObject.getId());
\r
109 domElement->setIdAttributeNS(NULL, SimpleXMLObject::ID_ATTRIB_NAME);
\r
113 void marshallElementContent(const XMLObject& xmlObject, DOMElement* domElement) const {
\r
114 const SimpleXMLObject& simpleXMLObject = dynamic_cast<const SimpleXMLObject&>(xmlObject);
\r
116 if(simpleXMLObject.getValue()) {
\r
117 domElement->setTextContent(simpleXMLObject.getValue());
\r
122 class SimpleXMLObjectUnmarshaller : public AbstractXMLObjectUnmarshaller
\r
125 SimpleXMLObjectUnmarshaller() : AbstractXMLObjectUnmarshaller(SimpleXMLObject::NAMESPACE, SimpleXMLObject::LOCAL_NAME) {}
\r
128 void processChildElement(XMLObject& parentXMLObject, XMLObject* childXMLObject) const {
\r
129 SimpleXMLObject& simpleXMLObject = dynamic_cast<SimpleXMLObject&>(parentXMLObject);
\r
131 SimpleXMLObject* child = dynamic_cast<SimpleXMLObject*>(childXMLObject);
\r
133 simpleXMLObject.m_children.push_back(child);
\r
134 simpleXMLObject.m_simples.push_back(child);
\r
137 throw UnmarshallingException("Unknown child element cannot be added to parent object.");
\r
141 void processAttribute(XMLObject& xmlObject, const DOMAttr* attribute) const {
\r
142 SimpleXMLObject& simpleXMLObject = dynamic_cast<SimpleXMLObject&>(xmlObject);
\r
144 if (XMLString::equals(attribute->getLocalName(),SimpleXMLObject::ID_ATTRIB_NAME)) {
\r
145 simpleXMLObject.setId(attribute->getValue());
\r
148 throw UnmarshallingException("Unknown attribute cannot be processed by parent object.");
\r
152 void processElementContent(XMLObject& xmlObject, const XMLCh* elementContent) const {
\r
153 SimpleXMLObject& simpleXMLObject = dynamic_cast<SimpleXMLObject&>(xmlObject);
\r
155 simpleXMLObject.setValue(elementContent);
\r
161 #if defined (_MSC_VER)
\r
162 #pragma warning( pop )
\r