diff options
author | David Robillard <d@drobilla.net> | 2020-11-28 12:02:55 +0100 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2020-11-28 12:45:57 +0100 |
commit | 0ae4276ac187a9a361950f26bd67eb2d54636aff (patch) | |
tree | cc46c2ff5df75d426de5e80b891042ae1ebb7bf3 /src | |
parent | 4ac8e622bb4ef5841435fc0815efb6bb756f76da (diff) | |
download | patchage-0ae4276ac187a9a361950f26bd67eb2d54636aff.tar.gz patchage-0ae4276ac187a9a361950f26bd67eb2d54636aff.tar.bz2 patchage-0ae4276ac187a9a361950f26bd67eb2d54636aff.zip |
Simplify driver connection interface
Diffstat (limited to 'src')
-rw-r--r-- | src/AlsaDriver.cpp | 45 | ||||
-rw-r--r-- | src/AlsaDriver.hpp | 15 | ||||
-rw-r--r-- | src/Driver.hpp | 15 | ||||
-rw-r--r-- | src/JackDbusDriver.cpp | 33 | ||||
-rw-r--r-- | src/JackDbusDriver.hpp | 15 | ||||
-rw-r--r-- | src/JackDriver.cpp | 37 | ||||
-rw-r--r-- | src/JackDriver.hpp | 15 | ||||
-rw-r--r-- | src/PatchageCanvas.cpp | 28 | ||||
-rw-r--r-- | src/PortID.hpp | 1 | ||||
-rw-r--r-- | src/PortNames.hpp | 44 |
10 files changed, 91 insertions, 157 deletions
diff --git a/src/AlsaDriver.cpp b/src/AlsaDriver.cpp index b8dcdc6..a132d54 100644 --- a/src/AlsaDriver.cpp +++ b/src/AlsaDriver.cpp @@ -24,6 +24,7 @@ PATCHAGE_DISABLE_FMT_WARNINGS #include <fmt/core.h> +#include <fmt/ostream.h> PATCHAGE_RESTORE_WARNINGS #include <cassert> @@ -406,12 +407,7 @@ AlsaDriver::ignore(const snd_seq_addr_t& addr, bool add) * \return Whether connection succeeded. */ bool -AlsaDriver::connect(const PortID tail_id, - const std::string& tail_client_name, - const std::string& tail_port_name, - const PortID head_id, - const std::string& head_client_name, - const std::string& head_port_name) +AlsaDriver::connect(const PortID tail_id, const PortID head_id) { if (tail_id.type() != PortID::Type::alsa || head_id.type() != PortID::Type::alsa) { @@ -455,17 +451,10 @@ AlsaDriver::connect(const PortID tail_id, } if (result) { - _log.info(fmt::format("[ALSA] Connected {}:{} => {}:{}", - tail_client_name, - tail_port_name, - head_client_name, - head_port_name)); + _log.info(fmt::format("[ALSA] Connected {} => {}", tail_id, head_id)); } else { - _log.error(fmt::format("[ALSA] Failed to connect {}:{} => {}:{}", - tail_client_name, - tail_port_name, - head_client_name, - head_port_name)); + _log.error( + fmt::format("[ALSA] Failed to connect {} => {}", tail_id, head_id)); } return (!result); @@ -476,12 +465,7 @@ AlsaDriver::connect(const PortID tail_id, * \return Whether disconnection succeeded. */ bool -AlsaDriver::disconnect(const PortID tail_id, - const std::string& tail_client_name, - const std::string& tail_port_name, - const PortID head_id, - const std::string& head_client_name, - const std::string& head_port_name) +AlsaDriver::disconnect(const PortID tail_id, const PortID head_id) { if (tail_id.type() != PortID::Type::alsa || head_id.type() != PortID::Type::alsa) { @@ -512,21 +496,14 @@ AlsaDriver::disconnect(const PortID tail_id, int ret = snd_seq_unsubscribe_port(_seq, subs); if (ret < 0) { - _log.error( - fmt::format("[ALSA] Failed to disconnect {}:{} => {}:{} ({})", - tail_client_name, - tail_port_name, - head_client_name, - head_port_name, - snd_strerror(ret))); + _log.error(fmt::format("[ALSA] Failed to disconnect {} => {} ({})", + tail_id, + head_id, + snd_strerror(ret))); return false; } - _log.info(fmt::format("[ALSA] Disconnected {}:{} => {}:{}", - tail_client_name, - tail_port_name, - head_client_name, - head_port_name)); + _log.info(fmt::format("[ALSA] Disconnected {} => {}", tail_id, head_id)); return true; } diff --git a/src/AlsaDriver.hpp b/src/AlsaDriver.hpp index 49acf51..2680509 100644 --- a/src/AlsaDriver.hpp +++ b/src/AlsaDriver.hpp @@ -59,19 +59,8 @@ public: PatchagePort* create_port_view(Patchage* patchage, const PortID& id) override; - bool connect(PortID tail_id, - const std::string& tail_client_name, - const std::string& tail_port_name, - PortID head_id, - const std::string& head_client_name, - const std::string& head_port_name) override; - - bool disconnect(PortID tail_id, - const std::string& tail_client_name, - const std::string& tail_port_name, - PortID head_id, - const std::string& head_client_name, - const std::string& head_port_name) override; + bool connect(PortID tail_id, PortID head_id) override; + bool disconnect(PortID tail_id, PortID head_id) override; void print_addr(snd_seq_addr_t addr); diff --git a/src/Driver.hpp b/src/Driver.hpp index 1144df5..5a9883c 100644 --- a/src/Driver.hpp +++ b/src/Driver.hpp @@ -52,19 +52,8 @@ public: virtual PatchagePort* create_port_view(Patchage* patchage, const PortID& id) = 0; - virtual bool connect(PortID tail_id, - const std::string& tail_client_name, - const std::string& tail_port_name, - PortID head_id, - const std::string& head_client_name, - const std::string& head_port_name) = 0; - - virtual bool disconnect(PortID tail_id, - const std::string& tail_client_name, - const std::string& tail_port_name, - PortID head_id, - const std::string& head_client_name, - const std::string& head_port_name) = 0; + virtual bool connect(PortID tail_id, PortID head_id) = 0; + virtual bool disconnect(PortID tail_id, PortID head_id) = 0; sigc::signal<void> signal_attached; sigc::signal<void> signal_detached; diff --git a/src/JackDbusDriver.cpp b/src/JackDbusDriver.cpp index 7d3a532..855acf8 100644 --- a/src/JackDbusDriver.cpp +++ b/src/JackDbusDriver.cpp @@ -24,6 +24,7 @@ #include "PatchageCanvas.hpp" #include "PatchageEvent.hpp" #include "PatchageModule.hpp" +#include "PortNames.hpp" PATCHAGE_DISABLE_FMT_WARNINGS #include <fmt/core.h> @@ -620,7 +621,7 @@ JackDriver::add_port(PatchageModule* module, void JackDriver::add_port(dbus_uint64_t /*client_id*/, - const char* client_name, + const char* client_name, dbus_uint64_t /*port_id*/, const char* port_name, dbus_uint32_t port_flags, @@ -925,15 +926,14 @@ JackDriver::refresh() } bool -JackDriver::connect(const PortID tail_id, - const std::string& tail_client_name, - const std::string& tail_port_name, - const PortID head_id, - const std::string& head_client_name, - const std::string& head_port_name) +JackDriver::connect(const PortID tail_id, const PortID head_id) { - (void)tail_id; - (void)head_id; + const auto tail_names = PortNames(tail_id); + const auto head_names = PortNames(head_id); + const char* const tail_client_name = tail_names.client().c_str(); + const char* const tail_port_name = tail_names.port().c_str(); + const char* const head_client_name = head_names.client().c_str(); + const char* const head_port_name = head_names.port().c_str(); DBusMessage* reply_ptr = nullptr; @@ -958,15 +958,14 @@ JackDriver::connect(const PortID tail_id, } bool -JackDriver::disconnect(const PortID tail_id, - const std::string& tail_client_name, - const std::string& tail_port_name, - const PortID head_id, - const std::string& head_client_name, - const std::string& head_port_name) +JackDriver::disconnect(const PortID tail_id, const PortID head_id) { - (void)tail_id; - (void)head_id; + const auto tail_names = PortNames(tail_id); + const auto head_names = PortNames(head_id); + const char* const tail_client_name = tail_names.client().c_str(); + const char* const tail_port_name = tail_names.port().c_str(); + const char* const head_client_name = head_names.client().c_str(); + const char* const head_port_name = head_names.port().c_str(); DBusMessage* reply_ptr = nullptr; diff --git a/src/JackDbusDriver.hpp b/src/JackDbusDriver.hpp index 1ba581c..ac1137d 100644 --- a/src/JackDbusDriver.hpp +++ b/src/JackDbusDriver.hpp @@ -56,19 +56,8 @@ public: void refresh() override; void destroy_all() override; - bool connect(PortID tail_id, - const std::string& tail_client_name, - const std::string& tail_port_name, - PortID head_id, - const std::string& head_client_name, - const std::string& head_port_name) override; - - bool disconnect(PortID tail_id, - const std::string& tail_client_name, - const std::string& tail_port_name, - PortID head_id, - const std::string& head_client_name, - const std::string& head_port_name) override; + bool connect(PortID tail_id, PortID head_id) override; + bool disconnect(PortID tail_id, PortID head_id) override; uint32_t get_xruns(); void reset_xruns(); diff --git a/src/JackDriver.cpp b/src/JackDriver.cpp index e0b01ff..8127f42 100644 --- a/src/JackDriver.cpp +++ b/src/JackDriver.cpp @@ -22,6 +22,7 @@ #include "PatchageCanvas.hpp" #include "PatchageEvent.hpp" #include "PatchageModule.hpp" +#include "PortNames.hpp" #include "patchage_config.h" #ifdef HAVE_JACK_METADATA @@ -425,27 +426,15 @@ JackDriver::port_names(const PortID& id, return true; } -/** Connects two Jack audio ports. - * To be called from GTK thread only. - * \return Whether connection succeeded. - */ bool -JackDriver::connect(const PortID tail_id, - const std::string& tail_client_name, - const std::string& tail_port_name, - const PortID head_id, - const std::string& head_client_name, - const std::string& head_port_name) +JackDriver::connect(const PortID tail_id, const PortID head_id) { - (void)tail_id; - (void)head_id; - if (!_client) { return false; } - const auto tail_name = tail_client_name + ":" + tail_port_name; - const auto head_name = head_client_name + ":" + head_port_name; + const auto& tail_name = tail_id.jack_name(); + const auto& head_name = head_id.jack_name(); const int result = jack_connect(_client, tail_name.c_str(), head_name.c_str()); @@ -461,27 +450,15 @@ JackDriver::connect(const PortID tail_id, return !result; } -/** Disconnects two Jack audio ports. - * To be called from GTK thread only. - * \return Whether disconnection succeeded. - */ bool -JackDriver::disconnect(const PortID tail_id, - const std::string& tail_client_name, - const std::string& tail_port_name, - const PortID head_id, - const std::string& head_client_name, - const std::string& head_port_name) +JackDriver::disconnect(const PortID tail_id, const PortID head_id) { - (void)tail_id; - (void)head_id; - if (!_client) { return false; } - const auto tail_name = tail_client_name + ":" + tail_port_name; - const auto head_name = head_client_name + ":" + head_port_name; + const auto& tail_name = tail_id.jack_name(); + const auto& head_name = head_id.jack_name(); const int result = jack_disconnect(_client, tail_name.c_str(), head_name.c_str()); diff --git a/src/JackDriver.hpp b/src/JackDriver.hpp index abf9008..7500f6e 100644 --- a/src/JackDriver.hpp +++ b/src/JackDriver.hpp @@ -68,19 +68,8 @@ public: PatchagePort* create_port_view(Patchage* patchage, const PortID& id) override; - bool connect(PortID tail_id, - const std::string& tail_client_name, - const std::string& tail_port_name, - PortID head_id, - const std::string& head_client_name, - const std::string& head_port_name) override; - - bool disconnect(PortID tail_id, - const std::string& tail_client_name, - const std::string& tail_port_name, - PortID head_id, - const std::string& head_client_name, - const std::string& head_port_name) override; + bool connect(PortID tail_id, PortID head_id) override; + bool disconnect(PortID tail_id, PortID head_id) override; uint32_t get_xruns() const { return _xruns; } void reset_xruns(); diff --git a/src/PatchageCanvas.cpp b/src/PatchageCanvas.cpp index 1433244..6bae432 100644 --- a/src/PatchageCanvas.cpp +++ b/src/PatchageCanvas.cpp @@ -207,22 +207,12 @@ PatchageCanvas::connect(Ganv::Node* port1, Ganv::Node* port2) (p1->type() == PortType::jack_osc && p2->type() == PortType::jack_osc)) { #if defined(PATCHAGE_LIBJACK) || defined(HAVE_JACK_DBUS) - _app->jack_driver()->connect(p1->id(), - p1->module_name(), - p1->name(), - p2->id(), - p2->module_name(), - p2->name()); + _app->jack_driver()->connect(p1->id(), p2->id()); #endif #ifdef HAVE_ALSA } else if (p1->type() == PortType::alsa_midi && p2->type() == PortType::alsa_midi) { - _app->alsa_driver()->connect(p1->id(), - p1->module_name(), - p1->name(), - p2->id(), - p2->module_name(), - p2->name()); + _app->alsa_driver()->connect(p1->id(), p2->id()); #endif } else { _app->log().warning("Cannot make connection, incompatible port types"); @@ -255,22 +245,12 @@ PatchageCanvas::disconnect(Ganv::Node* port1, Ganv::Node* port2) input->type() == PortType::jack_cv || input->type() == PortType::jack_osc) { #if defined(PATCHAGE_LIBJACK) || defined(HAVE_JACK_DBUS) - _app->jack_driver()->disconnect(output->id(), - output->module_name(), - output->name(), - input->id(), - input->module_name(), - input->name()); + _app->jack_driver()->disconnect(output->id(), input->id()); #endif #ifdef HAVE_ALSA } else if (input->type() == PortType::alsa_midi) { - _app->alsa_driver()->disconnect(output->id(), - output->module_name(), - output->name(), - input->id(), - input->module_name(), - input->name()); + _app->alsa_driver()->disconnect(output->id(), input->id()); #endif } else { _app->log().error("Attempt to disconnect ports with strange types"); diff --git a/src/PortID.hpp b/src/PortID.hpp index 2a53881..efdd78d 100644 --- a/src/PortID.hpp +++ b/src/PortID.hpp @@ -70,6 +70,7 @@ private: , _jack_name{std::move(jack_name)} { assert(_type == Type::jack); + assert(_jack_name.find(':') != std::string::npos); } PortID(const Type type, diff --git a/src/PortNames.hpp b/src/PortNames.hpp new file mode 100644 index 0000000..e976e34 --- /dev/null +++ b/src/PortNames.hpp @@ -0,0 +1,44 @@ +/* This file is part of Patchage. + * Copyright 2008-2020 David Robillard <d@drobilla.net> + * + * Patchage 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 3 of the License, or (at your option) + * any later version. + * + * Patchage 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 details. + * + * You should have received a copy of the GNU General Public License + * along with Patchage. If not, see <http://www.gnu.org/licenses/>. + */ + +#ifndef PATCHAGE_PORTNAMES_HPP +#define PATCHAGE_PORTNAMES_HPP + +#include <cassert> +#include <string> + +/// Utility class that splits a Jack port ID into client and client names +class PortNames +{ +public: + explicit PortNames(const PortID& id) + { + assert(id.type() == PortID::Type::jack); + + const auto colon = id.jack_name().find(':'); + _client_name = id.jack_name().substr(0, colon); + _port_name = id.jack_name().substr(colon + 1); + } + + const std::string& client() const { return _client_name; } + const std::string& port() const { return _port_name; } + +private: + std::string _client_name; + std::string _port_name; +}; + +#endif // PATCHAGE_PORTNAMES_HPP |