/* This file is part of Ingen. Copyright 2007-2017 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_COMPILEDGRAPH_HPP #define INGEN_ENGINE_COMPILEDGRAPH_HPP #include #include #include #include "ingen/types.hpp" #include "raul/Maid.hpp" #include "raul/Noncopyable.hpp" #include "Task.hpp" namespace Ingen { namespace Server { class BlockImpl; class GraphImpl; /** A graph ``compiled'' into a quickly executable form. * * This is a flat sequence of nodes ordered such that the process thread can * execute the nodes in order and have nodes always executed before any of * their dependencies. */ class CompiledGraph : public Raul::Maid::Disposable , public Raul::Noncopyable { public: static MPtr compile(Raul::Maid& maid, GraphImpl& graph); Task& master() { return *_master; } private: friend class Raul::Maid; ///< Allow make_managed to construct CompiledGraph(GraphImpl* graph); typedef std::set BlockSet; void dump(const std::string& name) const; void compile_graph(GraphImpl* graph); void compile_block(BlockImpl* n, Task& task, BlockSet& k); void compile_provider(const BlockImpl* root, BlockImpl* block, Task& task, BlockSet& k); std::unique_ptr _master; }; inline MPtr compile(Raul::Maid& maid, GraphImpl& graph) { return CompiledGraph::compile(maid, graph); } } // namespace Server } // namespace Ingen #endif // INGEN_ENGINE_COMPILEDGRAPH_HPP