/* 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 "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: explicit CompiledGraph(GraphImpl& graph); Task& master() { return _master; } private: Task _master; }; MPtr compile(Raul::Maid& maid, GraphImpl& graph); } // namespace Server } // namespace Ingen #endif // INGEN_ENGINE_COMPILEDGRAPH_HPP