aboutsummaryrefslogtreecommitdiffstats
path: root/src/control.c
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2015-12-31 14:10:55 -0500
committerDavid Robillard <d@drobilla.net>2015-12-31 14:10:55 -0500
commit0bb0b753c62c900027def66288489442cb69f336 (patch)
tree40f19d3d2f1748ca7130749b93c9ac4f697dfa55 /src/control.c
parent5a7c238a33400b5572a587f7290ca7027b207f70 (diff)
downloadjalv-0bb0b753c62c900027def66288489442cb69f336.tar.gz
jalv-0bb0b753c62c900027def66288489442cb69f336.tar.bz2
jalv-0bb0b753c62c900027def66288489442cb69f336.zip
Fix controls when range is given with integers
Diffstat (limited to 'src/control.c')
-rw-r--r--src/control.c7
1 files changed, 5 insertions, 2 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);