#ifndef JEZUK_SimpleDOM_ELEMENTNSIMPL_H #define JEZUK_SimpleDOM_ELEMENTNSIMPL_H #include #include namespace SimpleDOM { template class ElementNSImpl : public ElementImpl { typedef typename stringT::size_type size_type; typedef ElementImpl ElementImplT; using ElementImplT::cloneNode; using ElementImplT::ownerDoc_; using ElementImplT::tagName_; using ElementImplT::getPrefix; using ElementImplT::setPrefix; using ElementImplT::hasPrefix; using ElementImplT::throwIfReadOnly; public: ElementNSImpl(DocumentImpl* ownerDoc, const stringT& namespaceURI, bool hasNamespaceURI, const stringT& qualifiedName) : ElementImpl(ownerDoc, qualifiedName), hasNamespaceURI_(false) { string_adaptorT SA; bool hasPrefix = false; stringT prefix; size_type index = qualifiedName.find(SA.makeStringT(":")); if(index == stringT::npos) { //qualifiedName contains no ':' localName_ = qualifiedName; } else { hasPrefix = true; prefix = qualifiedName.substr(0, index); localName_ = qualifiedName.substr(index+1); } std::pair mappedURI = checkPrefixAndNamespace(hasPrefix, prefix, hasNamespaceURI, namespaceURI, DOM::Node::ELEMENT_NODE); hasNamespaceURI_ = mappedURI.first; namespaceURI_ = mappedURI.second; } // ElementImpl virtual ~ElementNSImpl() { } /////////////////////////////////////////////////////// // DOM::Node methods virtual DOM::Node_impl* cloneNode(bool deep) const { ElementNSImpl* clone = dynamic_cast(ownerDoc_->createElementNS(namespaceURI_, tagName_)); cloneChildren(clone, deep); return clone; } // cloneNode virtual stringT getNamespaceURI() const { return namespaceURI_; } // getNamespaceURI virtual stringT getPrefix() const { string_adaptorT SA; size_type index = tagName_.find(SA.makeStringT(":")); return (index != stringT::npos) ? tagName_.substr(0, index) : stringT(); } // getPrefix virtual void setPrefix(const stringT& prefix) { throwIfReadOnly(); if(hasNamespaceURI_ == false) throw DOM::DOMException(DOM::DOMException::NAMESPACE_ERR); if(prefix.empty()) { tagName_ = localName_; return; } // empty prefix checkPrefixAndNamespace(true, prefix, true, namespaceURI_, DOM::Node::ELEMENT_NODE); string_adaptorT SA; tagName_ = prefix + SA.makeStringT(":") + localName_; } // setPrefix virtual stringT getLocalName() const { return localName_; } // getLocalName // additional three methods - since C++ std::string (and by implication // stringT) don't differenciate between a null string and an empty string, // but the DOM recommendation does, I have to introduce these three methods // to disambiguate. If they return false, the corresponding attribute should be // considered null. If they return true, the attribute has been set EVEN IF // it has been set to the empty string virtual bool hasNamespaceURI() const { return hasNamespaceURI_; } // hasNamespaceURI virtual bool hasPrefix() const { string_adaptorT SA; return (tagName_.find(SA.makeStringT(":")) != stringT::npos); } // hasPrefix private: stringT namespaceURI_; stringT localName_; bool hasNamespaceURI_; }; // class ElementImpl } // namespace SAX2DOM #endif