Initial DOM handling interfaces.
[shibboleth/xmltooling.git] / xmltooling / DOMCachingXMLObject.h
1 /*\r
2  *  Copyright 2001-2006 Internet2\r
3  * \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
7  *\r
8  *     http://www.apache.org/licenses/LICENSE-2.0\r
9  *\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
15  */\r
16 \r
17 /**\r
18  * @file DOMCachingXMLObject.h\r
19  * \r
20  * An XMLObject that can cached a DOM representation of itself. \r
21  */\r
22 \r
23 #if !defined(__xmltooling_domxmlobj_h__)\r
24 #define __xmltooling_domxmlobj_h__\r
25 \r
26 #include <xercesc/dom/DOM.hpp>\r
27 #include <xmltooling/XMLObject.h>\r
28 \r
29 using namespace xercesc;\r
30 \r
31 namespace xmltooling {\r
32 \r
33     /**\r
34      * An XMLObject that can cached a DOM representation of itself.\r
35      */\r
36     class XMLTOOL_API DOMCachingXMLObject : public virtual XMLObject\r
37     {\r
38     public:\r
39         DOMCachingXMLObject() {}\r
40         virtual ~DOMCachingXMLObject() {}\r
41         \r
42         /**\r
43          * Gets the DOM representation of this XMLObject, if one exists.\r
44          * \r
45          * @return the DOM representation of this XMLObject\r
46          */\r
47         virtual const DOMElement* getDOM() const=0;\r
48         \r
49         /**\r
50          * Sets the DOM representation of this XMLObject.\r
51          * \r
52          * @param dom DOM representation of this XMLObject\r
53          */\r
54         virtual void setDOM(DOMElement* dom)=0;\r
55     \r
56         /**\r
57          * Assigns ownership of a DOM document to the XMLObject.\r
58          * This binds the lifetime of the document to the lifetime of the object.\r
59          * \r
60          * @param doc DOM document bound to this object \r
61          */\r
62         virtual DOMDocument* setDocument(DOMDocument* doc)=0;\r
63 \r
64         /**\r
65          * Releases the DOM representation of this XMLObject, if there is one.\r
66          */\r
67         virtual void releaseDOM()=0;\r
68         \r
69         /**\r
70          * Releases the DOM representation of this XMLObject's parent.\r
71          * \r
72          * @param propagateRelease true if all ancestors of this element should release their DOM\r
73          */\r
74         virtual void releaseParentDOM(bool propagateRelease=true)=0;\r
75         \r
76         /**\r
77          * Releases the DOM representation of this XMLObject's children.\r
78          * \r
79          * @param propagateRelease true if all descendants of this element should release their DOM\r
80          */\r
81         virtual void releaseChildrenDOM(bool propagateRelease=true)=0;\r
82     };\r
83     \r
84 };\r
85 \r
86 #endif /* __xmltooling_domxmlobj_h__ */\r