From cfdfb4606a7dac2e25f5ca6b12375cbdcfbb46b2 Mon Sep 17 00:00:00 2001 From: David Robillard Date: Sat, 28 Dec 2013 02:04:31 +0000 Subject: Don't expose non-MIDI event ports to Jack (fix #907). git-svn-id: http://svn.drobilla.net/lad/trunk/jalv@5220 a436a847-0d15-0410-975c-d299462d15a1 --- src/jalv.c | 46 +++++++++++++++++++++++++--------------------- 1 file changed, 25 insertions(+), 21 deletions(-) (limited to 'src') diff --git a/src/jalv.c b/src/jalv.c index ca3d7bf..7ed0aef 100644 --- a/src/jalv.c +++ b/src/jalv.c @@ -367,9 +367,12 @@ activate_port(Jalv* jalv, JACK_DEFAULT_AUDIO_TYPE, jack_flags, 0); break; case TYPE_EVENT: - port->jack_port = jack_port_register( - jalv->jack_client, symbol_str, - JACK_DEFAULT_MIDI_TYPE, jack_flags, 0); + if (lilv_port_supports_event( + jalv->plugin, port->lilv_port, jalv->nodes.midi_MidiEvent)) { + port->jack_port = jack_port_register( + jalv->jack_client, symbol_str, + JACK_DEFAULT_MIDI_TYPE, jack_flags, 0); + } break; default: break; @@ -472,10 +475,7 @@ jack_process_cb(jack_nframes_t nframes, void* data) /* Prepare port buffers */ for (uint32_t p = 0; p < jalv->num_ports; ++p) { struct Port* port = &jalv->ports[p]; - if (!port->jack_port) - continue; - - if (port->type == TYPE_AUDIO) { + if (port->type == TYPE_AUDIO && port->jack_port) { /* Connect plugin port directly to Jack port buffer */ lilv_instance_connect_port( jalv->instance, p, @@ -492,15 +492,17 @@ jack_process_cb(jack_nframes_t nframes, void* data) lv2_pos->type, lv2_pos->size, LV2_ATOM_BODY(lv2_pos)); } - /* Write Jack MIDI input */ - void* buf = jack_port_get_buffer(port->jack_port, nframes); - for (uint32_t i = 0; i < jack_midi_get_event_count(buf); ++i) { - jack_midi_event_t ev; - jack_midi_event_get(&ev, buf, i); - lv2_evbuf_write(&iter, - ev.time, 0, - jalv->midi_event_id, - ev.size, ev.buffer); + if (port->jack_port) { + /* Write Jack MIDI input */ + void* buf = jack_port_get_buffer(port->jack_port, nframes); + for (uint32_t i = 0; i < jack_midi_get_event_count(buf); ++i) { + jack_midi_event_t ev; + jack_midi_event_get(&ev, buf, i); + lv2_evbuf_write(&iter, + ev.time, 0, + jalv->midi_event_id, + ev.size, ev.buffer); + } } } else if (port->type == TYPE_EVENT) { /* Clear event output for plugin to write to */ @@ -559,10 +561,12 @@ jack_process_cb(jack_nframes_t nframes, void* data) /* Deliver MIDI output and UI events */ for (uint32_t p = 0; p < jalv->num_ports; ++p) { struct Port* const port = &jalv->ports[p]; - if (port->jack_port && port->flow == FLOW_OUTPUT - && port->type == TYPE_EVENT) { - void* buf = jack_port_get_buffer(port->jack_port, nframes); - jack_midi_clear_buffer(buf); + if (port->flow == FLOW_OUTPUT && port->type == TYPE_EVENT) { + void* buf = NULL; + if (port->jack_port) { + jack_port_get_buffer(port->jack_port, nframes); + jack_midi_clear_buffer(buf); + } for (LV2_Evbuf_Iterator i = lv2_evbuf_begin(port->evbuf); lv2_evbuf_is_valid(i); @@ -570,7 +574,7 @@ jack_process_cb(jack_nframes_t nframes, void* data) uint32_t frames, subframes, type, size; uint8_t* body; lv2_evbuf_get(i, &frames, &subframes, &type, &size, &body); - if (type == jalv->midi_event_id) { + if (buf && type == jalv->midi_event_id) { jack_midi_event_write(buf, frames, body, size); } -- cgit v1.2.1