merge with master, primarily for adrian's maximise-mixer change
[ardour.git] / libs / surfaces / mackie / mcp_buttons.cc
index 84674cb7afd62ea178ce6b47c0b9689291e92fdf..792813bf33d9798691d6d8b799a68eb94627235b 100644 (file)
        Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 */
 
+#include <algorithm>
+
 #include "pbd/memento_command.h"
 
+#include "ardour/debug.h"
 #include "ardour/session.h"
 #include "ardour/route.h"
 #include "ardour/location.h"
 #include "ardour/rc_configuration.h"
 
 #include "mackie_control_protocol.h"
+#include "surface.h"
+#include "fader.h"
 
 #include "i18n.h"
 
@@ -34,6 +39,7 @@
 
 using namespace Mackie;
 using namespace ARDOUR;
+using namespace PBD;
 using std::string;
 
 LedState
@@ -64,12 +70,14 @@ LedState
 MackieControlProtocol::control_press (Button &)
 {
        _modifier_state |= MODIFIER_CONTROL;
+       DEBUG_TRACE (DEBUG::MackieControl, string_compose ("CONTROL Press: modifier state now set to %1\n", _modifier_state));
        return on;
 }
 LedState
 MackieControlProtocol::control_release (Button &)
 {
        _modifier_state &= ~MODIFIER_CONTROL;
+       DEBUG_TRACE (DEBUG::MackieControl, string_compose ("CONTROL Release: modifier state now set to %1\n", _modifier_state));
        return on;
 }
 LedState
@@ -89,21 +97,18 @@ LedState
 MackieControlProtocol::left_press (Button &)
 {
        Sorted sorted = get_sorted_routes();
-       if (sorted.size() > route_table.size()) {
-               int new_initial = _current_initial_bank - route_table.size();
-               if (new_initial < 0) {
-                       new_initial = 0;
-               }
-               
-               if (new_initial != int (_current_initial_bank)) {
-                       session->set_dirty();
-                       switch_banks (new_initial);
-               }
+       uint32_t strip_cnt = n_strips (); 
 
-               return on;
+       DEBUG_TRACE (DEBUG::MackieControl, string_compose ("bank left with current initial = %1 nstrips = %2 tracks/busses = %3\n",
+                                                          _current_initial_bank, strip_cnt, sorted.size()));
+
+       if (_current_initial_bank > strip_cnt) {
+               switch_banks (_current_initial_bank - strip_cnt);
        } else {
-               return flashing;
+               switch_banks (0);
        }
+
+       return on;
 }
 
 LedState 
@@ -116,23 +121,16 @@ LedState
 MackieControlProtocol::right_press (Button &)
 {
        Sorted sorted = get_sorted_routes();
-       if (sorted.size() > route_table.size()) {
-               uint32_t delta = sorted.size() - (route_table.size() + _current_initial_bank);
+       uint32_t strip_cnt = n_strips();
+       uint32_t route_cnt = sorted.size();
 
-               if (delta > route_table.size()) {
-                       delta = route_table.size();
-               }
-               
-               if (delta > 0) {
-                       session->set_dirty();
-                       switch_banks (_current_initial_bank + delta);
-               }
+       DEBUG_TRACE (DEBUG::MackieControl, string_compose ("bank right with current initial = %1 nstrips = %2 tracks/busses = %3\n",
+                                                          _current_initial_bank, strip_cnt, route_cnt));
 
-               return on;
-       } else {
-               return flashing;
-       }
-       return off;
+       uint32_t new_initial = std::min (_current_initial_bank + strip_cnt, route_cnt - 1);
+       switch_banks (new_initial);
+
+       return on;
 }
 
 LedState 
@@ -155,6 +153,19 @@ MackieControlProtocol::cursor_left_press (Button& )
                } else {
                        ZoomOut (); /* EMIT SIGNAL */
                }
