Merge branch 'master' into cairocanvas
[ardour.git] / libs / surfaces / mackie / mackie_control_protocol.h
index 8bcec0933a122e1583d040586cd08a3e4554e4b4..4ff5d53f2567ab7b2ddef8cd792b64d2c28f7b7f 100644 (file)
@@ -28,8 +28,7 @@
 #include <pthread.h>
 #include <boost/smart_ptr.hpp>
 
-#include <glibmm/thread.h>
-
+#define ABSTRACT_UI_EXPORTS
 #include "pbd/abstract_ui.h"
 #include "midi++/types.h"
 #include "ardour/types.h"
@@ -122,21 +121,23 @@ class MackieControlProtocol
        Mackie::DeviceProfile& device_profile() { return _device_profile; }
 
        int set_active (bool yn);
-       void set_device (const std::string&, bool allow_activation = true);
-       void set_profile (const std::string&);
+       int  set_device (const std::string&);
+        void set_profile (const std::string&);
 
-       bool     flip_mode () const { return _flip_mode; }
+       FlipMode flip_mode () const { return _flip_mode; }
        ViewMode view_mode () const { return _view_mode; }
        bool zoom_mode () const { return _zoom_mode; }
+       bool     metering_active () const { return _metering_active; }
 
        void set_view_mode (ViewMode);
-       void set_flip_mode (bool);
+       void set_flip_mode (FlipMode);
 
        XMLNode& get_state ();
        int set_state (const XMLNode&, int version);
   
        static bool probe();
        
+        Glib::Threads::Mutex surfaces_lock;
        typedef std::list<boost::shared_ptr<Mackie::Surface> > Surfaces;
        Surfaces surfaces;
 
@@ -164,6 +165,7 @@ class MackieControlProtocol
        void notify_record_state_changed();
        void notify_transport_state_changed();
        void notify_loop_state_changed();
+       void notify_metering_state_changed();
        // mainly to pick up punch-in and punch-out
        void notify_parameter_changed(std::string const &);
        void notify_solo_active_changed(bool);
@@ -171,7 +173,7 @@ class MackieControlProtocol
        /// Turn timecode on and beats off, or vice versa, depending
        /// on state of _timecode_type
        void update_timecode_beats_led();
-  
+       
        /// this is called to generate the midi to send in response to a button press.
        void update_led(Mackie::Surface&, Mackie::Button & button, Mackie::LedState);
   
@@ -195,6 +197,8 @@ class MackieControlProtocol
 
        int16_t ipmidi_base() const { return _ipmidi_base; }
        void    set_ipmidi_base (int16_t);
+
+       void midi_connectivity_established ();
        
   protected:
        // shut down the surface
@@ -233,7 +237,6 @@ class MackieControlProtocol
        int stop ();
 
        void thread_init ();
-       void midi_connectivity_established ();
 
        bool route_is_locked_to_strip (boost::shared_ptr<ARDOUR::Route>) const;
 
@@ -260,10 +263,8 @@ class MackieControlProtocol
        uint32_t                 _current_initial_bank;
        PBD::ScopedConnectionList audio_engine_connections;
        PBD::ScopedConnectionList session_connections;
-       PBD::ScopedConnectionList port_connections;
        PBD::ScopedConnectionList route_connections;
        PBD::ScopedConnectionList gui_connections;
-       bool _transport_previously_rolling;
        // timer for two quick marker left presses
        Mackie::Timer            _frm_left_last;
        // last written timecode string
@@ -277,7 +278,7 @@ class MackieControlProtocol
        void*                    _gui;
        bool                     _zoom_mode;
        bool                     _scrub_mode;
-       bool                     _flip_mode;
+       FlipMode                 _flip_mode;
        ViewMode                 _view_mode;
        int                      _current_selected_track;
        int                      _modifier_state;
@@ -285,17 +286,26 @@ class MackieControlProtocol
        ButtonMap                 button_map;
        int16_t                  _ipmidi_base;
        bool                      needs_ipmidi_restart;
-       
-       void create_surfaces ();
+       bool                     _metering_active;
+       bool                     _initialized;
+       ARDOUR::RouteNotificationList _last_selected_routes;
+        XMLNode*                 _surfaces_state;
+        int                      _surfaces_version;
+
+       int create_surfaces ();
        bool periodic();
        void build_gui ();
        bool midi_input_handler (Glib::IOCondition ioc, MIDI::Port* port);
        void clear_ports ();
+       void clear_surfaces ();
        void force_special_route_to_strip (boost::shared_ptr<ARDOUR::Route> r, uint32_t surface, uint32_t strip_number);
        void build_button_map ();
-       void gui_track_selection_changed (ARDOUR::RouteNotificationListPtr);
-       void ipmidi_restart ();
-       
+       void gui_track_selection_changed (ARDOUR::RouteNotificationListPtr, bool save_list);
+       void _gui_track_selection_changed (ARDOUR::RouteNotificationList*, bool save_list);
+       int ipmidi_restart ();
+        void initialize ();
+        int set_device_info (const std::string& device_name);
+
        /* BUTTON HANDLING */
 
        typedef std::set<uint32_t> DownButtonList;
@@ -441,6 +451,8 @@ class MackieControlProtocol
        Mackie::LedState user_b_release (Mackie::Button &);
        Mackie::LedState fader_touch_press (Mackie::Button &);
        Mackie::LedState fader_touch_release (Mackie::Button &);
+       Mackie::LedState master_fader_touch_press (Mackie::Button &);
+       Mackie::LedState master_fader_touch_release (Mackie::Button &);
 
        Mackie::LedState snapshot_press (Mackie::Button&);
        Mackie::LedState snapshot_release (Mackie::Button&);
@@ -490,6 +502,4 @@ class MackieControlProtocol
        Mackie::LedState view_release (Mackie::Button&);
 };
 
-
-
 #endif // ardour_mackie_control_protocol_h