2002-06-21 11:16:28 +00:00
|
|
|
#ifndef JEZUK_SimpleDOM_ELEMENTNSIMPL_H
|
|
|
|
#define JEZUK_SimpleDOM_ELEMENTNSIMPL_H
|
|
|
|
|
|
|
|
#include <DOM/Simple/ElementImpl.h>
|
|
|
|
#include <DOM/Simple/Helpers.h>
|
|
|
|
|
|
|
|
namespace SimpleDOM
|
|
|
|
{
|
|
|
|
|
|
|
|
template<class stringT, class string_adaptorT>
|
|
|
|
class ElementNSImpl : public ElementImpl<stringT, string_adaptorT>
|
|
|
|
{
|
2005-09-08 21:43:21 +00:00
|
|
|
typedef typename string_adaptorT::size_type size_type;
|
2004-09-14 20:51:36 +00:00
|
|
|
typedef ElementImpl<stringT, string_adaptorT> ElementImplT;
|
2002-06-21 11:16:28 +00:00
|
|
|
public:
|
|
|
|
ElementNSImpl(DocumentImpl<stringT, string_adaptorT>* ownerDoc,
|
|
|
|
const stringT& namespaceURI,
|
|
|
|
bool hasNamespaceURI,
|
|
|
|
const stringT& qualifiedName) :
|
|
|
|
ElementImpl<stringT, string_adaptorT>(ownerDoc, qualifiedName),
|
2005-12-09 15:49:52 +00:00
|
|
|
hasNamespaceURI_(false),
|
|
|
|
prefix_(&ownerDoc->empty_string())
|
2002-06-21 11:16:28 +00:00
|
|
|
{
|
|
|
|
bool hasPrefix = false;
|
2005-09-30 21:36:11 +00:00
|
|
|
size_type index = string_adaptorT::find(qualifiedName, string_adaptorT::construct_from_utf8(":"));
|
2002-06-21 11:16:28 +00:00
|
|
|
|
2005-09-08 21:43:21 +00:00
|
|
|
if(index == string_adaptorT::npos)
|
2004-09-17 23:17:51 +00:00
|
|
|
{ //qualifiedName contains no ':'
|
2005-12-09 11:49:03 +00:00
|
|
|
localName_ = ElementImplT::ownerDoc_->stringPool(qualifiedName);
|
2002-06-21 11:16:28 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
hasPrefix = true;
|
2005-12-09 15:49:52 +00:00
|
|
|
prefix_ = ElementImplT::ownerDoc_->stringPool(string_adaptorT::substr(qualifiedName, 0, index));
|
2005-12-09 11:49:03 +00:00
|
|
|
localName_ = ElementImplT::ownerDoc_->stringPool(string_adaptorT::substr(qualifiedName, index+1));
|
2002-06-21 11:16:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
std::pair<bool, stringT> mappedURI =
|
2005-12-09 15:49:52 +00:00
|
|
|
checkPrefixAndNamespace<stringT, string_adaptorT>(hasPrefix, *prefix_, hasNamespaceURI, namespaceURI, DOM::Node<stringT>::ELEMENT_NODE);
|
2002-06-21 11:16:28 +00:00
|
|
|
|
|
|
|
hasNamespaceURI_ = mappedURI.first;
|
2005-12-09 11:49:03 +00:00
|
|
|
namespaceURI_ = ElementImplT::ownerDoc_->stringPool(mappedURI.second);
|
2002-06-21 11:16:28 +00:00
|
|
|
} // ElementImpl
|
|
|
|
|
|
|
|
virtual ~ElementNSImpl() { }
|
|
|
|
|
|
|
|
///////////////////////////////////////////////////////
|
|
|
|
// DOM::Node methods
|
|
|
|
virtual DOM::Node_impl<stringT>* cloneNode(bool deep) const
|
|
|
|
{
|
2005-12-09 11:49:03 +00:00
|
|
|
ElementNSImpl* clone = dynamic_cast<ElementNSImpl*>(ElementImplT::ownerDoc_->createElementNS(*namespaceURI_, ElementImplT::getNodeName()));
|
2004-10-12 20:49:30 +00:00
|
|
|
ElementImplT::cloneChildren(clone, deep);
|
2002-06-21 11:16:28 +00:00
|
|
|
return clone;
|
|
|
|
} // cloneNode
|
|
|
|
|
2005-12-09 15:49:52 +00:00
|
|
|
virtual const stringT& getNamespaceURI() const
|
2002-06-21 11:16:28 +00:00
|
|
|
{
|
2005-12-09 11:49:03 +00:00
|
|
|
return *namespaceURI_;
|
2002-06-21 11:16:28 +00:00
|
|
|
} // getNamespaceURI
|
|
|
|
|
2005-12-09 15:49:52 +00:00
|
|
|
virtual const stringT& getPrefix() const
|
2002-06-21 11:16:28 +00:00
|
|
|
{
|
2005-12-09 15:49:52 +00:00
|
|
|
return *prefix_;
|
2002-06-21 11:16:28 +00:00
|
|
|
} // getPrefix
|
|
|
|
|
|
|
|
virtual void setPrefix(const stringT& prefix)
|
|
|
|
{
|
2004-09-17 23:17:51 +00:00
|
|
|
ElementImplT::throwIfReadOnly();
|
2002-06-21 11:16:28 +00:00
|
|
|
|
|
|
|
if(hasNamespaceURI_ == false)
|
|
|
|
throw DOM::DOMException(DOM::DOMException::NAMESPACE_ERR);
|
|
|
|
|
2005-09-08 21:43:21 +00:00
|
|
|
if(string_adaptorT::empty(prefix))
|
2002-06-21 11:16:28 +00:00
|
|
|
{
|
2004-09-17 23:17:51 +00:00
|
|
|
ElementImplT::tagName_ = localName_;
|
2005-12-09 15:49:52 +00:00
|
|
|
prefix_ = &ElementImplT::ownerDoc_->empty_string();
|
2002-06-21 11:16:28 +00:00
|
|
|
return;
|
|
|
|
} // empty prefix
|
|
|
|
|
2005-12-09 11:49:03 +00:00
|
|
|
checkPrefixAndNamespace<stringT, string_adaptorT>(true, prefix, true, *namespaceURI_, DOM::Node<stringT>::ELEMENT_NODE);
|
2002-06-21 11:16:28 +00:00
|
|
|
|
2005-12-09 11:49:03 +00:00
|
|
|
stringT newTagName = prefix;
|
|
|
|
string_adaptorT::append(newTagName, string_adaptorT::construct_from_utf8(":"));
|
|
|
|
string_adaptorT::append(newTagName, *localName_);
|
|
|
|
|
2005-12-09 15:49:52 +00:00
|
|
|
prefix_ = ElementImplT::ownerDoc_->stringPool(prefix);
|
2005-12-09 11:49:03 +00:00
|
|
|
ElementImplT::tagName_ = ElementImplT::ownerDoc_->stringPool(newTagName);
|
2002-06-21 11:16:28 +00:00
|
|
|
} // setPrefix
|
|
|
|
|
2005-12-09 15:49:52 +00:00
|
|
|
virtual const stringT& getLocalName() const
|
2002-06-21 11:16:28 +00:00
|
|
|
{
|
2005-12-09 11:49:03 +00:00
|
|
|
return *localName_;
|
2002-06-21 11:16:28 +00:00
|
|
|
} // 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
|
|
|
|
{
|
2005-12-09 15:49:52 +00:00
|
|
|
return !(*prefix_ == ElementImplT::ownerDoc_->empty_string());
|
2002-06-21 11:16:28 +00:00
|
|
|
} // hasPrefix
|
|
|
|
|
|
|
|
private:
|
2005-12-09 11:49:03 +00:00
|
|
|
stringT const* namespaceURI_;
|
2005-12-09 15:49:52 +00:00
|
|
|
stringT const* prefix_;
|
2005-12-09 11:49:03 +00:00
|
|
|
stringT const* localName_;
|
2002-06-21 11:16:28 +00:00
|
|
|
bool hasNamespaceURI_;
|
2005-12-09 15:49:52 +00:00
|
|
|
}; // class ElementNSImpl
|
2002-06-21 11:16:28 +00:00
|
|
|
|
|
|
|
|
|
|
|
} // namespace SAX2DOM
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|