boost::shared_ptr<PannerShell> panner_shell() const { return _panshell; }
boost::shared_ptr<Panner> panner() const;
+ void unpan ();
void reset_panner ();
void defer_pan_reset ();
void allow_pan_reset ();
void send_to_going_away ();
void send_to_property_changed (const PBD::PropertyChange&);
int connect_when_legal ();
- int set_our_state (XMLNode const &, int);
+ void init_gain ();
int use_target (boost::shared_ptr<Route>);
};
framecnt_t update_port_latencies (PortSet& ports, PortSet& feeders, bool playback, framecnt_t) const;
void setup_invisible_processors ();
+ void unpan ();
boost::shared_ptr<CapturingProcessor> _capturing_processor;
return 0;
}
+void
+Delivery::unpan ()
+{
+ /* caller must hold process lock */
+
+ _panshell.reset ();
+}
+
void
Delivery::reset_panner ()
{
#include "pbd/failed_constructor.h"
+#include "ardour/audio_buffer.h"
#include "ardour/internal_return.h"
#include "ardour/mute_master.h"
#include "ardour/session.h"
}
}
+#if 0
+ if (_session.transport_rolling()) {
+ for (BufferSet::audio_iterator b = bufs.audio_begin(); b != bufs.audio_end(); ++b) {
+ Sample* p = b->data ();
+ for (pframes_t n = 0; n < nframes; ++n) {
+ if (p[n] != 0.0) {
+ cerr << "\tnon-zero data received\n";
+ break;
+ }
+ }
+ }
+ }
+#endif
+
+
_active = _pending_active;
}
#include "pbd/failed_constructor.h"
#include "ardour/amp.h"
+#include "ardour/audio_buffer.h"
#include "ardour/internal_send.h"
#include "ardour/meter.h"
#include "ardour/route.h"
}
}
- _amp->set_gain (0, this);
+ init_gain ();
}
InternalSend::~InternalSend ()
}
}
+void
+InternalSend::init_gain ()
+{
+ if (_role == Listen) {
+ /* send to monitor bus is always at unity */
+ _amp->set_gain (1.0, this);
+ } else {
+ /* aux sends start at -inf dB */
+ _amp->set_gain (0, this);
+ }
+}
+
int
InternalSend::use_target (boost::shared_ptr<Route> sendto)
{
return 0;
}
-
void
InternalSend::send_to_going_away ()
{
}
}
+#if 0
+ if (_session.transport_rolling()) {
+ for (BufferSet::audio_iterator b = mixbufs.audio_begin(); b != mixbufs.audio_end(); ++b) {
+ Sample* p = b->data ();
+ for (pframes_t n = 0; n < nframes; ++n) {
+ if (p[n] != 0.0) {
+ cerr << "\tnon-zero data SENT to " << b->data() << endl;
+ break;
+ }
+ }
+ }
+ }
+#endif
+
/* target will pick up our output when it is ready */
out:
}
int
-InternalSend::set_our_state (const XMLNode& node, int /*version*/)
+InternalSend::set_state (const XMLNode& node, int version)
{
const XMLProperty* prop;
+ Send::set_state (node, version);
+
+ init_gain ();
+
if ((prop = node.property ("target")) != 0) {
_send_to_id = prop->value();
return 0;
}
-int
-InternalSend::set_state (const XMLNode& node, int version)
-{
- Send::set_state (node, version);
- return set_our_state (node, version);
-}
-
int
InternalSend::connect_when_legal ()
{
_mute_master->set_solo_ignore (true);
}
+ if (is_monitor()) {
+ /* monitor bus does not get a panner, but if (re)created
+ via XML, it will already have one by the time we
+ call ::set_state(). so ... remove it.
+ */
+ unpan ();
+ }
+
/* add all processors (except amp, which is always present) */
nlist = node.children();
if (prop->value() == "intsend") {
processor.reset (new InternalSend (_session, _pannable, _mute_master, boost::shared_ptr<Route>(), Delivery::Role (0)));
+
} else if (prop->value() == "ladspa" || prop->value() == "Ladspa" ||
prop->value() == "lv2" ||
prop->value() == "vst" ||
return true;
}
+void
+Route::unpan ()
+{
+ Glib::Mutex::Lock lm (AudioEngine::instance()->process_lock ());
+ Glib::RWLock::ReaderLock lp (_processor_lock);
+
+ _pannable.reset ();
+
+ for (ProcessorList::iterator i = _processors.begin(); i != _processors.end(); ++i) {
+ boost::shared_ptr<Delivery> d = boost::dynamic_pointer_cast<Delivery>(*i);
+ if (d) {
+ d->unpan ();
+ }
+ }
+}