|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344 |
- /*
- * Carla OSC utils
- * Copyright (C) 2012-2019 Filipe Coelho <falktx@falktx.com>
- *
- * 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_OSC_UTILS_HPP_INCLUDED
- #define CARLA_OSC_UTILS_HPP_INCLUDED
-
- #include "CarlaUtils.hpp"
-
- #include <lo/lo.h>
-
- #define try_lo_send(...) \
- try { \
- lo_send(__VA_ARGS__); \
- } CARLA_SAFE_EXCEPTION("lo_send");
-
- // -----------------------------------------------------------------------
-
- struct CarlaOscData {
- const char* path;
- lo_address source;
- lo_address target;
-
- CarlaOscData() noexcept
- : path(nullptr),
- source(nullptr),
- target(nullptr) {}
-
- ~CarlaOscData() noexcept
- {
- clear();
- }
-
- void clear() noexcept
- {
- if (path != nullptr)
- {
- delete[] path;
- path = nullptr;
- }
-
- if (source != nullptr)
- {
- try {
- lo_address_free(source);
- } CARLA_SAFE_EXCEPTION("lo_address_free source");
- source = nullptr;
- }
-
- if (target != nullptr)
- {
- try {
- lo_address_free(target);
- } CARLA_SAFE_EXCEPTION("lo_address_free target");
- target = nullptr;
- }
- }
-
- #if 0
- void setNewURL(const char* const url)
- {
- if (path != nullptr)
- {
- delete[] path;
- path = nullptr;
- }
-
- if (target != nullptr)
- {
- try {
- lo_address_free(target);
- } CARLA_SAFE_EXCEPTION("lo_address_free target");
- target = nullptr;
- }
-
- char* const host = lo_url_get_hostname(url);
- char* const port = lo_url_get_port(url);
- path = carla_strdup_free(lo_url_get_path(url));
- target = lo_address_new_with_proto(LO_UDP, host, port);
-
- std::free(host);
- std::free(port);
- }
- #endif
-
- CARLA_PREVENT_HEAP_ALLOCATION
- CARLA_DECLARE_NON_COPY_STRUCT(CarlaOscData)
- };
-
- // -----------------------------------------------------------------------
-
- static inline
- void osc_send_configure(const CarlaOscData& oscData, const char* const key, const char* const value) noexcept
- {
- CARLA_SAFE_ASSERT_RETURN(oscData.path != nullptr && oscData.path[0] != '\0',);
- CARLA_SAFE_ASSERT_RETURN(oscData.target != nullptr,);
- CARLA_SAFE_ASSERT_RETURN(key != nullptr && key[0] != '\0',);
- CARLA_SAFE_ASSERT_RETURN(value != nullptr,);
- carla_debug("osc_send_configure(path:\"%s\", \"%s\", \"%s\")", oscData.path, key, value);
-
- char targetPath[std::strlen(oscData.path)+11];
- std::strcpy(targetPath, oscData.path);
- std::strcat(targetPath, "/configure");
- try_lo_send(oscData.target, targetPath, "ss", key, value);
- }
-
- static inline
- void osc_send_control(const CarlaOscData& oscData, const int32_t index, const float value) noexcept
- {
- CARLA_SAFE_ASSERT_RETURN(oscData.path != nullptr && oscData.path[0] != '\0',);
- CARLA_SAFE_ASSERT_RETURN(oscData.target != nullptr,);
- CARLA_SAFE_ASSERT_RETURN(index != -1,); // -1 == PARAMETER_NULL
- carla_debug("osc_send_control(path:\"%s\", %i, %f)", oscData.path, index, value);
-
- char targetPath[std::strlen(oscData.path)+9];
- std::strcpy(targetPath, oscData.path);
- std::strcat(targetPath, "/control");
- try_lo_send(oscData.target, targetPath, "if", index, static_cast<double>(value));
- }
-
- static inline
- void osc_send_program(const CarlaOscData& oscData, const uint32_t index) noexcept
- {
- CARLA_SAFE_ASSERT_RETURN(oscData.path != nullptr && oscData.path[0] != '\0',);
- CARLA_SAFE_ASSERT_RETURN(oscData.target != nullptr,);
- carla_debug("osc_send_program(path:\"%s\", %u)", oscData.path, index);
-
- char targetPath[std::strlen(oscData.path)+9];
- std::strcpy(targetPath, oscData.path);
- std::strcat(targetPath, "/program");
- try_lo_send(oscData.target, targetPath, "i", static_cast<int32_t>(index));
- }
-
- static inline
- void osc_send_program(const CarlaOscData& oscData, const uint32_t bank, const uint32_t program) noexcept
- {
- CARLA_SAFE_ASSERT_RETURN(oscData.path != nullptr && oscData.path[0] != '\0',);
- CARLA_SAFE_ASSERT_RETURN(oscData.target != nullptr,);
- carla_debug("osc_send_program(path:\"%s\", %u, %u)", oscData.path, bank, program);
-
- char targetPath[std::strlen(oscData.path)+9];
- std::strcpy(targetPath, oscData.path);
- std::strcat(targetPath, "/program");
- try_lo_send(oscData.target, targetPath, "ii", static_cast<int32_t>(bank), static_cast<int32_t>(program));
- }
-
- static inline
- void osc_send_midi_program(const CarlaOscData& oscData, const uint32_t index) noexcept
- {
- CARLA_SAFE_ASSERT_RETURN(oscData.path != nullptr && oscData.path[0] != '\0',);
- CARLA_SAFE_ASSERT_RETURN(oscData.target != nullptr,);
- carla_debug("osc_send_midi_program(path:\"%s\", %u)", oscData.path, index);
-
- char targetPath[std::strlen(oscData.path)+14];
- std::strcpy(targetPath, oscData.path);
- std::strcat(targetPath, "/midi-program");
- try_lo_send(oscData.target, targetPath, "i", static_cast<int32_t>(index));
- }
-
- static inline
- void osc_send_midi_program(const CarlaOscData& oscData, const uint32_t bank, const uint32_t program) noexcept
- {
- CARLA_SAFE_ASSERT_RETURN(oscData.path != nullptr && oscData.path[0] != '\0',);
- CARLA_SAFE_ASSERT_RETURN(oscData.target != nullptr,);
- carla_debug("osc_send_midi_program(path:\"%s\", %u, %u)", oscData.path, bank, program);
-
- char targetPath[std::strlen(oscData.path)+14];
- std::strcpy(targetPath, oscData.path);
- std::strcat(targetPath, "/midi-program");
- try_lo_send(oscData.target, targetPath, "ii", static_cast<int32_t>(bank), static_cast<int32_t>(program));
- }
-
- static inline
- void osc_send_midi(const CarlaOscData& oscData, const uint8_t buf[4]) noexcept
- {
- CARLA_SAFE_ASSERT_RETURN(oscData.path != nullptr && oscData.path[0] != '\0',);
- CARLA_SAFE_ASSERT_RETURN(oscData.target != nullptr,);
- CARLA_SAFE_ASSERT_RETURN(buf[0] == 0,);
- CARLA_SAFE_ASSERT_RETURN(buf[1] != 0,);
- carla_debug("osc_send_midi(path:\"%s\", port:%u, {0x%X, %03u, %03u})", oscData.path, buf[0], buf[1], buf[2], buf[3]);
-
- char targetPath[std::strlen(oscData.path)+6];
- std::strcpy(targetPath, oscData.path);
- std::strcat(targetPath, "/midi");
- try_lo_send(oscData.target, targetPath, "m", buf);
- }
-
- static inline
- void osc_send_sample_rate(const CarlaOscData& oscData, const float sampleRate) noexcept
- {
- CARLA_SAFE_ASSERT_RETURN(oscData.path != nullptr && oscData.path[0] != '\0',);
- CARLA_SAFE_ASSERT_RETURN(oscData.target != nullptr,);
- CARLA_SAFE_ASSERT_RETURN(sampleRate > 0.0f,);
- carla_debug("osc_send_sample_rate(path:\"%s\", %f)", oscData.path, sampleRate);
-
- char targetPath[std::strlen(oscData.path)+13];
- std::strcpy(targetPath, oscData.path);
- std::strcat(targetPath, "/sample-rate");
- try_lo_send(oscData.target, targetPath, "f", static_cast<double>(sampleRate));
- }
-
- static inline
- void osc_send_update(const CarlaOscData& oscData, const char* const url) noexcept
- {
- CARLA_SAFE_ASSERT_RETURN(oscData.path != nullptr && oscData.path[0] != '\0',);
- CARLA_SAFE_ASSERT_RETURN(oscData.target != nullptr,);
- CARLA_SAFE_ASSERT_RETURN(url != nullptr && url[0] != '\0',);
- carla_debug("osc_send_update(path:\"%s\", \"%s\")", oscData.path, url);
-
- char targetPath[std::strlen(oscData.path)+8];
- std::strcpy(targetPath, oscData.path);
- std::strcat(targetPath, "/update");
- try_lo_send(oscData.target, targetPath, "s", url);
- }
-
- static inline
- void osc_send_show(const CarlaOscData& oscData) noexcept
- {
- CARLA_SAFE_ASSERT_RETURN(oscData.path != nullptr && oscData.path[0] != '\0',);
- CARLA_SAFE_ASSERT_RETURN(oscData.target != nullptr,);
- carla_debug("osc_send_show(path:\"%s\")", oscData.path);
-
- char targetPath[std::strlen(oscData.path)+6];
- std::strcpy(targetPath, oscData.path);
- std::strcat(targetPath, "/show");
- try_lo_send(oscData.target, targetPath, "");
- }
-
- static inline
- void osc_send_hide(const CarlaOscData& oscData) noexcept
- {
- CARLA_SAFE_ASSERT_RETURN(oscData.path != nullptr && oscData.path[0] != '\0',);
- CARLA_SAFE_ASSERT_RETURN(oscData.target != nullptr,);
- carla_debug("osc_send_hide(path:\"%s\")", oscData.path);
-
- char targetPath[std::strlen(oscData.path)+6];
- std::strcpy(targetPath, oscData.path);
- std::strcat(targetPath, "/hide");
- try_lo_send(oscData.target, targetPath, "");
- }
-
- static inline
- void osc_send_quit(const CarlaOscData& oscData) noexcept
- {
- CARLA_SAFE_ASSERT_RETURN(oscData.path != nullptr && oscData.path[0] != '\0',);
- CARLA_SAFE_ASSERT_RETURN(oscData.target != nullptr,);
- carla_debug("osc_send_quit(path:\"%s\")", oscData.path);
-
- char targetPath[std::strlen(oscData.path)+6];
- std::strcpy(targetPath, oscData.path);
- std::strcat(targetPath, "/quit");
- try_lo_send(oscData.target, targetPath, "");
- }
-
- static inline
- void osc_send_exiting(const CarlaOscData& oscData) noexcept
- {
- CARLA_SAFE_ASSERT_RETURN(oscData.path != nullptr && oscData.path[0] != '\0',);
- CARLA_SAFE_ASSERT_RETURN(oscData.target != nullptr,);
- carla_debug("osc_send_exiting(path:\"%s\")", oscData.path);
-
- char targetPath[std::strlen(oscData.path)+9];
- std::strcpy(targetPath, oscData.path);
- std::strcat(targetPath, "/exiting");
- try_lo_send(oscData.target, targetPath, "");
- }
-
- // -----------------------------------------------------------------------
-
- static inline
- void osc_send_bridge_ready(const CarlaOscData& oscData, const char* const url) noexcept
- {
- CARLA_SAFE_ASSERT_RETURN(oscData.path != nullptr && oscData.path[0] != '\0',);
- CARLA_SAFE_ASSERT_RETURN(oscData.target != nullptr,);
- CARLA_SAFE_ASSERT_RETURN(url != nullptr && url[0] != '\0',);
- carla_debug("osc_send_bridge_ready(path:\"%s\", \"%s\")", oscData.path, url);
-
- char targetPath[std::strlen(oscData.path)+18];
- std::strcpy(targetPath, oscData.path);
- std::strcat(targetPath, "/bridge_ready");
- try_lo_send(oscData.target, targetPath, "s", url);
- }
-
- static inline
- void osc_send_bridge_error(const CarlaOscData& oscData, const char* const error) noexcept
- {
- CARLA_SAFE_ASSERT_RETURN(oscData.path != nullptr && oscData.path[0] != '\0',);
- CARLA_SAFE_ASSERT_RETURN(oscData.target != nullptr,);
- CARLA_SAFE_ASSERT_RETURN(error != nullptr && error[0] != '\0',);
- carla_debug("osc_send_bridge_error(path:\"%s\", \"%s\")", oscData.path, error);
-
- char targetPath[std::strlen(oscData.path)+14];
- std::strcpy(targetPath, oscData.path);
- std::strcat(targetPath, "/bridge_error");
- try_lo_send(oscData.target, targetPath, "s", error);
- }
-
- // -----------------------------------------------------------------------
-
- static inline
- void osc_send_lv2_atom_transfer(const CarlaOscData& oscData, const uint32_t portIndex, const char* const atomBuf) noexcept
- {
- CARLA_SAFE_ASSERT_RETURN(oscData.path != nullptr && oscData.path[0] != '\0',);
- CARLA_SAFE_ASSERT_RETURN(oscData.target != nullptr,);
- CARLA_SAFE_ASSERT_RETURN(atomBuf != nullptr && atomBuf[0] != '\0',);
- carla_debug("osc_send_lv2_atom_transfer(path:\"%s\", %u, <atomBuf:%p>)", oscData.path, portIndex, atomBuf);
-
- char targetPath[std::strlen(oscData.path)+19];
- std::strcpy(targetPath, oscData.path);
- std::strcat(targetPath, "/lv2_atom_transfer");
- try_lo_send(oscData.target, targetPath, "is", static_cast<int32_t>(portIndex), atomBuf);
- }
-
- static inline
- void osc_send_lv2_urid_map(const CarlaOscData& oscData, const uint32_t urid, const char* const uri) noexcept
- {
- CARLA_SAFE_ASSERT_RETURN(oscData.path != nullptr && oscData.path[0] != '\0',);
- CARLA_SAFE_ASSERT_RETURN(oscData.target != nullptr,);
- //CARLA_SAFE_ASSERT_RETURN(urid != 0,);
- CARLA_SAFE_ASSERT_RETURN(uri != nullptr && uri[0] != '\0',);
- carla_debug("osc_send_lv2_urid_map(path:\"%s\", %u, \"%s\")", oscData.path, urid, uri);
-
- char targetPath[std::strlen(oscData.path)+14];
- std::strcpy(targetPath, oscData.path);
- std::strcat(targetPath, "/lv2_urid_map");
- try_lo_send(oscData.target, targetPath, "is", static_cast<int32_t>(urid), uri);
- }
-
- // -----------------------------------------------------------------------
-
- #endif // CARLA_OSC_UTILS_HPP_INCLUDED
|