/*
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:
std::unique_ptr _master;
};
MPtr compile(Raul::Maid& maid, GraphImpl& graph);
} // namespace Server
} // namespace Ingen
#endif // INGEN_ENGINE_COMPILEDGRAPH_HPP