summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--libs/ardour/ardour/vca.h32
-rw-r--r--libs/ardour/vca.cc11
2 files changed, 40 insertions, 3 deletions
diff --git a/libs/ardour/ardour/vca.h b/libs/ardour/ardour/vca.h
index a3dfb3ec07..926cd500e0 100644
--- a/libs/ardour/ardour/vca.h
+++ b/libs/ardour/ardour/vca.h
@@ -28,6 +28,8 @@
#include "ardour/automatable.h"
#include "ardour/muteable.h"
+#include "ardour/monitorable.h"
+#include "ardour/recordable.h"
#include "ardour/soloable.h"
#include "ardour/slavable.h"
#include "ardour/stripable.h"
@@ -40,7 +42,14 @@ class SoloControl;
class MuteControl;
class MonitorControl;
-class LIBARDOUR_API VCA : public Stripable, public Soloable, public Muteable, public Automatable, public Slavable, public boost::enable_shared_from_this<VCA> {
+class LIBARDOUR_API VCA : public Stripable,
+ public Soloable,
+ public Muteable,
+ public Automatable,
+ public Slavable,
+ public Recordable,
+ public Monitorable,
+ public boost::enable_shared_from_this<VCA> {
public:
VCA (Session& session, uint32_t num, const std::string& name);
~VCA();
@@ -52,6 +61,8 @@ class LIBARDOUR_API VCA : public Stripable, public Soloable, public Muteable, pu
XMLNode& get_state();
int set_state (XMLNode const&, int version);
+ /* Soloable API */
+
void clear_all_solo_state ();
bool soloed () const;
@@ -60,9 +71,21 @@ class LIBARDOUR_API VCA : public Stripable, public Soloable, public Muteable, pu
bool can_solo() const { return true; }
bool is_safe () const { return false; }
+ /* Muteable API */
+
bool can_be_muted_by_others () const { return true; }
bool muted_by_others_soloing() const { return false; }
+ /* Recordable API */
+
+ int prep_record_enabled (bool yn) { return 0; }
+ bool can_be_record_enabled() { return true; }
+ bool can_be_record_safe() { return true; }
+
+ /* Monitorable API */
+
+ MonitorState monitoring_state() const;
+
static std::string default_name_template ();
static int next_vca_number ();
static std::string xml_node_name;
@@ -74,6 +97,8 @@ class LIBARDOUR_API VCA : public Stripable, public Soloable, public Muteable, pu
virtual boost::shared_ptr<GainControl> gain_control() const { return _gain_control; }
virtual boost::shared_ptr<SoloControl> solo_control() const { return _solo_control; }
virtual boost::shared_ptr<MuteControl> mute_control() const { return _mute_control; }
+ virtual boost::shared_ptr<AutomationControl> recenable_control() const { return _recenable_control; }
+ virtual boost::shared_ptr<MonitorControl> monitoring_control() const { return _monitor_control; }
/* null Stripable API, because VCAs don't have any of this */
@@ -81,8 +106,6 @@ class LIBARDOUR_API VCA : public Stripable, public Soloable, public Muteable, pu
virtual boost::shared_ptr<const PeakMeter> peak_meter() const { return boost::shared_ptr<PeakMeter>(); }
virtual boost::shared_ptr<PhaseControl> phase_control() const { return boost::shared_ptr<PhaseControl>(); }
virtual boost::shared_ptr<GainControl> trim_control() const { return boost::shared_ptr<GainControl>(); }
- virtual boost::shared_ptr<MonitorControl> monitoring_control() const { return boost::shared_ptr<MonitorControl>(); }
- virtual boost::shared_ptr<AutomationControl> recenable_control() const { return boost::shared_ptr<AutomationControl>(); }
virtual boost::shared_ptr<AutomationControl> pan_azimuth_control() const { return boost::shared_ptr<AutomationControl>(); }
virtual boost::shared_ptr<AutomationControl> pan_elevation_control() const { return boost::shared_ptr<AutomationControl>(); }
virtual boost::shared_ptr<AutomationControl> pan_width_control() const { return boost::shared_ptr<AutomationControl>(); }
@@ -119,6 +142,9 @@ class LIBARDOUR_API VCA : public Stripable, public Soloable, public Muteable, pu
boost::shared_ptr<GainControl> _gain_control;
boost::shared_ptr<SoloControl> _solo_control;
boost::shared_ptr<MuteControl> _mute_control;
+ boost::shared_ptr<AutomationControl> _recenable_control;
+ // boost::shared_ptr<AutomationControl> _record_safe_control;
+ boost::shared_ptr<MonitorControl> _monitor_control;
static gint next_number;
diff --git a/libs/ardour/vca.cc b/libs/ardour/vca.cc
index 72c0a2cdcb..d1e93cc403 100644
--- a/libs/ardour/vca.cc
+++ b/libs/ardour/vca.cc
@@ -20,7 +20,9 @@
#include "ardour/automation_control.h"
#include "ardour/gain_control.h"
+#include "ardour/monitor_control.h"
#include "ardour/rc_configuration.h"
+#include "ardour/record_enable_control.h"
#include "ardour/route.h"
#include "ardour/session.h"
#include "ardour/vca.h"
@@ -75,6 +77,8 @@ VCA::init ()
{
_solo_control.reset (new SoloControl (_session, X_("solo"), *this, *this));
_mute_control.reset (new MuteControl (_session, X_("mute"), *this));
+ _recenable_control.reset (new RecordEnableControl (_session, X_("recenable"), *this));
+ _monitor_control.reset (new MonitorControl (_session, X_("monitoring"), *this));
add_control (_gain_control);
add_control (_solo_control);
@@ -183,3 +187,10 @@ VCA::unassign_controls (boost::shared_ptr<VCA> vca)
return 0;
}
+
+MonitorState
+VCA::monitoring_state () const
+{
+ /* XXX this has to get more complex but not clear how */
+ return MonitoringInput;
+}