summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2008-06-09 19:20:15 +0000
committerDavid Robillard <d@drobilla.net>2008-06-09 19:20:15 +0000
commit4a1a4cecbeca04cd3b2f7a10b7f9fffff886e0ac (patch)
treea0620d7d6333344af21a9ccb09a0c562eded7ac5
parent7f325430ee790d1d926c43e2e40d92b244839ec4 (diff)
downloadpatchage-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.cpp32
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);
}
+