substantial overhaul of MCU code - no more separate thread, just connect to signals...
[ardour.git] / libs / surfaces / mackie / route_signal.cc
index adaeadd805661974fb6b66f4ceb508eb6fd30a3e..9a3dd41bf4ce29fa2bec337c1d1d0b8dad955290 100644 (file)
 */
 #include "route_signal.h"
 
-#include <ardour/route.h>
-#include <ardour/track.h>
-#include <ardour/panner.h>
-#include <ardour/types.h>
+#include "ardour/route.h"
+#include "ardour/track.h"
+#include "ardour/panner.h"
 
 #include "mackie_control_protocol.h"
 
 #include <stdexcept>
 
+using namespace ARDOUR;
 using namespace Mackie;
+using namespace std;
 
 void RouteSignal::connect()
 {
-       if ( _strip.has_solo() )
-               _solo_changed_connection = _route.solo_control()->Changed.connect( sigc::bind ( mem_fun ( _mcp, &MackieControlProtocol::notify_solo_changed ), this ) );
-       
-       if ( _strip.has_mute() )
-               _mute_changed_connection = _route.mute_control()->Changed.connect( sigc::bind ( mem_fun ( _mcp, &MackieControlProtocol::notify_mute_changed ), this ) );
+       if (_strip.has_solo()) {
+               _route->solo_control()->Changed.connect(connections, boost::bind (&MackieControlProtocol::notify_solo_changed, &_mcp, this));
+       }
+
+       if (_strip.has_mute()) {
+               _route->mute_control()->Changed.connect(connections, boost::bind (&MackieControlProtocol::notify_mute_changed, &_mcp, this));
+       }
+
+       if (_strip.has_gain()) {
+               _route->gain_control()->Changed.connect(connections, boost::bind (&MackieControlProtocol::notify_gain_changed, &_mcp, this, false));
+       }
+
+       _route->NameChanged.connect (connections, boost::bind (&MackieControlProtocol::notify_name_changed, &_mcp, this));
        
-       if ( _strip.has_gain() )
-               _gain_changed_connection = _route.gain_control()->Changed.connect( sigc::bind ( mem_fun ( _mcp, &MackieControlProtocol::notify_gain_changed ), this ) );
+       if (_route->panner()) {
+               _route->panner()->Changed.connect(connections, boost::bind (&MackieControlProtocol::notify_panner_changed, &_mcp, this, false));
                
-       _name_changed_connection = _route.NameChanged.connect( sigc::bind ( mem_fun ( _mcp, &MackieControlProtocol::notify_name_changed ), this ) );
-       
-       if ( _route.panner().size() == 1 )
-       {
-               _panner_changed_connection = _route.panner()[0]->Changed.connect( sigc::bind ( mem_fun ( _mcp, &MackieControlProtocol::notify_panner_changed ), this ) );
+               for ( unsigned int i = 0; i < _route->panner()->npanners(); ++i ) {
+                       _route->panner()->streampanner(i).Changed.connect (connections, boost::bind (&MackieControlProtocol::notify_panner_changed, &_mcp, this, false));
+               }
        }
        
-       try
-       {
-               _record_enable_changed_connection =
-                       dynamic_cast<ARDOUR::Track&>( _route ).rec_enable_control()->Changed
-                               .connect( sigc::bind ( mem_fun ( _mcp, &MackieControlProtocol::notify_record_enable_changed ), this ) )
-               ;
-       }
-       catch ( std::bad_cast & )
-       {
-               // this should catch the dynamic_cast to Track, if what we're working
-               // with can't be record-enabled
+       boost::shared_ptr<Track> trk = boost::dynamic_pointer_cast<ARDOUR::Track>(_route);
+       if (trk) {
+               trk->rec_enable_control()->Changed .connect(connections, boost::bind (&MackieControlProtocol::notify_record_enable_changed, &_mcp, this));
        }
-
+       
+       // TODO this works when a currently-banked route is made inactive, but not
+       // when a route is activated which should be currently banked.
+       _route->active_changed.connect (connections, boost::bind (&MackieControlProtocol::notify_active_changed, &_mcp, this));
+       
        // TODO
-       // active_changed
        // SelectedChanged
        // RemoteControlIDChanged. Better handled at Session level.
 }
 
 void RouteSignal::disconnect()
 {
-       _solo_changed_connection.disconnect();
-       _mute_changed_connection.disconnect();
-       _gain_changed_connection.disconnect();
-       _name_changed_connection.disconnect();
-       _panner_changed_connection.disconnect();
-       _record_enable_changed_connection.disconnect();
+       connections.drop_connections ();
 }
 
 void RouteSignal::notify_all()
 {
+#ifdef DEBUG
+       cout << "RouteSignal::notify_all for " << _strip << endl;
+#endif
        if ( _strip.has_solo() )
                _mcp.notify_solo_changed( this );
        
@@ -93,4 +93,7 @@ void RouteSignal::notify_all()
        
        if ( _strip.has_recenable() )
                _mcp.notify_record_enable_changed( this );
+#ifdef DEBUG
+       cout << "RouteSignal::notify_all finish" << endl;
+#endif
 }