Merge remote-tracking branch 'remotes/origin/cairocanvas' into windows
[ardour.git] / libs / surfaces / mackie / interface.cc
index 067941484c703779859a91ca96355caaf7a55ff0..abef84817d4cbf58e48023cd6f5bacc8044b4fd5 100644 (file)
        along with this program; if not, write to the Free Software
        Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 */
-#include "control_protocol/control_protocol.h"
-#include "mackie_control_protocol.h"
 
-#include "ardour/rc_configuration.h"
+#include <stdexcept>
 
 #include "pbd/error.h"
 
-#include <stdexcept>
+#include "ardour/rc_configuration.h"
+
+#include "control_protocol/control_protocol.h"
+#include "mackie_control_protocol.h"
 
 using namespace ARDOUR;
 using namespace PBD;
 using namespace std;
 
-ControlProtocol*
+static ControlProtocol*
 new_mackie_protocol (ControlProtocolDescriptor*, Session* s)
 {
-       if ( Config->get_mmc_port_name().substr(0,3) == "mcu" )
-       {
-               error << "mcu already used as mmc port" << endmsg;
-       }
-       else if ( Config->get_mtc_port_name().substr(0,3) == "mcu" )
-       {
-               error << "mcu already used as mtc port" << endmsg;
-       }
-       else if ( Config->get_midi_port_name().substr(0,3) == "mcu" )
-       {
-               error << "mcu already used as midi port" << endmsg;
+       MackieControlProtocol* mcp = 0;
+       
+       try {
+               mcp = new MackieControlProtocol (*s);
+               /* do not set active here - wait for set_state() */
        }
-       else
-       {
-               // no one else is using the port, so try instantiate the object
-               MackieControlProtocol * mcp = 0;
-               try
-               {
-                       mcp = new MackieControlProtocol (*s);
-                       mcp->set_active( true );
-               }
-               catch( exception & e )
-               {
-                       error << "Error instantiating MackieControlProtocol: " << e.what() << endmsg;
-                       delete mcp;
-                       mcp = 0;
-               }
-               return mcp;
+       catch (exception & e) {
+               error << "Error instantiating MackieControlProtocol: " << e.what() << endmsg;
+               delete mcp;
+               mcp = 0;
        }
-       return 0;
+       
+       return mcp;
 }
 
-void
+static void
 delete_mackie_protocol (ControlProtocolDescriptor*, ControlProtocol* cp)
 {
        try
@@ -82,34 +66,28 @@ delete_mackie_protocol (ControlProtocolDescriptor*, ControlProtocol* cp)
        So anything that can be changed in the UI should not be used here to
        prevent loading of the lib.
 */
-bool
+static bool
 probe_mackie_protocol (ControlProtocolDescriptor*)
 {
        return MackieControlProtocol::probe();
 }
 
+// Field names commented out by JE - 06-01-2010
 static ControlProtocolDescriptor mackie_descriptor = {
-       name : "Mackie",
-       id : "uri://ardour.org/surfaces/mackie:0",
-       ptr : 0,
-       module : 0,
-       mandatory : 0,
+       /*name :              */   "Mackie",
+       /*id :                */   "uri://ardour.org/surfaces/mackie:0",
+       /*ptr :               */   0,
+       /*module :            */   0,
+       /*mandatory :         */   0,
        // actually, the surface does support feedback, but all this
        // flag does is show a submenu on the UI, which is useless for the mackie
        // because feedback is always on. In any case, who'd want to use the
        // mcu without the motorised sliders doing their thing?
-       supports_feedback : false,
-       probe : probe_mackie_protocol,
-       initialize : new_mackie_protocol,
-       destroy : delete_mackie_protocol
+       /*supports_feedback : */   false,
+       /*probe :             */   probe_mackie_protocol,
+       /*initialize :        */   new_mackie_protocol,
+       /*destroy :           */   delete_mackie_protocol
 };
        
 
-extern "C" {
-
-ControlProtocolDescriptor* 
-protocol_descriptor () {
-       return &mackie_descriptor;
-}
-
-}
+extern "C" ARDOURSURFACE_API ControlProtocolDescriptor* protocol_descriptor () { return &mackie_descriptor; }