aboutsummaryrefslogtreecommitdiffstats
path: root/contrib/libs/poco/XML/src/AbstractNode.cpp
diff options
context:
space:
mode:
authororivej <orivej@yandex-team.ru>2022-02-10 16:44:49 +0300
committerDaniil Cherednik <dcherednik@yandex-team.ru>2022-02-10 16:44:49 +0300
commit718c552901d703c502ccbefdfc3c9028d608b947 (patch)
tree46534a98bbefcd7b1f3faa5b52c138ab27db75b7 /contrib/libs/poco/XML/src/AbstractNode.cpp
parente9656aae26e0358d5378e5b63dcac5c8dbe0e4d0 (diff)
downloadydb-718c552901d703c502ccbefdfc3c9028d608b947.tar.gz
Restoring authorship annotation for <orivej@yandex-team.ru>. Commit 1 of 2.
Diffstat (limited to 'contrib/libs/poco/XML/src/AbstractNode.cpp')
-rw-r--r--contrib/libs/poco/XML/src/AbstractNode.cpp734
1 files changed, 367 insertions, 367 deletions
diff --git a/contrib/libs/poco/XML/src/AbstractNode.cpp b/contrib/libs/poco/XML/src/AbstractNode.cpp
index 1897d69324..5efa19ed06 100644
--- a/contrib/libs/poco/XML/src/AbstractNode.cpp
+++ b/contrib/libs/poco/XML/src/AbstractNode.cpp
@@ -1,367 +1,367 @@
-//
-// AbstractNode.cpp
-//
-// Library: XML
-// Package: DOM
-// Module: DOM
-//
-// Copyright (c) 2004-2006, Applied Informatics Software Engineering GmbH.
-// and Contributors.
-//
-// SPDX-License-Identifier: BSL-1.0
-//
-
-
-#include "Poco/DOM/AbstractNode.h"
-#include "Poco/DOM/Document.h"
-#include "Poco/DOM/ChildNodesList.h"
-#include "Poco/DOM/EventDispatcher.h"
-#include "Poco/DOM/DOMException.h"
-#include "Poco/DOM/EventException.h"
-#include "Poco/DOM/DOMImplementation.h"
-#include "Poco/DOM/Attr.h"
-#include "Poco/XML/Name.h"
-#include "Poco/DOM/AutoPtr.h"
-
-
-namespace Poco {
-namespace XML {
-
-
-const XMLString AbstractNode::NODE_NAME = toXMLString("#node");
-const XMLString AbstractNode::EMPTY_STRING;
-
-
-AbstractNode::AbstractNode(Document* pOwnerDocument):
- _pParent(0),
- _pNext(0),
- _pOwner(pOwnerDocument),
- _pEventDispatcher(0)
-{
-}
-
-
-AbstractNode::AbstractNode(Document* pOwnerDocument, const AbstractNode& /*node*/):
- _pParent(0),
- _pNext(0),
- _pOwner(pOwnerDocument),
- _pEventDispatcher(0)
-{
-}
-
-
-AbstractNode::~AbstractNode()
-{
- delete _pEventDispatcher;
- if (_pNext) _pNext->release();
-}
-
-
-void AbstractNode::autoRelease()
-{
- _pOwner->autoReleasePool().add(this);
-}
-
-
-const XMLString& AbstractNode::nodeName() const
-{
- return NODE_NAME;
-}
-
-
-const XMLString& AbstractNode::getNodeValue() const
-{
- return EMPTY_STRING;
-}
-
-
-void AbstractNode::setNodeValue(const XMLString& /*value*/)
-{
- throw DOMException(DOMException::NO_DATA_ALLOWED_ERR);
-}
-
-
-Node* AbstractNode::parentNode() const
-{
- return _pParent;
-}
-
-
-NodeList* AbstractNode::childNodes() const
-{
- return new ChildNodesList(this);
-}
-
-
-Node* AbstractNode::firstChild() const
-{
- return 0;
-}
-
-
-Node* AbstractNode::lastChild() const
-{
- return 0;
-}
-
-
-Node* AbstractNode::previousSibling() const
-{
- if (_pParent)
- {
- AbstractNode* pSibling = _pParent->_pFirstChild;
- while (pSibling)
- {
- if (pSibling->_pNext == this) return pSibling;
- pSibling = pSibling->_pNext;
- }
- }
- return 0;
-}
-
-
-Node* AbstractNode::nextSibling() const
-{
- return _pNext;
-}
-
-
-NamedNodeMap* AbstractNode::attributes() const
-{
- return 0;
-}
-
-
-Document* AbstractNode::ownerDocument() const
-{
- return _pOwner;
-}
-
-
-Node* AbstractNode::insertBefore(Node* /*newChild*/, Node* /*refChild*/)
-{
- throw DOMException(DOMException::HIERARCHY_REQUEST_ERR);
-}
-
-
-Node* AbstractNode::replaceChild(Node* /*newChild*/, Node* /*oldChild*/)
-{
- throw DOMException(DOMException::HIERARCHY_REQUEST_ERR);
-}
-
-
-Node* AbstractNode::removeChild(Node* /*oldChild*/)
-{
- throw DOMException(DOMException::NO_MODIFICATION_ALLOWED_ERR);
-}
-
-
-Node* AbstractNode::appendChild(Node* /*newChild*/)
-{
- throw DOMException(DOMException::HIERARCHY_REQUEST_ERR);
-}
-
-
-bool AbstractNode::hasChildNodes() const
-{
- return false;
-}
-
-
-Node* AbstractNode::cloneNode(bool deep) const
-{
- return copyNode(deep, _pOwner);
-}
-
-
-void AbstractNode::normalize()
-{
-}
-
-
-bool AbstractNode::isSupported(const XMLString& feature, const XMLString& version) const
-{
- return DOMImplementation::instance().hasFeature(feature, version);
-}
-
-
-const XMLString& AbstractNode::namespaceURI() const
-{
- return EMPTY_STRING;
-}
-
-
-XMLString AbstractNode::prefix() const
-{
- return EMPTY_STRING;
-}
-
-
-const XMLString& AbstractNode::localName() const
-{
- return EMPTY_STRING;
-}
-
-
-bool AbstractNode::hasAttributes() const
-{
- return false;
-}
-
-
-XMLString AbstractNode::innerText() const
-{
- return EMPTY_STRING;
-}
-
-
-Node* AbstractNode::getNodeByPath(const XMLString& /*path*/) const
-{
- return 0;
-}
-
-
-Node* AbstractNode::getNodeByPathNS(const XMLString& /*path*/, const NSMap& /*nsMap*/) const
-{
- return 0;
-}
-
-
-void AbstractNode::addEventListener(const XMLString& type, EventListener* listener, bool useCapture)
-{
- if (_pEventDispatcher)
- _pEventDispatcher->removeEventListener(type, listener, useCapture);
- else
- _pEventDispatcher = new EventDispatcher;
-
- _pEventDispatcher->addEventListener(type, listener, useCapture);
-}
-
-
-void AbstractNode::removeEventListener(const XMLString& type, EventListener* listener, bool useCapture)
-{
- if (_pEventDispatcher)
- _pEventDispatcher->removeEventListener(type, listener, useCapture);
-}
-
-
-bool AbstractNode::dispatchEvent(Event* evt)
-{
- if (eventsSuspended()) return true;
-
- if (evt->type().empty()) throw EventException(EventException::UNSPECIFIED_EVENT_TYPE_ERR);
-
- evt->setTarget(this);
- evt->setCurrentPhase(Event::CAPTURING_PHASE);
-
- if (_pParent) _pParent->captureEvent(evt);
-
- if (_pEventDispatcher && !evt->isStopped())
- {
- evt->setCurrentPhase(Event::AT_TARGET);
- evt->setCurrentTarget(this);
- _pEventDispatcher->dispatchEvent(evt);
- }
- if (!evt->isStopped() && evt->bubbles() && _pParent)
- {
- evt->setCurrentPhase(Event::BUBBLING_PHASE);
- _pParent->bubbleEvent(evt);
- }
-
- return evt->isCanceled();
-}
-
-
-void AbstractNode::captureEvent(Event* evt)
-{
- if (_pParent)
- _pParent->captureEvent(evt);
-
- if (_pEventDispatcher && !evt->isStopped())
- {
- evt->setCurrentTarget(this);
- _pEventDispatcher->captureEvent(evt);
- }
-}
-
-
-void AbstractNode::bubbleEvent(Event* evt)
-{
- evt->setCurrentTarget(this);
- if (_pEventDispatcher)
- {
- _pEventDispatcher->bubbleEvent(evt);
- }
- if (_pParent && !evt->isStopped())
- _pParent->bubbleEvent(evt);
-}
-
-
-void AbstractNode::dispatchSubtreeModified()
-{
- AutoPtr<MutationEvent> pEvent = new MutationEvent(_pOwner, MutationEvent::DOMSubtreeModified, this, true, false, 0);
- dispatchEvent(pEvent.get());
-}
-
-
-void AbstractNode::dispatchNodeInserted()
-{
- AutoPtr<MutationEvent> pEvent = new MutationEvent(_pOwner, MutationEvent::DOMNodeInserted, this, true, false, parentNode());
- dispatchEvent(pEvent.get());
-}
-
-
-void AbstractNode::dispatchNodeRemoved()
-{
- AutoPtr<MutationEvent> pEvent = new MutationEvent(_pOwner, MutationEvent::DOMNodeRemoved, this, true, false, parentNode());
- dispatchEvent(pEvent.get());
-}
-
-
-void AbstractNode::dispatchNodeRemovedFromDocument()
-{
- AutoPtr<MutationEvent> pEvent = new MutationEvent(_pOwner, MutationEvent::DOMNodeRemovedFromDocument, this, false, false, 0);
- dispatchEvent(pEvent.get());
-}
-
-
-void AbstractNode::dispatchNodeInsertedIntoDocument()
-{
- AutoPtr<MutationEvent> pEvent = new MutationEvent(_pOwner, MutationEvent::DOMNodeInsertedIntoDocument, this, false, false, 0);
- dispatchEvent(pEvent.get());
-}
-
-
-void AbstractNode::dispatchAttrModified(Attr* pAttr, MutationEvent::AttrChangeType changeType, const XMLString& prevValue, const XMLString& newValue)
-{
- AutoPtr<MutationEvent> pEvent = new MutationEvent(_pOwner, MutationEvent::DOMAttrModified, this, true, false, pAttr, prevValue, newValue, pAttr->name(), changeType);
- dispatchEvent(pEvent.get());
-}
-
-
-void AbstractNode::dispatchCharacterDataModified(const XMLString& prevValue, const XMLString& newValue)
-{
- AutoPtr<MutationEvent> pEvent = new MutationEvent(_pOwner, MutationEvent::DOMCharacterDataModified, this, true, false, 0, prevValue, newValue, EMPTY_STRING, MutationEvent::MODIFICATION);
- dispatchEvent(pEvent.get());
-}
-
-
-bool AbstractNode::events() const
-{
- return _pOwner->events();
-}
-
-
-bool AbstractNode::eventsSuspended() const
-{
- return _pOwner->eventsSuspended();
-}
-
-
-void AbstractNode::setOwnerDocument(Document* pOwnerDocument)
-{
- _pOwner = pOwnerDocument;
-}
-
-
-} } // namespace Poco::XML
+//
+// AbstractNode.cpp
+//
+// Library: XML
+// Package: DOM
+// Module: DOM
+//
+// Copyright (c) 2004-2006, Applied Informatics Software Engineering GmbH.
+// and Contributors.
+//
+// SPDX-License-Identifier: BSL-1.0
+//
+
+
+#include "Poco/DOM/AbstractNode.h"
+#include "Poco/DOM/Document.h"
+#include "Poco/DOM/ChildNodesList.h"
+#include "Poco/DOM/EventDispatcher.h"
+#include "Poco/DOM/DOMException.h"
+#include "Poco/DOM/EventException.h"
+#include "Poco/DOM/DOMImplementation.h"
+#include "Poco/DOM/Attr.h"
+#include "Poco/XML/Name.h"
+#include "Poco/DOM/AutoPtr.h"
+
+
+namespace Poco {
+namespace XML {
+
+
+const XMLString AbstractNode::NODE_NAME = toXMLString("#node");
+const XMLString AbstractNode::EMPTY_STRING;
+
+
+AbstractNode::AbstractNode(Document* pOwnerDocument):
+ _pParent(0),
+ _pNext(0),
+ _pOwner(pOwnerDocument),
+ _pEventDispatcher(0)
+{
+}
+
+
+AbstractNode::AbstractNode(Document* pOwnerDocument, const AbstractNode& /*node*/):
+ _pParent(0),
+ _pNext(0),
+ _pOwner(pOwnerDocument),
+ _pEventDispatcher(0)
+{
+}
+
+
+AbstractNode::~AbstractNode()
+{
+ delete _pEventDispatcher;
+ if (_pNext) _pNext->release();
+}
+
+
+void AbstractNode::autoRelease()
+{
+ _pOwner->autoReleasePool().add(this);
+}
+
+
+const XMLString& AbstractNode::nodeName() const
+{
+ return NODE_NAME;
+}
+
+
+const XMLString& AbstractNode::getNodeValue() const
+{
+ return EMPTY_STRING;
+}
+
+
+void AbstractNode::setNodeValue(const XMLString& /*value*/)
+{
+ throw DOMException(DOMException::NO_DATA_ALLOWED_ERR);
+}
+
+
+Node* AbstractNode::parentNode() const
+{
+ return _pParent;
+}
+
+
+NodeList* AbstractNode::childNodes() const
+{
+ return new ChildNodesList(this);
+}
+
+
+Node* AbstractNode::firstChild() const
+{
+ return 0;
+}
+
+
+Node* AbstractNode::lastChild() const
+{
+ return 0;
+}
+
+
+Node* AbstractNode::previousSibling() const
+{
+ if (_pParent)
+ {
+ AbstractNode* pSibling = _pParent->_pFirstChild;
+ while (pSibling)
+ {
+ if (pSibling->_pNext == this) return pSibling;
+ pSibling = pSibling->_pNext;
+ }
+ }
+ return 0;
+}
+
+
+Node* AbstractNode::nextSibling() const
+{
+ return _pNext;
+}
+
+
+NamedNodeMap* AbstractNode::attributes() const
+{
+ return 0;
+}
+
+
+Document* AbstractNode::ownerDocument() const
+{
+ return _pOwner;
+}
+
+
+Node* AbstractNode::insertBefore(Node* /*newChild*/, Node* /*refChild*/)
+{
+ throw DOMException(DOMException::HIERARCHY_REQUEST_ERR);
+}
+
+
+Node* AbstractNode::replaceChild(Node* /*newChild*/, Node* /*oldChild*/)
+{
+ throw DOMException(DOMException::HIERARCHY_REQUEST_ERR);
+}
+
+
+Node* AbstractNode::removeChild(Node* /*oldChild*/)
+{
+ throw DOMException(DOMException::NO_MODIFICATION_ALLOWED_ERR);
+}
+
+
+Node* AbstractNode::appendChild(Node* /*newChild*/)
+{
+ throw DOMException(DOMException::HIERARCHY_REQUEST_ERR);
+}
+
+
+bool AbstractNode::hasChildNodes() const
+{
+ return false;
+}
+
+
+Node* AbstractNode::cloneNode(bool deep) const
+{
+ return copyNode(deep, _pOwner);
+}
+
+
+void AbstractNode::normalize()
+{
+}
+
+
+bool AbstractNode::isSupported(const XMLString& feature, const XMLString& version) const
+{
+ return DOMImplementation::instance().hasFeature(feature, version);
+}
+
+
+const XMLString& AbstractNode::namespaceURI() const
+{
+ return EMPTY_STRING;
+}
+
+
+XMLString AbstractNode::prefix() const
+{
+ return EMPTY_STRING;
+}
+
+
+const XMLString& AbstractNode::localName() const
+{
+ return EMPTY_STRING;
+}
+
+
+bool AbstractNode::hasAttributes() const
+{
+ return false;
+}
+
+
+XMLString AbstractNode::innerText() const
+{
+ return EMPTY_STRING;
+}
+
+
+Node* AbstractNode::getNodeByPath(const XMLString& /*path*/) const
+{
+ return 0;
+}
+
+
+Node* AbstractNode::getNodeByPathNS(const XMLString& /*path*/, const NSMap& /*nsMap*/) const
+{
+ return 0;
+}
+
+
+void AbstractNode::addEventListener(const XMLString& type, EventListener* listener, bool useCapture)
+{
+ if (_pEventDispatcher)
+ _pEventDispatcher->removeEventListener(type, listener, useCapture);
+ else
+ _pEventDispatcher = new EventDispatcher;
+
+ _pEventDispatcher->addEventListener(type, listener, useCapture);
+}
+
+
+void AbstractNode::removeEventListener(const XMLString& type, EventListener* listener, bool useCapture)
+{
+ if (_pEventDispatcher)
+ _pEventDispatcher->removeEventListener(type, listener, useCapture);
+}
+
+
+bool AbstractNode::dispatchEvent(Event* evt)
+{
+ if (eventsSuspended()) return true;
+
+ if (evt->type().empty()) throw EventException(EventException::UNSPECIFIED_EVENT_TYPE_ERR);
+
+ evt->setTarget(this);
+ evt->setCurrentPhase(Event::CAPTURING_PHASE);
+
+ if (_pParent) _pParent->captureEvent(evt);
+
+ if (_pEventDispatcher && !evt->isStopped())
+ {
+ evt->setCurrentPhase(Event::AT_TARGET);
+ evt->setCurrentTarget(this);
+ _pEventDispatcher->dispatchEvent(evt);
+ }
+ if (!evt->isStopped() && evt->bubbles() && _pParent)
+ {
+ evt->setCurrentPhase(Event::BUBBLING_PHASE);
+ _pParent->bubbleEvent(evt);
+ }
+
+ return evt->isCanceled();
+}
+
+
+void AbstractNode::captureEvent(Event* evt)
+{
+ if (_pParent)
+ _pParent->captureEvent(evt);
+
+ if (_pEventDispatcher && !evt->isStopped())
+ {
+ evt->setCurrentTarget(this);
+ _pEventDispatcher->captureEvent(evt);
+ }
+}
+
+
+void AbstractNode::bubbleEvent(Event* evt)
+{
+ evt->setCurrentTarget(this);
+ if (_pEventDispatcher)
+ {
+ _pEventDispatcher->bubbleEvent(evt);
+ }
+ if (_pParent && !evt->isStopped())
+ _pParent->bubbleEvent(evt);
+}
+
+
+void AbstractNode::dispatchSubtreeModified()
+{
+ AutoPtr<MutationEvent> pEvent = new MutationEvent(_pOwner, MutationEvent::DOMSubtreeModified, this, true, false, 0);
+ dispatchEvent(pEvent.get());
+}
+
+
+void AbstractNode::dispatchNodeInserted()
+{
+ AutoPtr<MutationEvent> pEvent = new MutationEvent(_pOwner, MutationEvent::DOMNodeInserted, this, true, false, parentNode());
+ dispatchEvent(pEvent.get());
+}
+
+
+void AbstractNode::dispatchNodeRemoved()
+{
+ AutoPtr<MutationEvent> pEvent = new MutationEvent(_pOwner, MutationEvent::DOMNodeRemoved, this, true, false, parentNode());
+ dispatchEvent(pEvent.get());
+}
+
+
+void AbstractNode::dispatchNodeRemovedFromDocument()
+{
+ AutoPtr<MutationEvent> pEvent = new MutationEvent(_pOwner, MutationEvent::DOMNodeRemovedFromDocument, this, false, false, 0);
+ dispatchEvent(pEvent.get());
+}
+
+
+void AbstractNode::dispatchNodeInsertedIntoDocument()
+{
+ AutoPtr<MutationEvent> pEvent = new MutationEvent(_pOwner, MutationEvent::DOMNodeInsertedIntoDocument, this, false, false, 0);
+ dispatchEvent(pEvent.get());
+}
+
+
+void AbstractNode::dispatchAttrModified(Attr* pAttr, MutationEvent::AttrChangeType changeType, const XMLString& prevValue, const XMLString& newValue)
+{
+ AutoPtr<MutationEvent> pEvent = new MutationEvent(_pOwner, MutationEvent::DOMAttrModified, this, true, false, pAttr, prevValue, newValue, pAttr->name(), changeType);
+ dispatchEvent(pEvent.get());
+}
+
+
+void AbstractNode::dispatchCharacterDataModified(const XMLString& prevValue, const XMLString& newValue)
+{
+ AutoPtr<MutationEvent> pEvent = new MutationEvent(_pOwner, MutationEvent::DOMCharacterDataModified, this, true, false, 0, prevValue, newValue, EMPTY_STRING, MutationEvent::MODIFICATION);
+ dispatchEvent(pEvent.get());
+}
+
+
+bool AbstractNode::events() const
+{
+ return _pOwner->events();
+}
+
+
+bool AbstractNode::eventsSuspended() const
+{
+ return _pOwner->eventsSuspended();
+}
+
+
+void AbstractNode::setOwnerDocument(Document* pOwnerDocument)
+{
+ _pOwner = pOwnerDocument;
+}
+
+
+} } // namespace Poco::XML