+       } else {
+               float page_fraction;
+               if (_modifier_state == MODIFIER_CONTROL) {
+                       page_fraction = 1.0;
+               } else if (_modifier_state == MODIFIER_OPTION) {
+                       page_fraction = 0.1;
+               } else if (_modifier_state == MODIFIER_SHIFT) {
+                       page_fraction = 2.0;
+               } else {
+                       page_fraction = 0.25;
+               }
+
+               ScrollTimeline (-page_fraction);
        }
 
        return off;
@@ -176,8 +187,21 @@ MackieControlProtocol::cursor_right_press (Button& )
                } else {
                        ZoomIn (); /* EMIT SIGNAL */
                }
-       }
+       } else {
+               float page_fraction;
+               if (_modifier_state == MODIFIER_CONTROL) {
+                       page_fraction = 1.0;
+               } else if (_modifier_state == MODIFIER_OPTION) {
+                       page_fraction = 0.1;
+               } else if (_modifier_state == MODIFIER_SHIFT) {
+                       page_fraction = 2.0;
+               } else {
+                       page_fraction = 0.25;
+               }
 
+               ScrollTimeline (page_fraction);
+       }
+                       
        return off;
 }
 
@@ -191,11 +215,14 @@ LedState
 MackieControlProtocol::cursor_up_press (Button&)
 {
        if (_zoom_mode) {
-               if (_modifier_state & MODIFIER_OPTION) {
-                       VerticalZoomOutSelected (); /* EMIT SIGNAL */
+               
+               if (_modifier_state & MODIFIER_CONTROL) {
+                       VerticalZoomInSelected (); /* EMIT SIGNAL */
                } else {
-                       VerticalZoomOutAll (); /* EMIT SIGNAL */
+                       VerticalZoomInAll (); /* EMIT SIGNAL */
                }
+       } else {
+               StepTracksUp (); /* EMIT SIGNAL */
        }
        return off;
 }
@@ -210,12 +237,13 @@ LedState
 MackieControlProtocol::cursor_down_press (Button&)
 {
        if (_zoom_mode) {
-               
                if (_modifier_state & MODIFIER_OPTION) {
-                       VerticalZoomInSelected (); /* EMIT SIGNAL */
+                       VerticalZoomOutSelected (); /* EMIT SIGNAL */
                } else {
-                       VerticalZoomInAll (); /* EMIT SIGNAL */
+                       VerticalZoomOutAll (); /* EMIT SIGNAL */
                }
+       } else {
+               StepTracksDown (); /* EMIT SIGNAL */
        }
        return off;
 }
@@ -230,7 +258,7 @@ LedState
 MackieControlProtocol::channel_left_press (Button &)
 {
        Sorted sorted = get_sorted_routes();
-       if (sorted.size() > route_table.size()) {
+       if (sorted.size() > n_strips()) {
                prev_track();
                return on;
        } else {
@@ -248,7 +276,7 @@ LedState
 MackieControlProtocol::channel_right_press (Button &)
 {
        Sorted sorted = get_sorted_routes();
-       if (sorted.size() > route_table.size()) {
+       if (sorted.size() > n_strips()) {
                next_track();
                return on;
        } else {
@@ -278,14 +306,16 @@ MackieControlProtocol::zoom_release (Mackie::Button &)
 Mackie::LedState 
 MackieControlProtocol::scrub_press (Mackie::Button &)
 {
-       _scrub_mode = !_scrub_mode;
-       return (_scrub_mode ? on : off);
+       if (!surfaces.empty()) {
+               surfaces.front()->next_jog_mode ();
+       }
+       return none;
 }
 
 Mackie::LedState 
 MackieControlProtocol::scrub_release (Mackie::Button &)
 {
-       return (_scrub_mode ? on : off);
+       return none;
 }
 
 LedState
@@ -375,17 +405,11 @@ MackieControlProtocol::timecode_beats_release (Button &)
 LedState 
 MackieControlProtocol::marker_press (Button &)
 {
-       // cut'n'paste from LocationUI::add_new_location()
        string markername;
-       framepos_t where = session->audible_frame();
-       session->locations()->next_available_name(markername,"mcu");
-       Location *location = new Location (*session, where, where, markername, Location::IsMark);
-       session->begin_reversible_command (_("add marker"));
-       XMLNode &before = session->locations()->get_state();
-       session->locations()->add (location, true);
-       XMLNode &after = session->locations()->get_state();
-       session->add_command (new MementoCommand<Locations>(*(session->locations()), &before, &after));
-       session->commit_reversible_command ();
+
+       session->locations()->next_available_name (markername,"mcu");
+       add_marker (markername);
+
        return on;
 }
 
@@ -405,22 +429,21 @@ MackieControlProtocol::frm_left_press (Button &)
        // can use first_mark_before/after as well
        unsigned long elapsed = _frm_left_last.restart();
 
-       Location * loc = session->locations()->first_location_before (
-               session->transport_frame()
-       );
-
+       framepos_t pos = session->locations()->first_mark_before (session->transport_frame());
+       
        // allow a quick double to go past a previous mark
-       if (session->transport_rolling() && elapsed < 500 && loc != 0) {
-               Location * loc_two_back = session->locations()->first_location_before (loc->start());
-               if (loc_two_back != 0)
-               {
-                       loc = loc_two_back;
+       if (session->transport_rolling() && elapsed < 500 && pos >= 0) {
+               framepos_t pos_two_back = session->locations()->first_mark_before (pos);
+               if (pos_two_back >= 0) {
+                       pos = pos_two_back;
                }
        }
 
        // move to the location, if it's valid
-       if (loc != 0) {
-               session->request_locate (loc->start(), session->transport_rolling());
+       if (pos >= 0) {
+               session->request_locate (pos, session->transport_rolling());
+       } else {
+               session->request_locate (session->current_start_frame(), session->transport_rolling());
        }
 
        return on;
@@ -436,10 +459,12 @@ LedState
 MackieControlProtocol::frm_right_press (Button &)
 {
        // can use first_mark_before/after as well
-       Location * loc = session->locations()->first_location_after (session->transport_frame());
+       framepos_t pos = session->locations()->first_mark_after (session->transport_frame());
        
-       if (loc != 0) {
-               session->request_locate (loc->start(), session->transport_rolling());
+       if (pos >= 0) {
+               session->request_locate (pos, session->transport_rolling());
+       } else {
+               session->request_locate (session->current_end_frame(), session->transport_rolling());
        }
                
        return on;
@@ -454,7 +479,7 @@ MackieControlProtocol::frm_right_release (Button &)
 LedState 
 MackieControlProtocol::stop_press (Button &)
 {
-       session->request_stop();
+       transport_stop ();
        return on;
 }
 
@@ -467,96 +492,83 @@ MackieControlProtocol::stop_release (Button &)
 LedState 
 MackieControlProtocol::play_press (Button &)
 {
-       session->request_transport_speed (1.0);
-       return on;
+       /* if we're already rolling at normal speed, and we're pressed
+          again, jump back to where we started last time
+       */
+
+       transport_play (session->transport_speed() == 1.0);
+       return none;
 }
 
 LedState 
 MackieControlProtocol::play_release (Button &)
 {
-       return session->transport_rolling();
+       return none;
 }
 
 LedState 
 MackieControlProtocol::record_press (Button &)
 {
-       if (session->get_record_enabled()) {
-               session->disable_record (false);
-       } else {
-               session->maybe_enable_record();
-       }
-       return on;
+       rec_enable_toggle ();
+       return none;
 }
 
 LedState 
 MackieControlProtocol::record_release (Button &)
 {
-       if (session->get_record_enabled()) {
-               if (session->transport_rolling()) {
-                       return on;
-               } else {
-                       return flashing;
-               }
-       } else {
-               return off;
-       }
+       return none;
 }
 
 LedState 
 MackieControlProtocol::rewind_press (Button &)
 {
-       _jog_wheel.push (JogWheel::speed);
-       _jog_wheel.transport_direction (-1);
-       session->request_transport_speed (-_jog_wheel.transport_speed());
-       return on;
+       if (_modifier_state == MODIFIER_CONTROL) {
+               goto_start ();
+       } else {
+               rewind ();
+       }
+       return none;
 }
 
 LedState 
 MackieControlProtocol::rewind_release (Button &)
 {
-       _jog_wheel.pop();
-       _jog_wheel.transport_direction (0);
-       if (_transport_previously_rolling) {
-               session->request_transport_speed (1.0);
-       } else {
-               session->request_stop();
-       }
-       return off;
+       return none;
 }
 
 LedState 
 MackieControlProtocol::ffwd_press (Button &)
 {
-       _jog_wheel.push (JogWheel::speed);
-       _jog_wheel.transport_direction (1);
-       session->request_transport_speed (_jog_wheel.transport_speed());
-       return on;
+       if (_modifier_state == MODIFIER_CONTROL) {
+               goto_end();
+       } else {
+               ffwd ();
+       }
+       return none;
 }
 
 LedState 
 MackieControlProtocol::ffwd_release (Button &)
 {
-       _jog_wheel.pop();
-       _jog_wheel.transport_direction (0);
-       if (_transport_previously_rolling) {
-               session->request_transport_speed (1.0);
-       } else {
-               session->request_stop();
-       }
-       return off;
+       return none;
 }
 
 LedState 
 MackieControlProtocol::loop_press (Button &)
 {
-       session->request_play_loop (!session->get_play_loop());
-       return on;
+       if (_modifier_state & MODIFIER_CONTROL) {
+               set_view_mode (Loop);
+               return on;
+       } else {
+               session->request_play_loop (!session->get_play_loop());
+               return none;
+       }
 }
 
 LedState 
 MackieControlProtocol::loop_release (Button &)
 {
-       return session->get_play_loop();
+       return none;
 }
 
 LedState 
@@ -652,190 +664,191 @@ MackieControlProtocol::enter_release (Button &)
        return off;
 }
 
-/* UNIMPLEMENTED */
-
 LedState
-MackieControlProtocol::io_press (Button &) 
+MackieControlProtocol::F1_press (Button &) 
 { 
        return off; 
 }
 LedState
-MackieControlProtocol::io_release (Button &) 
+MackieControlProtocol::F1_release (Button &) 
 { 
        return off; 
 }
 LedState
-MackieControlProtocol::sends_press (Button &) 
+MackieControlProtocol::F2_press (Button &) 
 { 
        return off; 
 }
 LedState
-MackieControlProtocol::sends_release (Button &) 
+MackieControlProtocol::F2_release (Button &) 
 { 
        return off; 
 }
 LedState
-MackieControlProtocol::pan_press (Button &) 
+MackieControlProtocol::F3_press (Button &) 
 { 
        return off; 
 }
 LedState
-MackieControlProtocol::pan_release (Button &) 
+MackieControlProtocol::F3_release (Button &) 
 { 
        return off; 
 }
 LedState
-MackieControlProtocol::plugin_press (Button &) 
+MackieControlProtocol::F4_press (Button &) 
 { 
        return off; 
 }
 LedState
-MackieControlProtocol::plugin_release (Button &) 
+MackieControlProtocol::F4_release (Button &) 
 { 
        return off; 
 }
 LedState
-MackieControlProtocol::eq_press (Button &) 
+MackieControlProtocol::F5_press (Button &) 
 { 
        return off; 
 }
 LedState
-MackieControlProtocol::eq_release (Button &) 
+MackieControlProtocol::F5_release (Button &) 
 { 
        return off; 
 }
 LedState
-MackieControlProtocol::dyn_press (Button &) 
+MackieControlProtocol::F6_press (Button &) 
 { 
        return off; 
 }
 LedState
-MackieControlProtocol::dyn_release (Button &) 
+MackieControlProtocol::F6_release (Button &) 
 { 
        return off; 
 }
 LedState
-MackieControlProtocol::flip_press (Button &) 
+MackieControlProtocol::F7_press (Button &) 
 { 
        return off; 
 }
 LedState
-MackieControlProtocol::flip_release (Button &) 
+MackieControlProtocol::F7_release (Button &) 
 { 
        return off; 
 }
 LedState
-MackieControlProtocol::edit_press (Button &) 
+MackieControlProtocol::F8_press (Button &) 
 { 
+       CloseDialog (); /* EMIT SIGNAL */
        return off; 
 }
 LedState
-MackieControlProtocol::edit_release (Button &) 
+MackieControlProtocol::F8_release (Button &) 
 { 
        return off; 
 }
+
+/* UNIMPLEMENTED */
+
 LedState
-MackieControlProtocol::name_value_press (Button &) 
+MackieControlProtocol::io_press (Button &) 
 { 
        return off; 
 }
 LedState
-MackieControlProtocol::name_value_release (Button &) 
+MackieControlProtocol::io_release (Button &) 
 { 
        return off; 
 }
 LedState
-MackieControlProtocol::F1_press (Button &) 
+MackieControlProtocol::sends_press (Button &) 
 { 
-       GotoView (0); /* EMIT SIGNAL */
-       return off; 
+       set_view_mode (Sends);
+       return on;
 }
 LedState
-MackieControlProtocol::F1_release (Button &) 
+MackieControlProtocol::sends_release (Button &) 
 { 
-       return off
+       return none
 }
 LedState
-MackieControlProtocol::F2_press (Button &) 
+MackieControlProtocol::pan_press (Button &) 
 { 
-       GotoView (1); /* EMIT SIGNAL */
        return off; 
 }
 LedState
-MackieControlProtocol::F2_release (Button &) 
+MackieControlProtocol::pan_release (Button &) 
 { 
        return off; 
 }
 LedState
-MackieControlProtocol::F3_press (Button &) 
+MackieControlProtocol::plugin_press (Button &) 
 { 
-       GotoView (2); /* EMIT SIGNAL */
        return off; 
 }
 LedState
-MackieControlProtocol::F3_release (Button &) 
+MackieControlProtocol::plugin_release (Button &) 
 { 
        return off; 
 }
 LedState
-MackieControlProtocol::F4_press (Button &) 
+MackieControlProtocol::eq_press (Button &) 
 { 
-       GotoView (3); /* EMIT SIGNAL */
-       return off; 
+       set_view_mode (EQ);
+       return on;
 }
 LedState
-MackieControlProtocol::F4_release (Button &) 
+MackieControlProtocol::eq_release (Button &) 
 { 
-       return off; 
+       return none;
 }
 LedState
-MackieControlProtocol::F5_press (Button &) 
+MackieControlProtocol::dyn_press (Button &) 
 { 
-       GotoView (4); /* EMIT SIGNAL */
-       return off; 
+       set_view_mode (Dynamics);
+       return on;
 }
 LedState
-MackieControlProtocol::F5_release (Button &) 
+MackieControlProtocol::dyn_release (Button &) 
 { 
-       return off; 
+       return none;
 }
 LedState
-MackieControlProtocol::F6_press (Button &) 
+MackieControlProtocol::flip_press (Button &) 
 { 
-       GotoView (5); /* EMIT SIGNAL */
-       return off; 
+       if (_flip_mode != Normal) {
+               set_flip_mode (Normal);
+       } else {
+               set_flip_mode (Mirror);
+       }
+       return ((_flip_mode != Normal) ? on : off);
 }
 LedState
-MackieControlProtocol::F6_release (Button &) 
+MackieControlProtocol::flip_release (Button &) 
 { 
-       return off; 
+       return none;
 }
 LedState
-MackieControlProtocol::F7_press (Button &) 
+MackieControlProtocol::edit_press (Button &) 
 { 
-       GotoView (6); /* EMIT SIGNAL */
        return off; 
 }
 LedState
-MackieControlProtocol::F7_release (Button &) 
+MackieControlProtocol::edit_release (Button &) 
 { 
        return off; 
 }
 LedState
-MackieControlProtocol::F8_press (Button &) 
+MackieControlProtocol::name_value_press (Button &) 
 { 
-       CloseDialog (); /* EMIT SIGNAL */
        return off; 
 }
 LedState
-MackieControlProtocol::F8_release (Button &) 
+MackieControlProtocol::name_value_release (Button &) 
 { 
        return off; 
 }
 LedState
 MackieControlProtocol::F9_press (Button &) 
 { 
-       GotoView (8); /* EMIT SIGNAL */
        return off; 
 }
 LedState
@@ -934,16 +947,6 @@ MackieControlProtocol::rec_ready_release (Button &)
        return off; 
 }
 LedState
-MackieControlProtocol::snapshot_press (Button &) 
-{ 
-       return off; 
-}
-LedState
-MackieControlProtocol::snapshot_release (Button &) 
-{ 
-       return off; 
-}
-LedState
 MackieControlProtocol::touch_press (Button &) 
 { 
        return off; 
@@ -976,6 +979,7 @@ MackieControlProtocol::mixer_release (Button &)
 LedState
 MackieControlProtocol::user_a_press (Button &) 
 { 
+       transport_play (session->transport_speed() == 1.0);
        return off; 
 }
 LedState
@@ -986,6 +990,7 @@ MackieControlProtocol::user_a_release (Button &)
 LedState
 MackieControlProtocol::user_b_press (Button &) 
 { 
+       transport_stop();
        return off; 
 }
 LedState
@@ -993,13 +998,253 @@ MackieControlProtocol::user_b_release (Button &)
 { 
        return off; 
 }
+
 LedState
-MackieControlProtocol::fader_touch_press (Button &) 
-{ 
-       return off; 
+MackieControlProtocol::master_fader_touch_press (Mackie::Button &)
+{
+       DEBUG_TRACE (DEBUG::MackieControl, "MackieControlProtocol::master_fader_touch_press\n");
+
+       Fader* master_fader = surfaces.front()->master_fader();
+
+       boost::shared_ptr<AutomationControl> ac = master_fader->control ();
+
+       master_fader->set_in_use (true);
+       master_fader->start_touch (transport_frame());
+
+       return none;
 }
 LedState
-MackieControlProtocol::fader_touch_release (Button &) 
-{ 
-       return off; 
+MackieControlProtocol::master_fader_touch_release (Mackie::Button &)
+{
+       DEBUG_TRACE (DEBUG::MackieControl, "MackieControlProtocol::master_fader_touch_release\n");
+
+       Fader* master_fader = surfaces.front()->master_fader();
+
+       master_fader->set_in_use (false);
+       master_fader->stop_touch (transport_frame(), true);
+
+       return none;
+}
+
+Mackie::LedState 
+MackieControlProtocol::snapshot_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::snapshot_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::read_press (Mackie::Button&) 
+{
+       _metering_active = !_metering_active;
+       notify_metering_state_changed ();
+       return _metering_active;
+}
+Mackie::LedState 
+MackieControlProtocol::read_release (Mackie::Button&) 
+{
+       return _metering_active;
+}
+Mackie::LedState 
+MackieControlProtocol::write_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::write_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::fdrgroup_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::fdrgroup_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::clearsolo_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::clearsolo_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::track_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::track_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::send_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::send_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::miditracks_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::miditracks_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::inputs_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::inputs_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::audiotracks_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::audiotracks_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::audioinstruments_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::audioinstruments_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::aux_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::aux_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::busses_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::busses_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::outputs_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::outputs_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::user_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::user_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::trim_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::trim_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::latch_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::latch_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::grp_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::grp_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::nudge_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::nudge_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::replace_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::replace_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::click_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::click_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::view_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::view_release (Mackie::Button&) 
+{
+       return none;
 }