aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2014-04-06 06:14:04 +0000
committerDavid Robillard <d@drobilla.net>2014-04-06 06:14:04 +0000
commiteb3d5ce0b533e4c7df025d1528a95570ee99b975 (patch)
tree152715e06bd0265e4c315136982088d146551cea
parent63c82eab6b70d77b46565467adb6c9b0fc00a524 (diff)
downloadjalv-eb3d5ce0b533e4c7df025d1528a95570ee99b975.tar.gz
jalv-eb3d5ce0b533e4c7df025d1528a95570ee99b975.tar.bz2
jalv-eb3d5ce0b533e4c7df025d1528a95570ee99b975.zip
Support port pretty names via new Jack metadata API.
git-svn-id: http://svn.drobilla.net/lad/trunk/jalv@5357 a436a847-0d15-0410-975c-d299462d15a1
-rw-r--r--NEWS5
-rw-r--r--src/jalv.c36
-rw-r--r--wscript9
3 files changed, 34 insertions, 16 deletions
diff --git a/NEWS b/NEWS
index 8adf7ab..24fb391 100644
--- a/NEWS
+++ b/NEWS
@@ -2,9 +2,10 @@ jalv (1.4.5) unstable;
* Show newly saved presets in the preset menu
* Generate Qt moc nonsense at build time for broader compatibility
- * Update for latest LV2 Atom Object simplifications.
+ * Update for latest LV2 Atom Object simplifications
+ * Set port pretty names via new Jack metadata API
- -- David Robillard <d@drobilla.net> Sun, 12 Jan 2014 18:50:11 -0500
+ -- David Robillard <d@drobilla.net> Sun, 06 Apr 2014 02:03:55 -0400
jalv (1.4.4) stable;
diff --git a/src/jalv.c b/src/jalv.c
index 0708577..bb4a574 100644
--- a/src/jalv.c
+++ b/src/jalv.c
@@ -44,6 +44,9 @@
#ifdef JALV_JACK_SESSION
# include <jack/session.h>
#endif
+#ifdef HAVE_JACK_METADATA
+# include <jack/metadata.h>
+#endif
#include "lv2/lv2plug.in/ns/ext/atom/atom.h"
#include "lv2/lv2plug.in/ns/ext/buf-size/buf-size.h"
@@ -203,10 +206,6 @@ create_port(Jalv* jalv,
port->control = 0.0f;
port->flow = FLOW_UNKNOWN;
- /* Get the port symbol for console printing */
- const LilvNode* symbol = lilv_port_get_symbol(jalv->plugin,
- port->lilv_port);
-
const bool optional = lilv_port_has_property(
jalv->plugin, port->lilv_port, jalv->nodes.lv2_connectionOptional);
@@ -248,9 +247,11 @@ create_port(Jalv* jalv,
}
lilv_node_free(min_size);
- const size_t sym_len = strlen(lilv_node_as_string(symbol));
- if (sym_len > jalv->longest_sym) {
- jalv->longest_sym = sym_len;
+ /* Update longest symbol for aligned console printing */
+ const LilvNode* sym = lilv_port_get_symbol(jalv->plugin, port->lilv_port);
+ const size_t len = strlen(lilv_node_as_string(sym));
+ if (len > jalv->longest_sym) {
+ jalv->longest_sym = len;
}
}
@@ -338,10 +339,7 @@ activate_port(Jalv* jalv,
{
struct Port* const port = &jalv->ports[port_index];
- /* Get the port symbol for console printing */
- const LilvNode* symbol = lilv_port_get_symbol(jalv->plugin,
- port->lilv_port);
- const char* symbol_str = lilv_node_as_string(symbol);
+ const LilvNode* sym = lilv_port_get_symbol(jalv->plugin, port->lilv_port);
/* Connect unsupported ports to NULL (known to be optional by this point) */
if (port->flow == FLOW_UNKNOWN || port->type == TYPE_UNKNOWN) {
@@ -357,26 +355,36 @@ activate_port(Jalv* jalv,
/* Connect the port based on its type */
switch (port->type) {
case TYPE_CONTROL:
- printf("%-*s = %f\n", jalv->longest_sym, symbol_str,
+ printf("%-*s = %f\n", jalv->longest_sym, lilv_node_as_string(sym),
jalv->ports[port_index].control);
lilv_instance_connect_port(jalv->instance, port_index, &port->control);
break;
case TYPE_AUDIO:
port->jack_port = jack_port_register(
- jalv->jack_client, symbol_str,
+ jalv->jack_client, lilv_node_as_string(sym),
JACK_DEFAULT_AUDIO_TYPE, jack_flags, 0);
break;
case TYPE_EVENT:
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,
+ jalv->jack_client, lilv_node_as_string(sym),
JACK_DEFAULT_MIDI_TYPE, jack_flags, 0);
}
break;
default:
break;
}
+
+#ifdef HAVE_JACK_METADATA
+ if (port->jack_port) {
+ LilvNode* name = lilv_port_get_name(jalv->plugin, port->lilv_port);
+ jack_set_property(
+ jalv->jack_client, jack_port_uuid(port->jack_port),
+ JACK_METADATA_PRETTY_NAME, lilv_node_as_string(name), NULL);
+ lilv_node_free(name);
+ }
+#endif
}
/** Jack buffer size callback. */
diff --git a/wscript b/wscript
index 20d8f24..65d7645 100644
--- a/wscript
+++ b/wscript
@@ -61,6 +61,13 @@ def configure(conf):
conf.check(function_name='jack_port_type_get_buffer_size',
header_name='jack/jack.h',
define_name='HAVE_JACK_PORT_TYPE_GET_BUFFER_SIZE',
+ uselib='JACK',
+ mandatory=False)
+
+ conf.check(function_name='jack_set_property',
+ header_name='jack/metadata.h',
+ define_name='HAVE_JACK_METADATA',
+ uselib='JACK',
mandatory=False)
if not Options.options.no_jack_session:
@@ -70,6 +77,8 @@ def configure(conf):
conf.write_config_header('jalv_config.h', remove=False)
+ autowaf.display_msg(conf, "Jack metadata support",
+ conf.is_defined('HAVE_JACK_METADATA'))
autowaf.display_msg(conf, "Gtk 2.0 support",
conf.is_defined('HAVE_GTK2'))
autowaf.display_msg(conf, "Gtk 3.0 support",