// SPDX-License-Identifier: GPL-2.0-or-later /** @file * @brief Object representing a subtree of the XML document *//* * Authors: see git history * * Copyright (C) 2015 Authors * Copyright 2005 MenTaLguY * * Released under GNU GPL v2+, read the file 'COPYING' for more information. */ #ifndef SEEN_INKSCAPE_XML_SUBTREE_H #define SEEN_INKSCAPE_XML_SUBTREE_H #include "inkgc/gc-managed.h" #include "xml/composite-node-observer.h" namespace Inkscape { namespace XML { /** * @brief Represents a node and all its descendants * * This is a convenience object for node operations that affect all of the node's descendants. * Currently the only such operations are adding and removing subtree observers * and synthesizing events for the entire subtree. */ class Subtree : public GC::Managed { public: Subtree(Node &root); ~Subtree(); /** * @brief Synthesize events for the entire subtree * * This method notifies the specified observer of node changes equivalent to creating * this subtree from scratch. The notifications recurse into the tree depth-first. * Currently this is the only method that provides extra functionality compared to * the public methods of Node. */ void synthesizeEvents(NodeObserver &observer); /** * @brief Add an observer watching for subtree changes * * Equivalent to Node::addSubtreeObserver(). */ void addObserver(NodeObserver &observer); /** * @brief Add an observer watching for subtree changes * * Equivalent to Node::removeSubtreeObserver(). */ void removeObserver(NodeObserver &observer); private: Node &_root; CompositeNodeObserver _observers; }; } } #endif /* Local Variables: mode:c++ c-file-style:"stroustrup" c-file-offsets:((innamespace . 0)(inline-open . 0)(case-label . +)) indent-tabs-mode:nil fill-column:99 End: */ // vim: filetype=cpp:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:fileencoding=utf-8:textwidth=99 :