diff options
author | David Robillard <d@drobilla.net> | 2012-09-16 16:59:35 +0000 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2012-09-16 16:59:35 +0000 |
commit | d38365283adef399f2fc366f491a03b5fc3cf560 (patch) | |
tree | df4c65825b6e4839fd48a08d09098bb88d0e90da /src/fmod.c | |
parent | 3ae8043771d8b4a11492b74bc4c0a79a7487d0a5 (diff) | |
download | blop.lv2-d38365283adef399f2fc366f491a03b5fc3cf560.tar.gz blop.lv2-d38365283adef399f2fc366f491a03b5fc3cf560.tar.bz2 blop.lv2-d38365283adef399f2fc366f491a03b5fc3cf560.zip |
Support latest options and morph extensions.
git-svn-id: http://svn.drobilla.net/lad/trunk/plugins/blop.lv2@4776 a436a847-0d15-0410-975c-d299462d15a1
Diffstat (limited to 'src/fmod.c')
-rw-r--r-- | src/fmod.c | 92 |
1 files changed, 53 insertions, 39 deletions
@@ -19,6 +19,7 @@ #include <stdlib.h> #include "lv2/lv2plug.in/ns/ext/morph/morph.h" +#include "lv2/lv2plug.in/ns/ext/options/options.h" #include "lv2/lv2plug.in/ns/lv2core/lv2.h" #include "math_func.h" #include "uris.h" @@ -63,49 +64,62 @@ connect_port(LV2_Handle instance, } } -static LV2_Morph_Status -morph_port(LV2_Handle instance, - uint32_t port, - LV2_URID type, - const LV2_Morph_Property*const* properties) +static uint32_t +options_set(LV2_Handle instance, + const LV2_Options_Option* options) { - Fmod* plugin = (Fmod*)instance; - - if (type != plugin->uris.lv2_ControlPort && - type != plugin->uris.lv2_CVPort) { - return LV2_MORPH_ERR_BAD_TYPE; + Fmod* plugin = (Fmod*)instance; + uint32_t ret = 0; + for (const LV2_Options_Option* o = options; o->key; ++o) { + if (o->context != LV2_OPTIONS_PORT) { + ret |= LV2_OPTIONS_ERR_BAD_SUBJECT; + } else if (o->key != plugin->uris.morph_currentType) { + ret |= LV2_OPTIONS_ERR_BAD_KEY; + } else if (o->type != plugin->uris.atom_URID) { + ret |= LV2_OPTIONS_ERR_BAD_VALUE; + } else { + LV2_URID port_type = *(const LV2_URID*)(o->value); + if (port_type != plugin->uris.lv2_ControlPort && + port_type != plugin->uris.lv2_CVPort) { + ret |= LV2_OPTIONS_ERR_BAD_VALUE; + continue; + } + + switch (o->subject) { + case FMOD_FREQUENCY: + plugin->frequency_is_cv = (port_type == plugin->uris.lv2_CVPort); + break; + case FMOD_MODULATOR: + plugin->modulator_is_cv = (port_type == plugin->uris.lv2_CVPort); + break; + default: + ret |= LV2_OPTIONS_ERR_BAD_SUBJECT; + } + } } - - switch (port) { - case FMOD_FREQUENCY: - plugin->frequency_is_cv = (type == plugin->uris.lv2_CVPort); - break; - case FMOD_MODULATOR: - plugin->modulator_is_cv = (type == plugin->uris.lv2_CVPort); - break; - default: - return LV2_MORPH_ERR_BAD_PORT; - } - - plugin->output_is_cv = plugin->frequency_is_cv || plugin->modulator_is_cv; - return LV2_MORPH_SUCCESS; + return ret; } -static LV2_URID -port_type(LV2_Handle instance, - uint32_t port, - LV2_Morph_Property*const* properties) +static uint32_t +options_get(LV2_Handle instance, + LV2_Options_Option* options) { const Fmod* plugin = (const Fmod*)instance; - - switch (port) { - case FMOD_OUTPUT: - return (plugin->output_is_cv - ? plugin->uris.lv2_CVPort - : plugin->uris.lv2_ControlPort); - default: - return 0; + uint32_t ret = 0; + for (LV2_Options_Option* o = options; o->key; ++o) { + if (o->context != LV2_OPTIONS_PORT || o->subject != FMOD_OUTPUT) { + ret |= LV2_OPTIONS_ERR_BAD_SUBJECT; + } else if (o->key != plugin->uris.morph_currentType) { + ret |= LV2_OPTIONS_ERR_BAD_KEY; + } else { + o->size = sizeof(LV2_URID); + o->type = plugin->uris.atom_URID; + o->value = (plugin->output_is_cv + ? &plugin->uris.lv2_CVPort + : &plugin->uris.lv2_ControlPort); + } } + return ret; } static LV2_Handle @@ -157,9 +171,9 @@ run(LV2_Handle instance, static const void* extension_data(const char* uri) { - static const LV2_Morph_Interface morph = { morph_port, port_type }; - if (!strcmp(uri, LV2_MORPH__interface)) { - return &morph; + static const LV2_Options_Interface options = { options_get, options_set }; + if (!strcmp(uri, LV2_OPTIONS__interface)) { + return &options; } return NULL; } |