From 0bb0b753c62c900027def66288489442cb69f336 Mon Sep 17 00:00:00 2001 From: David Robillard Date: Thu, 31 Dec 2015 14:10:55 -0500 Subject: Fix controls when range is given with integers --- src/control.c | 7 +++++-- src/jalv_gtk.c | 25 ++++++++++++++++--------- src/jalv_qt.cpp | 2 +- 3 files changed, 22 insertions(+), 12 deletions(-) diff --git a/src/control.c b/src/control.c index 1921785..97ba797 100644 --- a/src/control.c +++ b/src/control.c @@ -39,6 +39,9 @@ new_port_control(Jalv* jalv, uint32_t index) id->jalv = jalv; id->type = PORT; id->index = index; + id->min = lilv_port_get(plug, lport, nodes->lv2_minimum); + id->max = lilv_port_get(plug, lport, nodes->lv2_maximum); + id->def = lilv_port_get(plug, lport, nodes->lv2_default); id->is_toggle = lilv_port_has_property(plug, lport, nodes->lv2_toggled); id->is_integer = lilv_port_has_property(plug, lport, nodes->lv2_integer); id->is_enumeration = lilv_port_has_property(plug, lport, nodes->lv2_enumeration); @@ -47,12 +50,12 @@ new_port_control(Jalv* jalv, uint32_t index) lilv_port_get_range(plug, lport, &id->def, &id->min, &id->max); if (lilv_port_has_property(plug, lport, jalv->nodes.lv2_sampleRate)) { /* Adjust range for lv2:sampleRate controls */ - if (lilv_node_is_float(id->min)) { + if (lilv_node_is_float(id->min) || lilv_node_is_int(id->min)) { const float min = lilv_node_as_float(id->min) * jalv->sample_rate; lilv_node_free(id->min); id->min = lilv_new_float(jalv->world, min); } - if (lilv_node_is_float(id->max)) { + if (lilv_node_is_float(id->max) || lilv_node_is_int(id->max)) { const float max = lilv_node_as_float(id->max) * jalv->sample_rate; lilv_node_free(id->max); id->max = lilv_new_float(jalv->world, max); diff --git a/src/jalv_gtk.c b/src/jalv_gtk.c index a3f6320..104d7a2 100644 --- a/src/jalv_gtk.c +++ b/src/jalv_gtk.c @@ -30,6 +30,15 @@ typedef struct { GtkSpinButton* spin; GtkWidget* control; } Controller; +static float +get_float(const LilvNode* node, float fallback) +{ + if (lilv_node_is_float(node) || lilv_node_is_int(node)) { + return lilv_node_as_float(node); + } + + return fallback; +} static GtkWidget* new_box(gboolean horizontal, gint spacing) @@ -791,8 +800,8 @@ make_combo(ControlID* record, float value) static Controller* make_log_slider(ControlID* record, float value) { - const float min = lilv_node_is_float(record->min) ? lilv_node_as_float(record->min) : 0.0f; - const float max = lilv_node_is_float(record->max) ? lilv_node_as_float(record->max) : 1.0f; + const float min = get_float(record->min, 0.0f); + const float max = get_float(record->max, 1.0f); const float lmin = logf(min); const float lmax = logf(max); const float ldft = logf(value); @@ -814,8 +823,8 @@ make_log_slider(ControlID* record, float value) static Controller* make_slider(ControlID* record, float value) { - const float min = lilv_node_is_float(record->min) ? lilv_node_as_float(record->min) : 0.0f; - const float max = lilv_node_is_float(record->max) ? lilv_node_as_float(record->max) : 1.0f; + const float min = get_float(record->min, 0.0f); + const float max = get_float(record->max, 1.0f); const double step = record->is_integer ? 1.0 : ((max - min) / 100.0); GtkWidget* scale = new_hscale(min, max, step); GtkWidget* spin = gtk_spin_button_new_with_range(min, max, step); @@ -1009,7 +1018,8 @@ build_control_widget(Jalv* jalv, GtkWidget* window) size_t np = 0; LILV_FOREACH(scale_points, s, sp) { const LilvScalePoint* p = lilv_scale_points_get(sp, s); - if (lilv_node_is_float(lilv_scale_point_get_value(p))) { + if (lilv_node_is_float(lilv_scale_point_get_value(p)) || + lilv_node_is_int(lilv_scale_point_get_value(p))) { control_id->points[np].value = lilv_node_as_float( lilv_scale_point_get_value(p)); control_id->points[np].label = g_strdup( @@ -1068,10 +1078,7 @@ build_control_widget(Jalv* jalv, GtkWidget* window) } else if (record->value_type == jalv->forge.Path) { controller = make_file_chooser(record); } else { - controller = make_controller(record, - (lilv_node_is_float(record->def) - ? lilv_node_as_float(record->def) - : 0.0f)); + controller = make_controller(record, get_float(record->def, 0.0f)); } record->widget = controller; diff --git a/src/jalv_qt.cpp b/src/jalv_qt.cpp index b531f75..114faf2 100644 --- a/src/jalv_qt.cpp +++ b/src/jalv_qt.cpp @@ -429,7 +429,7 @@ Control::Control(PortContainer portContainer, QWidget* parent) LILV_FOREACH(scale_points, s, sp) { const LilvScalePoint* p = lilv_scale_points_get(sp, s); const LilvNode* val = lilv_scale_point_get_value(p); - if (!lilv_node_is_float(val)) { + if (!lilv_node_is_float(val) && !lilv_node_is_int(val)) { continue; } -- cgit v1.2.1