merge with master, primarily for adrian's maximise-mixer change
[ardour.git] / libs / surfaces / mackie / mcp_buttons.cc
index 5699c9ff030fe15cfe06b9cf1309db7f4dceb1a4..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"
@@ -26,6 +29,7 @@
 
 #include "mackie_control_protocol.h"
 #include "surface.h"
+#include "fader.h"
 
 #include "i18n.h"
 
@@ -35,6 +39,7 @@
 
 using namespace Mackie;
 using namespace ARDOUR;
+using namespace PBD;
 using std::string;
 
 LedState
@@ -65,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
@@ -90,22 +97,18 @@ LedState
 MackieControlProtocol::left_press (Button &)
 {
        Sorted sorted = get_sorted_routes();
-       uint32_t strip_cnt = n_strips ();
+       uint32_t strip_cnt = n_strips (); 
 
-       if (sorted.size() > strip_cnt) {
-               int new_initial = _current_initial_bank - strip_cnt;
-               if (new_initial < 0) {
-                       new_initial = 0;
-               }
-               
-               if (new_initial != int (_current_initial_bank)) {
-                       switch_banks (new_initial);
-               }
+       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()));
 
-               return on;
+       if (_current_initial_bank > strip_cnt) {
+               switch_banks (_current_initial_bank - strip_cnt);
        } else {
-               return flashing;
+               switch_banks (0);
        }
+
+       return on;
 }
 
 LedState 
@@ -119,23 +122,15 @@ MackieControlProtocol::right_press (Button &)
 {
        Sorted sorted = get_sorted_routes();
        uint32_t strip_cnt = n_strips();
+       uint32_t route_cnt = sorted.size();
 
-       if (sorted.size() > strip_cnt) {
-               uint32_t delta = sorted.size() - (strip_cnt + _current_initial_bank);
+       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));
 
-               if (delta > strip_cnt) {
-                       delta = strip_cnt;
-               }
-               
-               if (delta > 0) {
-                       switch_banks (_current_initial_bank + delta);
-               }
+       uint32_t new_initial = std::min (_current_initial_bank + strip_cnt, route_cnt - 1);
+       switch_banks (new_initial);
 
-               return on;
-       } else {
-               return flashing;
-       }
-       return off;
+       return on;
 }
 
 LedState 
@@ -158,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;
@@ -179,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;
 }
 
@@ -194,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;
 }
@@ -213,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;
 }
@@ -281,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
@@ -378,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;
 }
 
@@ -408,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;
@@ -439,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;
@@ -470,66 +492,83 @@ MackieControlProtocol::stop_release (Button &)
 LedState 
 MackieControlProtocol::play_press (Button &)
 {
-       transport_play ();
-       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 &)
 {
        rec_enable_toggle ();
-       return off;
+       return none;
 }
 
 LedState 
 MackieControlProtocol::record_release (Button &)
 {
-       return off;
+       return none;
 }
 
 LedState 
 MackieControlProtocol::rewind_press (Button &)
 {
-       rewind ();
-       return off;
+       if (_modifier_state == MODIFIER_CONTROL) {
+               goto_start ();
+       } else {
+               rewind ();
+       }
+       return none;
 }
 
 LedState 
 MackieControlProtocol::rewind_release (Button &)
 {
-       return off;
+       return none;
 }
 
 LedState 
 MackieControlProtocol::ffwd_press (Button &)
 {
-       ffwd ();
-       return off;
+       if (_modifier_state == MODIFIER_CONTROL) {
+               goto_end();
+       } else {
+               ffwd ();
+       }
+       return none;
 }
 
 LedState 
 MackieControlProtocol::ffwd_release (Button &)
 {
-       return off;
+       return none;
 }
 
 LedState 
 MackieControlProtocol::loop_press (Button &)
 {
-       session->request_play_loop (!session->get_play_loop());
-       return off;
+       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 off;
+       return none;
 }
 
 LedState 
