/*
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 .
*/
#include
#include "ingen/shared/URIs.hpp"
#include "Buffer.hpp"
#include "DuplexPort.hpp"
#include "OutputPort.hpp"
using namespace std;
namespace Ingen {
namespace Server {
DuplexPort::DuplexPort(BufferFactory& bufs,
NodeImpl* parent,
const string& name,
uint32_t index,
bool polyphonic,
uint32_t poly,
PortType type,
LV2_URID buffer_type,
const Raul::Atom& value,
size_t buffer_size,
bool is_output)
: PortImpl(bufs, parent, name, index, poly, type, buffer_type, value, buffer_size)
, InputPort(bufs, parent, name, index, poly, type, buffer_type, value, buffer_size)
, OutputPort(bufs, parent, name, index, poly, type, buffer_type, value, buffer_size)
, _is_output(is_output)
{
set_property(bufs.uris().ingen_polyphonic,
bufs.forge().make(polyphonic));
}
bool
DuplexPort::get_buffers(Context& context,
BufferFactory& bufs,
Raul::Array* buffers,
uint32_t poly) const
{
if (_is_output) {
return InputPort::get_buffers(context, bufs, buffers, poly);
} else {
return OutputPort::get_buffers(context, bufs, buffers, poly);
}
}
/** Prepare for the execution of parent patch */
void
DuplexPort::pre_process(Context& context)
{
if (_is_output) {
/* This is a patch output, which is an input from the internal
perspective. Prepare buffers for write so plugins can deliver to
them */
for (uint32_t v = 0; v < _poly; ++v) {
_buffers->at(v)->prepare_write(context);
}
} else {
/* This is a a patch input, which is an output from the internal
perspective. Do whatever a normal node's input port does to prepare
input for reading. */
InputPort::pre_process(context);
}
}
/** Finalize after the execution of parent patch (deliver outputs) */
void
DuplexPort::post_process(Context& context)
{
if (_is_output) {
/* This is a patch output, which is an input from the internal
perspective. Mix down input delivered by plugins so output
(external perspective) is ready. */
InputPort::pre_process(context);
if (_broadcast)
broadcast_value(context, false);
}
}
} // namespace Server
} // namespace Ingen