, public boost::enable_shared_from_this<AutomationControl>
, public ControlGroupMember
{
- public:
+public:
AutomationControl(ARDOUR::Session&,
const Evoral::Parameter& parameter,
const ParameterDescriptor& desc,
const ARDOUR::Session& session() const { return _session; }
void commit_transaction (bool did_write);
- protected:
+protected:
ARDOUR::Session& _session;
boost::shared_ptr<ControlGroup> _group;
/* this will be invoked in turn on behalf of the group or the control by itself */
virtual void do_pre_realtime_queue_stuff (double new_value) {}
- private:
+private:
/* I am unclear on why we have to make ControlGroup a friend in order
to get access to the ::set_group() method when it is already
declared to be a friend in ControlGroupMember. Oh well.
class LIBARDOUR_API MuteControl : public SlavableAutomationControl
{
- public:
+public:
MuteControl (Session& session, std::string const& name, Muteable&);
double get_value () const;
void automation_run (framepos_t start, pframes_t nframes);
- protected:
+protected:
void master_changed (bool, PBD::Controllable::GroupControlDisposition, boost::shared_ptr<AutomationControl>);
void actually_set_value (double, PBD::Controllable::GroupControlDisposition group_override);
void pre_remove_master (boost::shared_ptr<AutomationControl>);
void post_add_master (boost::shared_ptr<AutomationControl>);
- private:
+private:
Muteable& _muteable;
};
/*
-
Copyright (C) 2009 Paul Davis
This program is free software; you can redistribute it and/or modify
: SessionHandleRef (s)
, _muteable (&m)
, _mute_point (MutePoint (0))
- , _muted_by_self (false)
- , _soloed_by_self (false)
- , _soloed_by_others (false)
+ , _muted_by_self (false)
+ , _soloed_by_self (false)
+ , _soloed_by_others (false)
, _muted_by_masters (0)
{
gain_t
MuteMaster::mute_gain_at (MutePoint mp) const
{
- gain_t gain;
-
- if (Config->get_solo_mute_override()) {
- if (_soloed_by_self) {
- gain = GAIN_COEFF_UNITY;
- } else if (muted_by_self_at (mp) || muted_by_masters_at (mp)) {
- gain = GAIN_COEFF_ZERO;
- } else {
- if (!_soloed_by_others && muted_by_others_soloing_at (mp)) {
- gain = Config->get_solo_mute_gain ();
- } else {
- gain = GAIN_COEFF_UNITY;
- }
- }
- } else {
- if (muted_by_self_at (mp) || muted_by_masters_at (mp)) {
- gain = GAIN_COEFF_ZERO;
- } else if (_soloed_by_self || _soloed_by_others) {
- gain = GAIN_COEFF_UNITY;
- } else {
- if (muted_by_others_soloing_at (mp)) {
- gain = Config->get_solo_mute_gain ();
- } else {
- gain = GAIN_COEFF_UNITY;
- }
- }
- }
-
- return gain;
+ gain_t gain;
+
+ if (Config->get_solo_mute_override()) {
+ if (_soloed_by_self) {
+ gain = GAIN_COEFF_UNITY;
+ } else if (muted_by_self_at (mp) || muted_by_masters_at (mp)) {
+ gain = GAIN_COEFF_ZERO;
+ } else {
+ if (!_soloed_by_others && muted_by_others_soloing_at (mp)) {
+ gain = Config->get_solo_mute_gain ();
+ } else {
+ gain = GAIN_COEFF_UNITY;
+ }
+ }
+ } else {
+ if (muted_by_self_at (mp) || muted_by_masters_at (mp)) {
+ gain = GAIN_COEFF_ZERO;
+ } else if (_soloed_by_self || _soloed_by_others) {
+ gain = GAIN_COEFF_UNITY;
+ } else {
+ if (muted_by_others_soloing_at (mp)) {
+ gain = Config->get_solo_mute_gain ();
+ } else {
+ gain = GAIN_COEFF_UNITY;
+ }
+ }
+ }
+
+ return gain;
}
void
MuteMaster::set_mute_points (const std::string& mute_point)
{
- MutePoint old = _mute_point;
+ MutePoint old = _mute_point;
_mute_point = (MutePoint) string_2_enum (mute_point, _mute_point);
- if (old != _mute_point) {
- MutePointChanged(); /* EMIT SIGNAL */
- }
+ if (old != _mute_point) {
+ MutePointChanged(); /* EMIT SIGNAL */
+ }
}
void
MuteMaster::set_mute_points (MutePoint mp)
{
- if (_mute_point != mp) {
- _mute_point = mp;
- MutePointChanged (); /* EMIT SIGNAL */
- }
+ if (_mute_point != mp) {
+ _mute_point = mp;
+ MutePointChanged (); /* EMIT SIGNAL */
+ }
}
int