@@ -628,7 +667,6 @@ MackieControlProtocol::enter_release (Button &)
 LedState
 MackieControlProtocol::F1_press (Button &) 
 { 
-       GotoView (0); /* EMIT SIGNAL */
        return off; 
 }
 LedState
@@ -639,7 +677,6 @@ MackieControlProtocol::F1_release (Button &)
 LedState
 MackieControlProtocol::F2_press (Button &) 
 { 
-       GotoView (1); /* EMIT SIGNAL */
        return off; 
 }
 LedState
@@ -650,7 +687,6 @@ MackieControlProtocol::F2_release (Button &)
 LedState
 MackieControlProtocol::F3_press (Button &) 
 { 
-       GotoView (2); /* EMIT SIGNAL */
        return off; 
 }
 LedState
@@ -661,7 +697,6 @@ MackieControlProtocol::F3_release (Button &)
 LedState
 MackieControlProtocol::F4_press (Button &) 
 { 
-       GotoView (3); /* EMIT SIGNAL */
        return off; 
 }
 LedState
@@ -672,7 +707,6 @@ MackieControlProtocol::F4_release (Button &)
 LedState
 MackieControlProtocol::F5_press (Button &) 
 { 
-       GotoView (4); /* EMIT SIGNAL */
        return off; 
 }
 LedState
@@ -683,7 +717,6 @@ MackieControlProtocol::F5_release (Button &)
 LedState
 MackieControlProtocol::F6_press (Button &) 
 { 
-       GotoView (5); /* EMIT SIGNAL */
        return off; 
 }
 LedState
@@ -694,7 +727,6 @@ MackieControlProtocol::F6_release (Button &)
 LedState
 MackieControlProtocol::F7_press (Button &) 
 { 
-       GotoView (6); /* EMIT SIGNAL */
        return off; 
 }
 LedState
@@ -729,12 +761,13 @@ MackieControlProtocol::io_release (Button &)
 LedState
 MackieControlProtocol::sends_press (Button &) 
 { 
-       return off; 
+       set_view_mode (Sends);
+       return on;
 }
 LedState
 MackieControlProtocol::sends_release (Button &) 
 { 
-       return off
+       return none
 }
 LedState
 MackieControlProtocol::pan_press (Button &) 
@@ -759,33 +792,39 @@ MackieControlProtocol::plugin_release (Button &)
 LedState
 MackieControlProtocol::eq_press (Button &) 
 { 
-       return off; 
+       set_view_mode (EQ);
+       return on;
 }
 LedState
 MackieControlProtocol::eq_release (Button &) 
 { 
-       return off; 
+       return none;
 }
 LedState
 MackieControlProtocol::dyn_press (Button &) 
 { 
-       return off; 
+       set_view_mode (Dynamics);
+       return on;
 }
 LedState
 MackieControlProtocol::dyn_release (Button &) 
 { 
-       return off; 
+       return none;
 }
 LedState
 MackieControlProtocol::flip_press (Button &) 
 { 
-       _flip_mode = !_flip_mode;
-       return (_flip_mode ? on : off);
+       if (_flip_mode != Normal) {
+               set_flip_mode (Normal);
+       } else {
+               set_flip_mode (Mirror);
+       }
+       return ((_flip_mode != Normal) ? on : off);
 }
 LedState
 MackieControlProtocol::flip_release (Button &) 
 { 
-       return (_flip_mode ? on : off);
+       return none;
 }
 LedState
 MackieControlProtocol::edit_press (Button &) 
@@ -940,6 +979,7 @@ MackieControlProtocol::mixer_release (Button &)
 LedState
 MackieControlProtocol::user_a_press (Button &) 
 { 
+       transport_play (session->transport_speed() == 1.0);
        return off; 
 }
 LedState
@@ -950,6 +990,7 @@ MackieControlProtocol::user_a_release (Button &)
 LedState
 MackieControlProtocol::user_b_press (Button &) 
 { 
+       transport_stop();
        return off; 
 }
 LedState
@@ -957,3 +998,253 @@ MackieControlProtocol::user_b_release (Button &)
 { 
        return off; 
 }
+
+LedState
+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::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;
+}