/** * This file is part of the DOM implementation for KDE. * * Copyright 1999 Lars Knoll (knoll@kde.org) * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public License * along with this library; see the file COPYING.LIB. If not, write to * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, * Boston, MA 02110-1301, USA. * */ #include "dom/dom_doc.h" #include "dom/dom_exception.h" #include "dom/dom2_events.h" #include "xml/dom_docimpl.h" #include "xml/dom_elementimpl.h" #include "xml/dom2_eventsimpl.h" #include using namespace DOM; NamedNodeMap::NamedNodeMap() { impl = 0; } NamedNodeMap::NamedNodeMap(const NamedNodeMap &other) { impl = other.impl; if (impl) impl->ref(); } NamedNodeMap::NamedNodeMap(NamedNodeMapImpl *i) { impl = i; if (impl) impl->ref(); } NamedNodeMap &NamedNodeMap::operator = (const NamedNodeMap &other) { if ( impl != other.impl ) { if(impl) impl->deref(); impl = other.impl; if(impl) impl->ref(); } return *this; } NamedNodeMap::~NamedNodeMap() { if(impl) impl->deref(); } Node NamedNodeMap::getNamedItem( const DOMString &name ) const { if (!impl) return 0; return impl->getNamedItem(name); } Node NamedNodeMap::setNamedItem( const Node &arg ) { if (!impl) throw DOMException(DOMException::NOT_FOUND_ERR); int exceptioncode = 0; Node r = impl->setNamedItem(arg, exceptioncode); if (exceptioncode) throw DOMException(exceptioncode); return r; } Node NamedNodeMap::removeNamedItem( const DOMString &name ) { if (!impl) throw DOMException(DOMException::NOT_FOUND_ERR); int exceptioncode = 0; Node r = impl->removeNamedItem(name, exceptioncode); if (exceptioncode) throw DOMException(exceptioncode); return r; } Node NamedNodeMap::item( unsigned long index ) const { if (!impl) return 0; return impl->item(index); } Node NamedNodeMap::getNamedItemNS( const DOMString &namespaceURI, const DOMString &localName ) const { if (!impl) return 0; return impl->getNamedItemNS(namespaceURI, localName); } Node NamedNodeMap::setNamedItemNS( const Node &arg ) { if (!impl) throw DOMException(DOMException::NOT_FOUND_ERR); int exceptioncode = 0; Node r = impl->setNamedItemNS(arg, exceptioncode); if (exceptioncode) throw DOMException(exceptioncode); return r; } Node NamedNodeMap::removeNamedItemNS( const DOMString &namespaceURI, const DOMString &localName ) { if (!impl) throw DOMException(DOMException::NOT_FOUND_ERR); int exceptioncode = 0; Node r = impl->removeNamedItemNS(namespaceURI, localName, exceptioncode); if (exceptioncode) throw DOMException(exceptioncode); return r; } unsigned long NamedNodeMap::length() const { if (!impl) return 0; return impl->length(); } // --------------------------------------------------------------------------- Node::Node(const Node &other) { impl = other.impl; if(impl) impl->ref(); } Node::Node( NodeImpl *i ) { impl = i; if(impl) impl->ref(); } Node &Node::operator = (const Node &other) { if(impl != other.impl) { if(impl) impl->deref(); impl = other.impl; if(impl) impl->ref(); } return *this; } bool Node::operator == (const Node &other) const { return (impl == other.impl); } bool Node::operator != (const Node &other) const { return !(impl == other.impl); } Node::~Node() { if(impl) impl->deref(); } DOMString Node::nodeName() const { if(impl) return impl->nodeName(); return DOMString(); } DOMString Node::nodeValue() const { // ### should throw exception on plain node ? if(impl) return impl->nodeValue(); return DOMString(); } void Node::setNodeValue( const DOMString &_str ) { if (!impl) throw DOMException(DOMException::NOT_FOUND_ERR); int exceptioncode = 0; if(impl) impl->setNodeValue( _str,exceptioncode ); if (exceptioncode) throw DOMException(exceptioncode); } unsigned short Node::nodeType() const { if (!impl) throw DOMException(DOMException::NOT_FOUND_ERR); return impl->nodeType(); } Node Node::parentNode() const { if (!impl) throw DOMException(DOMException::NOT_FOUND_ERR); return impl->parentNode(); } NodeList Node::childNodes() const { if (!impl) return 0; return impl->childNodes().get(); } Node Node::firstChild() const { if (!impl) throw DOMException(DOMException::NOT_FOUND_ERR); return impl->firstChild(); } Node Node::lastChild() const { if (!impl) throw DOMException(DOMException::NOT_FOUND_ERR); return impl->lastChild(); } Node Node::previousSibling() const { if (!impl) throw DOMException(DOMException::NOT_FOUND_ERR); return impl->previousSibling(); } Node Node::nextSibling() const { if (!impl) throw DOMException(DOMException::NOT_FOUND_ERR); return impl->nextSibling(); } NamedNodeMap Node::attributes() const { if (!impl || !impl->isElementNode()) return 0; return static_cast(impl)->attributes(); } Document Node::ownerDocument() const { if (!impl || !impl->ownerDocument()) return Document(false); return impl->ownerDocument(); } Node Node::insertBefore( const Node &newChild, const Node &refChild ) { if (!impl) throw DOMException(DOMException::NOT_FOUND_ERR); int exceptioncode = 0; NodeImpl *r = impl->insertBefore( newChild.impl, refChild.impl, exceptioncode ); if (exceptioncode) throw DOMException(exceptioncode); return r; } Node Node::replaceChild( const Node &newChild, const Node &oldChild ) { if (!impl) throw DOMException(DOMException::NOT_FOUND_ERR); int exceptioncode = 0; impl->replaceChild( newChild.impl, oldChild.impl, exceptioncode ); if (exceptioncode) throw DOMException(exceptioncode); return oldChild; } Node Node::removeChild( const Node &oldChild ) { if (!impl) throw DOMException(DOMException::NOT_FOUND_ERR); int exceptioncode = 0; impl->removeChild( oldChild.impl, exceptioncode ); if (exceptioncode) throw DOMException(exceptioncode); return oldChild; } Node Node::appendChild( const Node &newChild ) { if (!impl) throw DOMException(DOMException::NOT_FOUND_ERR); int exceptioncode = 0; NodeImpl *r = impl->appendChild( newChild.impl, exceptioncode ); if (exceptioncode) throw DOMException(exceptioncode); return r; } bool Node::hasAttributes() { if (!impl) throw DOMException(DOMException::NOT_FOUND_ERR); return impl->hasAttributes(); } bool Node::hasChildNodes( ) { if (!impl) return false; return impl->hasChildNodes(); } Node Node::cloneNode( bool deep ) { if (!impl) return 0; return impl->cloneNode( deep ).get(); } void Node::normalize ( ) { if (!impl) return; impl->normalize(); } bool Node::isSupported( const DOMString &feature, const DOMString &version ) const { return NodeImpl::isSupported(feature, version); } DOMString Node::namespaceURI( ) const { if (!impl) return DOMString(); return impl->namespaceURI(); } DOMString Node::prefix( ) const { if (!impl) return DOMString(); return impl->prefix(); } void Node::setPrefix(const DOMString &prefix ) { if (!impl) throw DOMException(DOMException::NOT_FOUND_ERR); int exceptioncode = 0; impl->setPrefix(prefix,exceptioncode); if (exceptioncode) throw DOMException(exceptioncode); } DOMString Node::localName( ) const { if (!impl) return DOMString(); return impl->localName(); } void Node::addEventListener(const DOMString &type, EventListener *listener, const bool useCapture) { if (!impl) return; if (listener) impl->addEventListener(EventName::fromString(type),listener,useCapture); } void Node::removeEventListener(const DOMString &type, EventListener *listener, bool useCapture) { if (!impl) return; impl->removeEventListener(EventName::fromString(type),listener,useCapture); } bool Node::dispatchEvent(const Event &evt) { if (!impl) throw DOMException(DOMException::INVALID_STATE_ERR); if (!evt.handle()) throw DOMException(DOMException::NOT_FOUND_ERR); int exceptioncode = 0; impl->dispatchEvent(evt.handle(),exceptioncode); if (exceptioncode) throw DOMException(exceptioncode); return !evt.handle()->defaultPrevented(); } DOMString Node::textContent() const { if (!impl) return DOMString(); return impl->textContent(); } void Node::setTextContent(const DOMString& content) { if (!impl) throw DOMException(DOMException::NOT_FOUND_ERR); int exceptioncode = 0; impl->setTextContent(content, exceptioncode); if (exceptioncode) throw DOMException(exceptioncode); } unsigned Node::compareDocumentPosition(const Node& other) { if (!impl || !other.impl) throw DOMException(DOMException::NOT_FOUND_ERR); return impl->compareDocumentPosition(other.impl); } unsigned int Node::elementId() const { if (!impl) return 0; return impl->id(); } unsigned long Node::index() const { if (!impl) return 0; return impl->nodeIndex(); } #ifndef KDE_NO_DEPRECATED QString Node::toHTML() { if (!impl) return QString(); return impl->toString().string(); } #endif void Node::applyChanges() { if (!impl) return; impl->recalcStyle( NodeImpl::Inherit ); } #ifndef KDE_NO_DEPRECATED void Node::getCursor(int offset, int &_x, int &_y, int &height) { if (!impl) throw DOMException(DOMException::NOT_FOUND_ERR); int dummy; impl->getCaret(offset, false, _x, _y, dummy, height); } #endif QRect Node::getRect() { if (!impl) throw DOMException(DOMException::NOT_FOUND_ERR); return impl->getRect(); } //----------------------------------------------------------------------------- NodeList::NodeList() { impl = 0; } NodeList::NodeList(const NodeList &other) { impl = other.impl; if(impl) impl->ref(); } NodeList::NodeList(const NodeListImpl *i) { impl = const_cast(i); if(impl) impl->ref(); } NodeList &NodeList::operator = (const NodeList &other) { if ( impl != other.impl ) { if(impl) impl->deref(); impl = other.impl; if(impl) impl->ref(); } return *this; } NodeList::~NodeList() { if(impl) impl->deref(); } Node NodeList::item( unsigned long index ) const { if (!impl) return 0; return impl->item(index); } unsigned long NodeList::length() const { if (!impl) return 0; return impl->length(); } //----------------------------------------------------------------------------- DOMString DOMException::codeAsString() const { return codeAsString(code); } DOMString DOMException::codeAsString(int code) { switch ( code ) { case INDEX_SIZE_ERR: return DOMString( "INDEX_SIZE_ERR" ); case DOMSTRING_SIZE_ERR: return DOMString( "DOMSTRING_SIZE_ERR" ); case HIERARCHY_REQUEST_ERR: return DOMString( "HIERARCHY_REQUEST_ERR" ); case WRONG_DOCUMENT_ERR: return DOMString( "WRONG_DOCUMENT_ERR" ); case INVALID_CHARACTER_ERR: return DOMString( "INVALID_CHARACTER_ERR" ); case NO_DATA_ALLOWED_ERR: return DOMString( "NO_DATA_ALLOWED_ERR" ); case NO_MODIFICATION_ALLOWED_ERR: return DOMString( "NO_MODIFICATION_ALLOWED_ERR" ); case NOT_FOUND_ERR: return DOMString( "NOT_FOUND_ERR" ); case NOT_SUPPORTED_ERR: return DOMString( "NOT_SUPPORTED_ERR" ); case INUSE_ATTRIBUTE_ERR: return DOMString( "INUSE_ATTRIBUTE_ERR" ); case INVALID_STATE_ERR: return DOMString( "INVALID_STATE_ERR" ); case SYNTAX_ERR: return DOMString( "SYNTAX_ERR" ); case INVALID_MODIFICATION_ERR: return DOMString( "INVALID_MODIFICATION_ERR" ); case NAMESPACE_ERR: return DOMString( "NAMESPACE_ERR" ); case INVALID_ACCESS_ERR: return DOMString( "INVALID_ACCESS_ERR" ); case VALIDATION_ERR: return DOMString( "VALIDATION_ERR" ); case TYPE_MISMATCH_ERR: return DOMString( "TYPE_MISMATCH_ERR" ); case SECURITY_ERR: return DOMString( "SECURITY_ERR" ); case NETWORK_ERR: return DOMString( "NETWORK_ERR" ); case ABORT_ERR: return DOMString( "ABORT_ERR" ); case URL_MISMATCH_ERR: return DOMString( "URL_MISMATCH_ERR" ); case QUOTA_EXCEEDED_ERR: return DOMString( "QUOTA_EXCEEDED_ERR" ); case TIMEOUT_ERR: return DOMString( "TIMEOUT_ERR" ); case NOT_READABLE_ERR: return DOMString( "NOT_READABLE_ERR" ); case DATA_CLONE_ERR: return DOMString( "DATA_CLONE_ERR" ); case ENCODING_ERR: return DOMString( "ENCODING_ERR" ); default: return DOMString( "(unknown exception code)" ); } } bool DOMException::isDOMExceptionCode(int exceptioncode) { return exceptioncode < 100; }