/*
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_EDGE_IMPL_HPP
#define INGEN_ENGINE_EDGE_IMPL_HPP
#include
#include
#include
#include
#include "ingen/Edge.hpp"
#include "lv2/lv2plug.in/ns/ext/atom/atom.h"
#include "raul/Deletable.hpp"
#include "raul/log.hpp"
#include "BufferFactory.hpp"
#include "Context.hpp"
namespace Ingen {
namespace Server {
class PortImpl;
class OutputPort;
class InputPort;
class Buffer;
class BufferFactory;
/** Represents a single inbound connection for an InputPort.
*
* This can be a group of ports (ie coming from a polyphonic Node) or
* a single Port. This class exists basically as an abstraction of mixing
* down polyphonic inputs, so InputPort can just deal with mixing down
* multiple connections (oblivious to the polyphonic situation of the
* connection itself).
*
* This is stored in an intrusive slist in InputPort.
*
* \ingroup engine
*/
class EdgeImpl
: public Raul::Deletable
, private Raul::Noncopyable
, public Edge
, public boost::intrusive::slist_base_hook<
boost::intrusive::link_mode >
{
public:
EdgeImpl(PortImpl* tail, PortImpl* head);
PortImpl* tail() const { return _tail; }
PortImpl* head() const { return _head; }
const Raul::Path& tail_path() const;
const Raul::Path& head_path() const;
void queue(Context& context);
void get_sources(Context& context,
uint32_t voice,
boost::intrusive_ptr* srcs,
uint32_t max_num_srcs,
uint32_t& num_srcs);
/** Get the buffer for a particular voice.
* An Edge is smart - it knows the destination port requesting the
* buffer, and will return accordingly (e.g. the same buffer for every
* voice in a mono->poly edge).
*/
BufferRef buffer(uint32_t voice) const;
/** Whether this edge must mix down voices into a local buffer */
bool must_mix() const;
/** Whether this edge crosses contexts and must buffer */
bool must_queue() const;
static bool can_connect(const OutputPort* src, const InputPort* dst);
protected:
void dump() const;
PortImpl* const _tail;
PortImpl* const _head;
Raul::RingBuffer* _queue;
};
} // namespace Server
} // namespace Ingen
#endif // INGEN_ENGINE_EDGEIMPL_HPP