source: icXML/icXML-devel/src/xercesc/dom/impl/DOMEntityReferenceImpl.cpp @ 6297

Last change on this file since 6297 was 2777, checked in by cameron, 7 years ago

Set up to use xercesc/icxercesc root-relative paths for all includes

File size: 10.4 KB
Line 
1/*
2 * Licensed to the Apache Software Foundation (ASF) under one or more
3 * contributor license agreements.  See the NOTICE file distributed with
4 * this work for additional information regarding copyright ownership.
5 * The ASF licenses this file to You under the Apache License, Version 2.0
6 * (the "License"); you may not use this file except in compliance with
7 * the License.  You may obtain a copy of the License at
8 *
9 *      http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 */
17
18/*
19 * $Id: DOMEntityReferenceImpl.cpp 678381 2008-07-21 10:15:01Z borisk $
20 */
21
22#include <xercesc/dom/impl/DOMDocumentImpl.hpp>
23#include <xercesc/dom/impl/DOMDocumentTypeImpl.hpp>
24#include <xercesc/dom/impl/DOMEntityImpl.hpp>
25#include <xercesc/dom/impl/DOMEntityReferenceImpl.hpp>
26
27#include <xercesc/dom/DOMException.hpp>
28#include <xercesc/dom/DOMNode.hpp>
29#include <xercesc/dom/DOMNamedNodeMap.hpp>
30
31XERCES_CPP_NAMESPACE_BEGIN
32
33DOMEntityReferenceImpl::DOMEntityReferenceImpl(DOMDocument *ownerDoc,
34                                         const XMLCh *entityName)
35    : fNode(ownerDoc), fParent(ownerDoc), fBaseURI(0)
36{
37    fName = ((DOMDocumentImpl*)fParent.fOwnerDocument)->getPooledString(entityName);
38    // EntityReference behaves as a read-only node, since its contents
39    // reflect the Entity it refers to -- but see setNodeName().
40    //retrieve the corresponding entity content
41
42    if (ownerDoc) {
43        if (ownerDoc->getDoctype()) {
44            if (ownerDoc->getDoctype()->getEntities()) {
45                DOMEntityImpl* entity = (DOMEntityImpl*)ownerDoc->getDoctype()->getEntities()->getNamedItem(entityName);
46                if (entity) {
47                    fBaseURI = entity->getBaseURI();
48                    DOMEntityReference* refEntity = entity->getEntityRef();
49                    if (refEntity) {
50                        fParent.cloneChildren(refEntity);
51                    }
52                }
53            }
54        }
55    }
56
57    fNode.setReadOnly(true, true);
58}
59
60
61DOMEntityReferenceImpl::DOMEntityReferenceImpl(DOMDocument *ownerDoc,
62                                         const XMLCh *entityName,
63                                         bool cloneChild)
64    : fNode(ownerDoc), fParent(ownerDoc), fBaseURI(0)
65{
66    fName = ((DOMDocumentImpl*)fParent.fOwnerDocument)->getPooledString(entityName);
67    // EntityReference behaves as a read-only node, since its contents
68    // reflect the Entity it refers to -- but see setNodeName().
69    //retrieve the corresponding entity content
70
71    if (ownerDoc) {
72        if (ownerDoc->getDoctype()) {
73            if (ownerDoc->getDoctype()->getEntities()) {
74                DOMEntityImpl* entity = (DOMEntityImpl*)ownerDoc->getDoctype()->getEntities()->getNamedItem(entityName);
75                if (entity) {
76                    fBaseURI = entity->getBaseURI();
77                    if (cloneChild) {
78                        DOMEntityReference* refEntity = entity->getEntityRef();
79                        if (refEntity) {
80                            fParent.cloneChildren(refEntity);
81                        }
82                    }
83                }
84            }
85        }
86    }
87
88    fNode.setReadOnly(true, true);
89}
90
91DOMEntityReferenceImpl::DOMEntityReferenceImpl(const DOMEntityReferenceImpl &other,
92                                         bool deep)
93    : DOMEntityReference(other),
94      fNode(other.fNode),
95      fParent(other.fParent),
96      fChild(other.fChild),
97      fName(other.fName),
98      fBaseURI(other.fBaseURI)
99{
100    if (deep)
101        fParent.cloneChildren(&other);
102    fNode.setReadOnly(true, true);
103}
104
105
106
107DOMEntityReferenceImpl::~DOMEntityReferenceImpl()
108{
109}
110
111DOMNode *DOMEntityReferenceImpl::cloneNode(bool deep) const
112{
113    DOMNode* newNode = new (fParent.fOwnerDocument, DOMMemoryManager::ENTITY_REFERENCE_OBJECT) DOMEntityReferenceImpl(*this, deep);
114    fNode.callUserDataHandlers(DOMUserDataHandler::NODE_CLONED, this, newNode);
115    return newNode;
116}
117
118
119const XMLCh * DOMEntityReferenceImpl::getNodeName() const
120{
121    return fName;
122}
123
124
125DOMNode::NodeType DOMEntityReferenceImpl::getNodeType() const {
126    return DOMNode::ENTITY_REFERENCE_NODE;
127}
128
129
130
131/**
132* EntityReferences never have a nodeValue.
133* @throws DOMException(NO_MODIFICATION_ALLOWED_ERR)
134*/
135void DOMEntityReferenceImpl::setNodeValue(const XMLCh *x)
136{
137    fNode.setNodeValue(x);
138}
139
140
141/**
142* EntityRef is already, and must be, a read-only node. Attempts to change
143* that will throw a NO_MODIFICATION_ALLOWED_ERR DOMException.
144* <P>
145* If you want to alter its contents, edit the Entity definition.
146*
147* @param readOnly boolean
148*/
149void DOMEntityReferenceImpl::setReadOnly(bool readOnl,bool deep)
150{
151    if(((DOMDocumentImpl *)fParent.fOwnerDocument)->getErrorChecking() && readOnl==false)
152        throw DOMException(DOMException::NO_MODIFICATION_ALLOWED_ERR, 0, GetDOMNodeMemoryManager);
153    fNode.setReadOnly(readOnl,deep);
154}
155
156
157void DOMEntityReferenceImpl::release()
158{
159    if (fNode.isOwned() && !fNode.isToBeReleased())
160        throw DOMException(DOMException::INVALID_ACCESS_ERR,0, GetDOMNodeMemoryManager);
161
162    DOMDocumentImpl* doc = (DOMDocumentImpl*) fParent.fOwnerDocument;
163    if (doc) {
164        fNode.callUserDataHandlers(DOMUserDataHandler::NODE_DELETED, 0, 0);
165        fParent.release();
166        doc->release(this, DOMMemoryManager::ENTITY_REFERENCE_OBJECT);
167    }
168    else {
169        // shouldn't reach here
170        throw DOMException(DOMException::INVALID_ACCESS_ERR,0, GetDOMNodeMemoryManager);
171    }
172}
173
174const XMLCh* DOMEntityReferenceImpl::getBaseURI() const
175{
176    return fBaseURI;
177}
178
179
180
181//
182//   Delegate functions from Node to the appropriate implementation.
183//
184
185
186           DOMNode*         DOMEntityReferenceImpl::appendChild(DOMNode *newChild)          {return fParent.appendChild (newChild); }
187           DOMNamedNodeMap* DOMEntityReferenceImpl::getAttributes() const                   {return fNode.getAttributes (); }
188           DOMNodeList*     DOMEntityReferenceImpl::getChildNodes() const                   {return fParent.getChildNodes (); }
189           DOMNode*         DOMEntityReferenceImpl::getFirstChild() const                   {return fParent.getFirstChild (); }
190           DOMNode*         DOMEntityReferenceImpl::getLastChild() const                    {return fParent.getLastChild (); }
191     const XMLCh*           DOMEntityReferenceImpl::getLocalName() const                    {return fNode.getLocalName (); }
192     const XMLCh*           DOMEntityReferenceImpl::getNamespaceURI() const                 {return fNode.getNamespaceURI (); }
193           DOMNode*         DOMEntityReferenceImpl::getNextSibling() const                  {return fChild.getNextSibling (); }
194     const XMLCh*           DOMEntityReferenceImpl::getNodeValue() const                    {return fNode.getNodeValue (); }
195           DOMDocument*     DOMEntityReferenceImpl::getOwnerDocument() const                {return fParent.fOwnerDocument; }
196     const XMLCh*           DOMEntityReferenceImpl::getPrefix() const                       {return fNode.getPrefix (); }
197           DOMNode*         DOMEntityReferenceImpl::getParentNode() const                   {return fChild.getParentNode (this); }
198           DOMNode*         DOMEntityReferenceImpl::getPreviousSibling() const              {return fChild.getPreviousSibling (this); }
199           bool             DOMEntityReferenceImpl::hasChildNodes() const                   {return fParent.hasChildNodes (); }
200           DOMNode*         DOMEntityReferenceImpl::insertBefore(DOMNode *newChild, DOMNode *refChild)
201                                                                                            {return fParent.insertBefore (newChild, refChild); }
202           void             DOMEntityReferenceImpl::normalize()                             {fParent.normalize (); }
203           DOMNode*         DOMEntityReferenceImpl::removeChild(DOMNode *oldChild)          {return fParent.removeChild (oldChild); }
204           DOMNode*         DOMEntityReferenceImpl::replaceChild(DOMNode *newChild, DOMNode *oldChild)
205                                                                                            {return fParent.replaceChild (newChild, oldChild); }
206           bool             DOMEntityReferenceImpl::isSupported(const XMLCh *feature, const XMLCh *version) const
207                                                                                            {return fNode.isSupported (feature, version); }
208           void             DOMEntityReferenceImpl::setPrefix(const XMLCh  *prefix)         {fNode.setPrefix(prefix); }
209           bool             DOMEntityReferenceImpl::hasAttributes() const                   {return fNode.hasAttributes(); }
210           bool             DOMEntityReferenceImpl::isSameNode(const DOMNode* other) const  {return fNode.isSameNode(other); }
211           bool             DOMEntityReferenceImpl::isEqualNode(const DOMNode* arg) const   {return fParent.isEqualNode(arg); }
212           void*            DOMEntityReferenceImpl::setUserData(const XMLCh* key, void* data, DOMUserDataHandler* handler)
213                                                                                            {return fNode.setUserData(key, data, handler); }
214           void*            DOMEntityReferenceImpl::getUserData(const XMLCh* key) const     {return fNode.getUserData(key); }
215           short            DOMEntityReferenceImpl::compareDocumentPosition(const DOMNode* other) const {return fNode.compareDocumentPosition(other); }
216           const XMLCh*     DOMEntityReferenceImpl::getTextContent() const                  {return fNode.getTextContent(); }
217           void             DOMEntityReferenceImpl::setTextContent(const XMLCh* textContent){fNode.setTextContent(textContent); }
218           const XMLCh*     DOMEntityReferenceImpl::lookupPrefix(const XMLCh* namespaceURI) const  {return fNode.lookupPrefix(namespaceURI); }
219           bool             DOMEntityReferenceImpl::isDefaultNamespace(const XMLCh* namespaceURI) const {return fNode.isDefaultNamespace(namespaceURI); }
220           const XMLCh*     DOMEntityReferenceImpl::lookupNamespaceURI(const XMLCh* prefix) const  {return fNode.lookupNamespaceURI(prefix); }
221           void*            DOMEntityReferenceImpl::getFeature(const XMLCh* feature, const XMLCh* version) const {return fNode.getFeature(feature, version); }
222
223XERCES_CPP_NAMESPACE_END
Note: See TracBrowser for help on using the repository browser.