From 77b6f2a6a7b37e22323c4a0d80713f6cc8a231d7 Mon Sep 17 00:00:00 2001 From: David Robillard Date: Sat, 3 May 2008 22:16:36 +0000 Subject: Apply slv2_plugin_get_port_ranges usage Ingen patch from larsl. git-svn-id: http://svn.drobilla.net/lad/ingen@1194 a436a847-0d15-0410-975c-d299462d15a1 --- src/libs/engine/LV2Node.cpp | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) (limited to 'src/libs/engine/LV2Node.cpp') diff --git a/src/libs/engine/LV2Node.cpp b/src/libs/engine/LV2Node.cpp index a0fdebc0..bdeca701 100644 --- a/src/libs/engine/LV2Node.cpp +++ b/src/libs/engine/LV2Node.cpp @@ -149,6 +149,9 @@ LV2Node::instantiate() PortImpl* port = NULL; + float* def_values = new float[num_ports]; + slv2_plugin_get_port_ranges(plug, 0, 0, def_values); + for (uint32_t j=0; j < num_ports; ++j) { SLV2Port id = slv2_plugin_get_port_by_index(plug, j); @@ -186,11 +189,9 @@ LV2Node::instantiate() return false; } - SLV2Value def, min, max; - slv2_port_get_range(plug, id, &def, &min, &max); - // FIXME: need nice type preserving SLV2Value -> Raul::Atom conversion - Atom defatm = (float)((def && slv2_value_is_float(def)) ? slv2_value_as_float(def) : 0.0f); + float def = isnan(def_values[j]) ? 0.0f : def_values[j]; + Atom defatm = def; if (direction == INPUT) port = new InputPort(this, port_name, j, _polyphony, data_type, defatm, port_buffer_size); @@ -198,14 +199,13 @@ LV2Node::instantiate() port = new OutputPort(this, port_name, j, _polyphony, data_type, defatm, port_buffer_size); if (direction == INPUT && data_type == DataType::CONTROL) - ((AudioBuffer*)port->buffer(0))->set(slv2_value_as_float(def), 0); - - slv2_value_free(def); - slv2_value_free(min); - slv2_value_free(max); + ((AudioBuffer*)port->buffer(0))->set(def, 0); _ports->at(j) = port; } + + delete [] def_values; + return true; } -- cgit v1.2.1