/*
This file is part of Ingen.
Copyright 2007-2012 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_DRIVER_HPP
#define INGEN_ENGINE_DRIVER_HPP
#include
#include
#include "raul/Deletable.hpp"
#include "DuplexPort.hpp"
namespace Raul { class Path; }
namespace Ingen {
namespace Server {
class DuplexPort;
class EnginePort;
/** Driver abstract base class.
*
* A Driver is, from the perspective of GraphObjects (nodes, patches, ports) an
* interface for managing system ports. An implementation of Driver basically
* needs to manage DriverPorts, and handle writing/reading data to/from them.
*
* \ingroup engine
*/
class Driver : boost::noncopyable {
public:
virtual ~Driver() {}
/** Activate driver (begin processing graph and events). */
virtual void activate() {}
/** Deactivate driver (stop processing graph and events). */
virtual void deactivate() {}
/** Create a port ready to be inserted with add_input (non realtime).
* May return NULL if the Driver can not create the port for some reason.
*/
virtual EnginePort* create_port(DuplexPort* patch_port) = 0;
/** Return the DriverPort for a particular path, iff one exists. */
virtual EnginePort* engine_port(ProcessContext& context,
const Raul::Path& path) = 0;
/** Find a system port by path. */
virtual EnginePort* port(const Raul::Path& path) = 0;
/** Add a system visible port (e.g. a port on the root patch). */
virtual void add_port(ProcessContext& context, EnginePort* port) = 0;
/** Remove a system visible port. */
virtual Raul::Deletable* remove_port(ProcessContext& context,
EnginePort* port) = 0;
/** Return the audio buffer size in frames */
virtual SampleCount block_length() const = 0;
/** Return the sample rate in Hz */
virtual SampleCount sample_rate() const = 0;
/** Return the current frame time (running counter) */
virtual SampleCount frame_time() const = 0;
/** Return true iff the driver is running in real-time mode */
virtual bool is_realtime() const = 0;
};
} // namespace Server
} // namespace Ingen
#endif // INGEN_ENGINE_DRIVER_HPP