/* This file is part of Om. Copyright (C) 2006 Dave Robillard. * * Om is free software; you can redistribute it and/or modify it under the * terms of the GNU General Public License as published by the Free Software * Foundation; either version 2 of the License, or (at your option) any later * version. * * Om 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 General Public License for details. * * You should have received a copy of the GNU General Public License along * with this program; if not, write to the Free Software Foundation, Inc., * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #ifndef CONNECTIONBASE_H #define CONNECTIONBASE_H #include "util/types.h" #include "OutputPort.h" #include "Connection.h" namespace Om { class MidiMessage; class Port; template class InputPort; /** A Connection with a type. * * \ingroup engine */ template class ConnectionBase : public Connection { public: ConnectionBase(OutputPort* const src_port, InputPort* const dst_port); virtual ~ConnectionBase(); void prepare_buffers(); inline OutputPort* src_port() const { return (OutputPort*)m_src_port; } inline InputPort* dst_port() const { return (InputPort*)m_dst_port; } /** Used by some (recursive) events to prevent double disconnections */ bool pending_disconnection() { return m_pending_disconnection; } void pending_disconnection(bool b) { m_pending_disconnection = b; } /** Get the buffer for a particular voice. * A ConnectionBase is smart - it knows the destination port respondering the * buffer, and will return accordingly (ie the same buffer for every voice * in a mono->poly connection). */ inline Buffer* buffer(size_t voice) const; private: // Disallow copies (undefined) ConnectionBase(const ConnectionBase& copy); ConnectionBase& operator=(const ConnectionBase&); Buffer* m_local_buffer; ///< Only used for poly->mono connections bool m_is_poly_to_mono; size_t m_buffer_size; bool m_pending_disconnection; }; template <> inline Buffer* ConnectionBase::buffer(size_t voice) const { PortBase* const src_port = (PortBase*)m_src_port; if (m_is_poly_to_mono) { return m_local_buffer; } else { if (src_port->poly() == 1) return src_port->buffer(0); else return src_port->buffer(voice); } } template <> inline Buffer* ConnectionBase::buffer(size_t voice) const { // No such thing as polyphonic MIDI ports assert(m_src_port->poly() == 1); assert(m_dst_port->poly() == 1); PortBase* const src_port = (PortBase*)m_src_port; return src_port->buffer(0); } template class ConnectionBase; template class ConnectionBase; } // namespace Om #endif // CONNECTIONBASE_H