diff options
author | David Robillard <d@drobilla.net> | 2007-07-25 01:06:22 +0000 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2007-07-25 01:06:22 +0000 |
commit | 5837be3b45c83bd5743735de8cf451c5bdf3541d (patch) | |
tree | 3a0331f2a5391726efbb7b6362004a06050f50f1 | |
parent | 35b1c7c0683a72978f646c883f411e1eabd595ae (diff) | |
download | patchage-5837be3b45c83bd5743735de8cf451c5bdf3541d.tar.gz patchage-5837be3b45c83bd5743735de8cf451c5bdf3541d.tar.bz2 patchage-5837be3b45c83bd5743735de8cf451c5bdf3541d.zip |
Avoid some canvas text measuring overhead in Patchage (module resizing).
Fix duplex Alsa Sequencer ports (fix ticket 12).
git-svn-id: http://svn.drobilla.net/lad/patchage@617 a436a847-0d15-0410-975c-d299462d15a1
-rw-r--r-- | src/AlsaDriver.cpp | 60 | ||||
-rw-r--r-- | src/AlsaDriver.hpp | 2 | ||||
-rw-r--r-- | src/JackDriver.cpp | 9 | ||||
-rw-r--r-- | src/PatchageCanvas.cpp | 26 | ||||
-rw-r--r-- | src/PatchageCanvas.hpp | 2 | ||||
-rw-r--r-- | src/PatchageEvent.cpp | 2 | ||||
-rw-r--r-- | src/PatchageEvent.hpp | 17 |
7 files changed, 91 insertions, 27 deletions
diff --git a/src/AlsaDriver.cpp b/src/AlsaDriver.cpp index 5aad6aa..115524d 100644 --- a/src/AlsaDriver.cpp +++ b/src/AlsaDriver.cpp @@ -16,8 +16,10 @@ */ #include <string> +#include <set> #include <iostream> #include <cassert> +#include <raul/SharedPtr.hpp> #include "PatchageCanvas.hpp" #include "AlsaDriver.hpp" #include "Patchage.hpp" @@ -128,6 +130,8 @@ AlsaDriver::refresh_ports() bool is_input = false; bool is_duplex = false; bool is_application = true; + + set<SharedPtr<PatchageModule> > resized_modules; while (snd_seq_query_next_client (_seq, cinfo) >= 0) { snd_seq_port_info_set_client(pinfo, snd_seq_client_info_get_client(cinfo)); @@ -166,11 +170,12 @@ AlsaDriver::refresh_ports() is_application = (type & SND_SEQ_PORT_TYPE_APPLICATION); port_name = snd_seq_port_info_get_name(pinfo); boost::shared_ptr<PatchageModule> m; + + bool split = _app->state_manager()->get_module_split(client_name, !is_application) + || is_duplex; //cout << client_name << " : " << port_name << " is_application = " << is_application - // << " is_duplex = " << is_duplex << endl; - - bool split = _app->state_manager()->get_module_split(client_name, !is_application); + // << " is_duplex = " << is_duplex << ", split = " << split << endl; // Application input/output ports go on the same module if (!split) { @@ -188,7 +193,9 @@ AlsaDriver::refresh_ports() m->add_port(create_port(m, port_name, true, addr)); m->add_port(create_port(m, port_name, false, addr)); } + resized_modules.insert(m); } + } else { // non-application input/output ports (hw interface, etc) go on separate modules ModuleType type = InputOutput; @@ -196,8 +203,8 @@ AlsaDriver::refresh_ports() // is pretty nasty... if (!is_duplex) { // just one port to add - if (is_input) type = Input; - else type = Output; + + type = ((is_input) ? Input : Output); // See if an InputOutput module exists (maybe with Jack ports on it) m = _app->canvas()->find_module(client_name, InputOutput); @@ -211,8 +218,12 @@ AlsaDriver::refresh_ports() m->load_location(); m->store_location(); } - if (!m->get_port(port_name)) + + if (!m->get_port(port_name)) { m->add_port(create_port(m, port_name, is_input, addr)); + resized_modules.insert(m); + } + } else { // two ports to add type = Input; @@ -227,12 +238,15 @@ AlsaDriver::refresh_ports() new PatchageModule(_app, client_name, type)); m->load_location(); m->store_location(); + _app->canvas()->add_item(m); } assert(m); - if (!m->get_port(port_name)) + if (!m->get_port(port_name)) { m->add_port(create_port(m, port_name, true, addr)); + resized_modules.insert(m); + } type = Output; @@ -247,17 +261,21 @@ AlsaDriver::refresh_ports() new PatchageModule(_app, client_name, type)); m->load_location(); m->store_location(); + _app->canvas()->add_item(m); } - if (!m->get_port(port_name)) + + if (!m->get_port(port_name)) { m->add_port(create_port(m, port_name, false, addr)); + resized_modules.insert(m); + } } } - - _app->canvas()->add_item(m); - - m->resize(); } } + + for (set<SharedPtr<PatchageModule> >::const_iterator i = resized_modules.begin(); + i != resized_modules.end(); ++i) + (*i)->resize(); } @@ -307,10 +325,12 @@ AlsaDriver::add_connections(boost::shared_ptr<PatchagePort> port) snd_seq_query_subscribe_set_root(subsinfo, addr); snd_seq_query_subscribe_set_index(subsinfo, 0); - while(!snd_seq_query_port_subscribers(_seq, subsinfo)) { + while (!snd_seq_query_port_subscribers(_seq, subsinfo)) { const snd_seq_addr_t* connected_addr = snd_seq_query_subscribe_get_addr(subsinfo); + if (!connected_addr) + continue; - connected_port = _app->canvas()->find_port(connected_addr); + connected_port = _app->canvas()->find_port(*connected_addr, true); if (connected_port) { boost::shared_ptr<Connection> existing = _app->canvas()->get_connection(port, connected_port); @@ -505,6 +525,12 @@ AlsaDriver::_refresh_main() switch (ev->type) { case SND_SEQ_EVENT_PORT_SUBSCRIBED: + /*cout << "Subscription: "; + print_addr(ev->data.connect.sender); + cout << " -> "; + print_addr(ev->data.connect.dest); + cout << endl;*/ + _events.push(PatchageEvent(PatchageEvent::CONNECTION, ev->data.connect.sender, ev->data.connect.dest)); break; @@ -530,3 +556,9 @@ AlsaDriver::_refresh_main() } } + +void +AlsaDriver::print_addr(snd_seq_addr_t addr) +{ + cout << (int)addr.client << ":" << (int)addr.port << endl; +} diff --git a/src/AlsaDriver.hpp b/src/AlsaDriver.hpp index d251d78..11adac7 100644 --- a/src/AlsaDriver.hpp +++ b/src/AlsaDriver.hpp @@ -51,6 +51,8 @@ public: bool disconnect(boost::shared_ptr<PatchagePort> src_port, boost::shared_ptr<PatchagePort> dst_port); + + void print_addr(snd_seq_addr_t addr); private: void refresh_ports(); diff --git a/src/JackDriver.cpp b/src/JackDriver.cpp index 5572769..761c1c2 100644 --- a/src/JackDriver.cpp +++ b/src/JackDriver.cpp @@ -18,6 +18,7 @@ #include <cassert> #include <cstring> #include <string> +#include <set> #include <iostream> #include "config.h" #include <jack/jack.h> @@ -202,6 +203,8 @@ JackDriver::refresh() string port1_name; string client2_name; string port2_name; + + set<SharedPtr<PatchageModule> > resized_modules; // Add all ports if (ports) @@ -258,7 +261,7 @@ JackDriver::refresh() m->add_port(create_port(m, port)); } - m->resize(); + resized_modules.insert(m); } // Add all connections @@ -320,6 +323,10 @@ JackDriver::refresh() free(connected_ports); } } + + for (set<SharedPtr<PatchageModule> >::const_iterator i = resized_modules.begin(); + i != resized_modules.end(); ++i) + (*i)->resize(); free(ports); } diff --git a/src/PatchageCanvas.cpp b/src/PatchageCanvas.cpp index 22b4d1f..ea4e371 100644 --- a/src/PatchageCanvas.cpp +++ b/src/PatchageCanvas.cpp @@ -62,19 +62,33 @@ PatchageCanvas::find_module(const string& name, ModuleType type) #ifdef HAVE_ALSA boost::shared_ptr<PatchagePort> -PatchageCanvas::find_port(const snd_seq_addr_t* alsa_addr) +PatchageCanvas::find_port(snd_seq_addr_t alsa_addr, bool input) { boost::shared_ptr<PatchagePort> pp; for (ItemList::iterator m = _items.begin(); m != _items.end(); ++m) { - SharedPtr<Module> module = PtrCast<Module>(*m); + SharedPtr<PatchageModule> module = PtrCast<PatchageModule>(*m); if (!module) continue; + for (PortVector::const_iterator p = module->ports().begin(); p != module->ports().end(); ++p) { pp = boost::dynamic_pointer_cast<PatchagePort>(*p); - if (pp && pp->type() == ALSA_MIDI && pp->alsa_addr() - && pp->alsa_addr()->client == alsa_addr->client - && pp->alsa_addr()->port == alsa_addr->port) - return pp; + if (!pp) + continue; + + if (pp->type() == ALSA_MIDI) { + /*cerr << "ALSA PORT: " << (int)pp->alsa_addr()->client << ":" + << (int)pp->alsa_addr()->port << endl;*/ + + if (pp->alsa_addr() + && pp->alsa_addr()->client == alsa_addr.client + && pp->alsa_addr()->port == alsa_addr.port) { + if (!input && module->type() == Input) { + //cerr << "WRONG DIRECTION, SKIPPED PORT" << endl; + } else { + return pp; + } + } + } } } diff --git a/src/PatchageCanvas.hpp b/src/PatchageCanvas.hpp index fd662f1..0ef54fb 100644 --- a/src/PatchageCanvas.hpp +++ b/src/PatchageCanvas.hpp @@ -40,7 +40,7 @@ public: boost::shared_ptr<PatchageModule> find_module(const string& name, ModuleType type); #ifdef HAVE_ALSA - boost::shared_ptr<PatchagePort> find_port(const snd_seq_addr_t* alsa_addr); + boost::shared_ptr<PatchagePort> find_port(snd_seq_addr_t alsa_addr, bool input); #endif void connect(boost::shared_ptr<Connectable> port1, boost::shared_ptr<Connectable> port2); void disconnect(boost::shared_ptr<Connectable> port1, boost::shared_ptr<Connectable> port2); diff --git a/src/PatchageEvent.cpp b/src/PatchageEvent.cpp index a6b237f..e2849b7 100644 --- a/src/PatchageEvent.cpp +++ b/src/PatchageEvent.cpp @@ -32,7 +32,7 @@ PatchageEvent::find_port(const Patchage* patchage, const PortRef& ref) #ifdef HAVE_ALSA if (ref.type == PortRef::ALSA_ADDR) { - return patchage->canvas()->find_port(&ref.id.alsa_addr); + return patchage->canvas()->find_port(ref.id.alsa_addr, ref.is_input); } else #endif { diff --git a/src/PatchageEvent.hpp b/src/PatchageEvent.hpp index ada4718..19cf16d 100644 --- a/src/PatchageEvent.hpp +++ b/src/PatchageEvent.hpp @@ -25,6 +25,9 @@ #endif #include "PatchagePort.hpp" +#include <iostream> +using namespace std; + class Patchage; @@ -58,8 +61,8 @@ public: #ifdef HAVE_ALSA PatchageEvent(Type type, snd_seq_addr_t port_1, snd_seq_addr_t port_2) : _type(type) - , _port_1(port_1) - , _port_2(port_2) + , _port_1(port_1, false) + , _port_2(port_2, true) {} #endif @@ -71,13 +74,14 @@ private: uint8_t _type; struct PortRef { - PortRef() : type(NULL_PORT_REF) { id.jack_id = 0; } + PortRef() : type(NULL_PORT_REF) { memset(&id, 0, sizeof(id)); } PortRef(jack_port_id_t jack_id) : type(JACK_ID) { id.jack_id = jack_id; } PortRef(jack_port_t* jack_port) : type(JACK_PORT) { id.jack_port = jack_port; } #ifdef HAVE_ALSA - PortRef(snd_seq_addr_t addr) : type(ALSA_ADDR) { id.alsa_addr = addr; } + PortRef(snd_seq_addr_t addr, bool input) : type(ALSA_ADDR) + { id.alsa_addr = addr; is_input = input; } #endif enum { NULL_PORT_REF, JACK_ID, JACK_PORT, ALSA_ADDR } type; @@ -89,6 +93,11 @@ private: snd_seq_addr_t alsa_addr; #endif } id; + +#ifdef HAVE_ALSA + bool is_input; +#endif + }; PortRef _port_1; |