/* This file is part of Ingen. Copyright 2007-2015 David Robillard Ingen is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or any later version. Ingen 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 Affero General Public License for details. You should have received a copy of the GNU Affero General Public License along with Ingen. If not, see . */ #ifndef INGEN_ENGINE_NODEIMPL_HPP #define INGEN_ENGINE_NODEIMPL_HPP #include #include #include #include #include #include namespace ingen { class Atom; class URIs; namespace server { class BufferFactory; class GraphImpl; class RunContext; /** An object on the audio graph (a Graph, Block, or Port). * * Each of these is a raul::Deletable and so can be deleted in a realtime safe * way from anywhere, and they all have a map of variable for clients to store * arbitrary values in (which the engine puts no significance to whatsoever). * * \ingroup engine */ class NodeImpl : public Node { public: const raul::Symbol& symbol() const override { return _symbol; } Node* graph_parent() const override { return _parent; } NodeImpl* parent() const { return _parent; } /** Rename */ void set_path(const raul::Path& new_path) override { _path = new_path; const char* const new_sym = new_path.symbol(); if (new_sym[0] != '\0') { _symbol = raul::Symbol(new_sym); } set_uri(path_to_uri(new_path)); } const Atom& get_property(const URI& key) const override; /** The Graph this object is a child of. */ virtual GraphImpl* parent_graph() const; const raul::Path& path() const override { return _path; } /** Prepare for a new (external) polyphony value. * * Preprocessor thread, poly is actually applied by apply_poly. * \return true on success. */ virtual bool prepare_poly(BufferFactory& bufs, uint32_t poly) = 0; /** Apply a new (external) polyphony value. * * \param ctx Process context (process thread only). * \param poly Must be <= the most recent value passed to prepare_poly. */ virtual bool apply_poly(RunContext& ctx, uint32_t poly) = 0; /** Return true iff this is main (the top level Node). * * This is sometimes called "the root graph", but the term "main" is used * to avoid ambiguity with the root path, since main does not have the path * "/", but usually "/main" to leave namespace for non-node things. */ bool is_main() const { return !_parent; } protected: NodeImpl(const ingen::URIs& uris, NodeImpl* parent, const raul::Symbol& symbol); NodeImpl* _parent; raul::Path _path; raul::Symbol _symbol; }; } // namespace server } // namespace ingen #endif // INGEN_ENGINE_NODEIMPL_HPP