#ifndef JEZUK_SimpleDOM_ENTITYREFERENCEIMPL_H #define JEZUK_SimpleDOM_ENTITYREFERENCEIMPL_H #include namespace SimpleDOM { template class EntityReferenceImpl : public DOM::EntityReference_impl, public NodeImplWithChildren { typedef NodeImplWithChildren NodeT; public: EntityReferenceImpl(DocumentImpl* ownerDoc, const stringT name) : DOM::EntityReference_impl(), NodeImplWithChildren(ownerDoc), name_(name) { } // EntityReferenceImpl virtual ~EntityReferenceImpl() { } /////////////////////////////////////////////////////// // DOM::Node methods virtual DOM::Node_base::Type getNodeType() const { return DOM::Node_base::ENTITY_REFERENCE_NODE; } // getNodeType virtual const stringT& getNodeName() const { return name_; } // getNodeName virtual void setNodeValue(const stringT& x) { throw DOM::DOMException(DOM::DOMException::NO_MODIFICATION_ALLOWED_ERR); } // setNodeValue virtual DOM::Node_impl* cloneNode(bool deep) const { return NodeT::ownerDoc_->createEntityReference(name_); } // cloneNode ////////////////////////////////////////////////////// // this implementation private: virtual void checkChildType(DOM::Node_impl* child) { if(NodeT::readOnly_) throw DOM::DOMException(DOM::DOMException::NO_MODIFICATION_ALLOWED_ERR); typename DOM::Node::Type type = child->getNodeType(); if((type != DOM::Node::ELEMENT_NODE) && (type != DOM::Node::PROCESSING_INSTRUCTION_NODE) && (type != DOM::Node::COMMENT_NODE) && (type != DOM::Node::TEXT_NODE) && (type != DOM::Node::CDATA_SECTION_NODE) && (type != DOM::Node::ENTITY_REFERENCE_NODE)) throw DOM::DOMException(DOM::DOMException::HIERARCHY_REQUEST_ERR); } // checkChildType stringT name_; }; // class EntityReferenceImpl } // namespace SAX2DOM #endif