/*
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