From d10aab38d5fca62c4da2d98f7c7c6877906ebe58 Mon Sep 17 00:00:00 2001 From: Andreas Stöckel Date: Fri, 2 Jan 2015 23:32:36 +0100 Subject: Added index class which allows to build an index of Nodes stored in a NodeContainer --- src/core/model/Index.cpp | 85 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 85 insertions(+) create mode 100644 src/core/model/Index.cpp (limited to 'src/core/model/Index.cpp') diff --git a/src/core/model/Index.cpp b/src/core/model/Index.cpp new file mode 100644 index 0000000..17565d2 --- /dev/null +++ b/src/core/model/Index.cpp @@ -0,0 +1,85 @@ +/* + Ousía + Copyright (C) 2014, 2015 Benjamin Paaßen, Andreas Stöckel + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + This program 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 General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program. If not, see . +*/ + +#include "Index.hpp" +#include "Node.hpp" + +namespace ousia { + +/* Class Index */ + +void Index::indexHandleNameChange(const Event &ev, Managed *owner, void *data) +{ + // Fetch the referenced node, the index instance and the NameChangeEvent + const NameChangeEvent &nameEv = static_cast(ev); + Handle node = static_cast(ev.sender); + Index &index = *(static_cast(data)); + + // Re-add the node to the index + index.deleteFromIndex(nameEv.oldName, node); + index.addToIndex(nameEv.newName, node); +} + +void Index::addToIndex(const std::string &name, const Handle &node) +{ + if (!name.empty()) { + index.emplace(name, node.get()); + } +} + +void Index::deleteFromIndex(const std::string &name, const Handle &node) +{ + if (!name.empty()) { + auto it = index.find(name); + if (it != index.end() && it->second == node) { + index.erase(it); + } + } +} + +void Index::addElement(Handle node, Managed *owner) +{ + addToIndex(node->getName(), node); + node->registerEvent(EventType::NAME_CHANGE, Index::indexHandleNameChange, + owner, this); +} + +void Index::deleteElement(Handle node, Managed *owner, + bool fromDestructor) +{ + if (!fromDestructor) { + deleteFromIndex(node->getName(), node); + node->unregisterEvent(EventType::NAME_CHANGE, + Index::indexHandleNameChange, owner, this); + } else if (owner) { + owner->getManager().unregisterEvent(node.get(), EventType::NAME_CHANGE, + Index::indexHandleNameChange, owner, + this); + } +} + +Rooted Index::resolve(const std::string &name) const +{ + auto it = index.find(name); + if (it != index.end()) { + return it->second; + } + return nullptr; +} + +} -- cgit v1.2.3