X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fardour%2Fmute_master.h;h=d0e261e059255566dc2d9345dc0dab973fa46133;hb=a1c5d1be43007265ef1257889a3138b0fa75c2ac;hp=0e3c10b795b02e6a2250c3b59cdbcef84e02fecb;hpb=11792ed95dc9b9435045f1830eb4cf298e6d475d;p=ardour.git diff --git a/libs/ardour/ardour/mute_master.h b/libs/ardour/ardour/mute_master.h index 0e3c10b795..d0e261e059 100644 --- a/libs/ardour/ardour/mute_master.h +++ b/libs/ardour/ardour/mute_master.h @@ -20,50 +20,72 @@ #ifndef __ardour_mute_master_h__ #define __ardour_mute_master_h__ -#include "evoral/Parameter.hpp" +#include + #include "pbd/signals.h" #include "pbd/stateful.h" +#include "evoral/Parameter.hpp" + +#include "ardour/session_handle.h" +#include "ardour/types.h" + namespace ARDOUR { class Session; +class Muteable; -class MuteMaster : public PBD::Stateful +class LIBARDOUR_API MuteMaster : public SessionHandleRef, public PBD::Stateful { - public: +public: + /** deliveries to mute when the channel is "muted" */ enum MutePoint { - PreFader = 0x1, - PostFader = 0x2, - Listen = 0x4, - Main = 0x8 + PreFader = 0x1, ///< mute all pre-fader sends + PostFader = 0x2, ///< mute all post-fader sends + Listen = 0x4, ///< mute listen out + Main = 0x8 ///< mute main out }; static const MutePoint AllPoints; - MuteMaster (Session& s, const std::string& name); + MuteMaster (Session& s, Muteable&, const std::string& name); ~MuteMaster() {} - bool muted_pre_fader() const { return _mute_point & PreFader; } - bool muted_post_fader() const { return _mute_point & PostFader; } - bool muted_listen() const { return _mute_point & Listen; } - bool muted_main () const { return _mute_point & Main; } - - bool muted_at (MutePoint mp) const { return _mute_point & mp; } - bool muted() const { return _mute_point != MutePoint (0); } + bool muted_by_self () const { return _muted_by_self && (_mute_point != MutePoint (0)); } + bool muted_by_self_at (MutePoint mp) const { return _muted_by_self && (_mute_point & mp); } + bool muted_by_others_soloing_at (MutePoint mp) const; + bool muted_by_masters () const { return _muted_by_masters && (_mute_point != MutePoint (0)); } + bool muted_by_masters_at (MutePoint mp) const { return _muted_by_masters && (_mute_point & mp); } gain_t mute_gain_at (MutePoint) const; - void clear_mute (); + void set_muted_by_self (bool yn) { _muted_by_self = yn; } + void mute_at (MutePoint); void unmute_at (MutePoint); + void set_mute_points (const std::string& mute_point); + void set_mute_points (MutePoint); + MutePoint mute_points() const { return _mute_point; } + + void set_soloed_by_self (bool yn) { _soloed_by_self = yn; } + void set_soloed_by_others (bool yn) { _soloed_by_others = yn; } + + void set_muted_by_masters (bool); + PBD::Signal0 MutePointChanged; XMLNode& get_state(); int set_state(const XMLNode&, int version); + static const std::string xml_node_name; - private: +private: + Muteable* _muteable; MutePoint _mute_point; + bool _muted_by_self; + bool _soloed_by_self; + bool _soloed_by_others; + bool _muted_by_masters; }; } // namespace ARDOUR