- gain_t gain;
-
- if (Config->get_solo_mute_override()) {
- if (_soloed) {
- gain = GAIN_COEFF_UNITY;
- } else if (muted_by_self_at (mp)) {
- gain = GAIN_COEFF_ZERO;
- } else {
- if (muted_by_others_at (mp)) {
- gain = Config->get_solo_mute_gain ();
- } else {
- gain = GAIN_COEFF_UNITY;
- }
- }
- } else {
- if (muted_by_self_at (mp)) {
- gain = GAIN_COEFF_ZERO;
- } else if (_soloed) {
- gain = GAIN_COEFF_UNITY;
- } else {
- if (muted_by_others_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;