#ifndef JEZUK_SimpleDOM_DOCUMENTFRAGMENTIMPL_H #define JEZUK_SimpleDOM_DOCUMENTFRAGMENTIMPL_H #include namespace SimpleDOM { template class DocumentFragmentImpl : public DOM::DocumentFragment_impl, public NodeImplWithChildren { typedef NodeImplWithChildren NodeT; public: DocumentFragmentImpl(DocumentImpl* ownerDoc) : DOM::DocumentFragment_impl(), NodeImplWithChildren(ownerDoc) { } // DocumentFragmentImpl virtual ~DocumentFragmentImpl() { } /////////////////////////////////////////////////////// // DOM::Node methods virtual DOM::Node_base::Type getNodeType() const { return DOM::Node_base::DOCUMENT_FRAGMENT_NODE; } // getNodeType virtual DOM::Node_impl* cloneNode(bool deep) const { DOM::Node_impl* clone = NodeT::ownerDoc_->createDocumentFragment(); if(deep) for(DOM::Node_impl* c = NodeT::getFirstChild(); c != 0; c = c->getNextSibling()) clone->appendChild(c->cloneNode(true)); return clone; } // cloneNode virtual stringT getNodeName() const { return string_adaptorT::construct_from_utf8("#document-fragment"); } // getNodeName virtual DOM::Node_impl* getParentNode() const { return 0; } // getParentNode private: virtual void checkChildType(DOM::Node_impl* child) { 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 }; // class DocumentFragmentImpl } // namespace SAX2DOM #endif