/* * Carla Bridge OSC * Copyright (C) 2011-2014 Filipe Coelho * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License as * published by the Free Software Foundation; either version 2 of * the License, or any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * For a full copy of the GNU General Public License see the doc/GPL.txt file. */ #ifndef CARLA_BRIDGE_OSC_HPP_INCLUDED #define CARLA_BRIDGE_OSC_HPP_INCLUDED #include "CarlaBridge.hpp" #include "CarlaOscUtils.hpp" #include "CarlaString.hpp" #define CARLA_BRIDGE_OSC_HANDLE_ARGS const int argc, const lo_arg* const* const argv, const char* const types #define CARLA_BRIDGE_OSC_CHECK_OSC_TYPES(/* argc, types, */ argcToCompare, typesToCompare) \ /* check argument count */ \ if (argc != argcToCompare) \ { \ carla_stderr("CarlaBridgeOsc::%s() - argument count mismatch: %i != %i", __FUNCTION__, argc, argcToCompare); \ return 1; \ } \ if (argc > 0) \ { \ /* check for nullness */ \ if (types == nullptr || typesToCompare == nullptr) \ { \ carla_stderr("CarlaBridgeOsc::%s() - argument types are null", __FUNCTION__); \ return 1; \ } \ /* check argument types */ \ if (std::strcmp(types, typesToCompare) != 0) \ { \ carla_stderr("CarlaBridgeOsc::%s() - argument types mismatch: '%s' != '%s'", __FUNCTION__, types, typesToCompare); \ return 1; \ } \ } CARLA_BRIDGE_START_NAMESPACE // ----------------------------------------------------------------------- class CarlaBridgeOsc { public: CarlaBridgeOsc(CarlaBridgeClient* const client); ~CarlaBridgeOsc(); void init(const char* const url); void idle() const; void close(); // ------------------------------------------------------------------- bool isControlRegistered() const noexcept { return (fControlData.target != nullptr); } const CarlaOscData& getControlData() const noexcept { return fControlData; } const char* getServerPath() const noexcept { return fServerPath; } // ------------------------------------------------------------------- private: CarlaBridgeClient* const kClient; CarlaOscData fControlData; CarlaString fName; CarlaString fServerPath; lo_server fServer; // ------------------------------------------------------------------- int handleMessage(const char* const path, const int argc, const lo_arg* const* const argv, const char* const types, const lo_message msg); int handleMsgConfigure(CARLA_BRIDGE_OSC_HANDLE_ARGS); int handleMsgControl(CARLA_BRIDGE_OSC_HANDLE_ARGS); int handleMsgProgram(CARLA_BRIDGE_OSC_HANDLE_ARGS); int handleMsgMidiProgram(CARLA_BRIDGE_OSC_HANDLE_ARGS); int handleMsgMidi(CARLA_BRIDGE_OSC_HANDLE_ARGS); int handleMsgShow(); int handleMsgHide(); int handleMsgQuit(); #ifdef BRIDGE_LV2 int handleMsgLv2AtomTransfer(CARLA_BRIDGE_OSC_HANDLE_ARGS); int handleMsgLv2UridMap(CARLA_BRIDGE_OSC_HANDLE_ARGS); #endif // ------------------------------------------------------------------- static int osc_message_handler(const char* path, const char* types, lo_arg** argv, int argc, lo_message msg, void* userData) { return ((CarlaBridgeOsc*)userData)->handleMessage(path, argc, argv, types, msg); } static void osc_error_handler(int num, const char* msg, const char* path) { carla_stderr("CarlaBridgeOsc::osc_error_handler(%i, \"%s\", \"%s\")", num, msg, path); } CARLA_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR(CarlaBridgeOsc) }; // ----------------------------------------------------------------------- CARLA_BRIDGE_END_NAMESPACE #endif // CARLA_BRIDGE_OSC_HPP_INCLUDED