diff options
author | David Robillard <d@drobilla.net> | 2008-06-09 19:20:15 +0000 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2008-06-09 19:20:15 +0000 |
commit | 4a1a4cecbeca04cd3b2f7a10b7f9fffff886e0ac (patch) | |
tree | a0620d7d6333344af21a9ccb09a0c562eded7ac5 | |
parent | 7f325430ee790d1d926c43e2e40d92b244839ec4 (diff) | |
download | patchage-4a1a4cecbeca04cd3b2f7a10b7f9fffff886e0ac.tar.gz patchage-4a1a4cecbeca04cd3b2f7a10b7f9fffff886e0ac.tar.bz2 patchage-4a1a4cecbeca04cd3b2f7a10b7f9fffff886e0ac.zip |
Fix creation of new ports on split modules (fixes ticket #144).
git-svn-id: http://svn.drobilla.net/lad/patchage@1257 a436a847-0d15-0410-975c-d299462d15a1
-rw-r--r-- | src/JackDriver.cpp | 32 |
1 files changed, 23 insertions, 9 deletions
diff --git a/src/JackDriver.cpp b/src/JackDriver.cpp index 44c3b99..2b98ecb 100644 --- a/src/JackDriver.cpp +++ b/src/JackDriver.cpp @@ -148,15 +148,26 @@ JackDriver::create_port_view(Patchage* patchage, if (ref.type == PatchageEvent::PortRef::JACK_ID) jack_port = jack_port_by_id(_client, ref.id.jack_id); - + string module_name, port_name; port_names(ref, module_name, port_name); + + ModuleType type = InputOutput; + if (_app->state_manager()->get_module_split(module_name, + (jack_port_flags(jack_port) & JackPortIsTerminal))) { + if (jack_port_flags(jack_port) & JackPortIsInput) { + type = Input; + } else { + type = Output; + } + } + boost::shared_ptr<PatchageModule> parent - = _app->canvas()->find_module(module_name, InputOutput); + = _app->canvas()->find_module(module_name, type); if (!parent) { parent = boost::shared_ptr<PatchageModule>( - new PatchageModule(patchage, module_name, InputOutput)); + new PatchageModule(patchage, module_name, type)); parent->load_location(); patchage->canvas()->add_item(parent); parent->show(); @@ -233,13 +244,17 @@ JackDriver::refresh() ports = jack_get_ports(_client, NULL, NULL, 0); // get all existing ports + if (!ports) { + _shutdown_mutex.unlock(); + return; + } + string client1_name; string port1_name; string client2_name; string port2_name; // Add all ports - if (ports) for (int i=0; ports[i]; ++i) { port = jack_port_by_name(_client, ports[i]); @@ -285,8 +300,6 @@ JackDriver::refresh() } // Add all connections - if (ports) { - for (int i=0; ports[i]; ++i) { port = jack_port_by_name(_client, ports[i]); @@ -331,8 +344,6 @@ JackDriver::refresh() } } - } - _shutdown_mutex.unlock(); free(ports); @@ -570,6 +581,7 @@ JackDriver::set_buffer_size(jack_nframes_t size) } } + float JackDriver::get_max_dsp_load() { @@ -592,8 +604,10 @@ JackDriver::get_max_dsp_load() return max_load; } + void JackDriver::reset_max_dsp_load() { - jack_reset_max_delayed_usecs(_client); + jack_reset_max_delayed_usecs(_client); } + |