diff options
Diffstat (limited to 'plugins')
-rw-r--r-- | plugins/eg-metro.lv2/metro.c | 52 |
1 files changed, 11 insertions, 41 deletions
diff --git a/plugins/eg-metro.lv2/metro.c b/plugins/eg-metro.lv2/metro.c index a7231d2..cf6bccf 100644 --- a/plugins/eg-metro.lv2/metro.c +++ b/plugins/eg-metro.lv2/metro.c @@ -22,6 +22,7 @@ #include "lv2/log/log.h" #include "lv2/log/logger.h" #include "lv2/time/time.h" +#include "lv2/urid/sid.h" #include "lv2/urid/urid.h" #include <math.h> @@ -37,19 +38,6 @@ #define EG_METRO_URI "http://lv2plug.in/plugins/eg-metro" -typedef struct { - LV2_URID atom_Blank; - LV2_URID atom_Float; - LV2_URID atom_Object; - LV2_URID atom_Path; - LV2_URID atom_Resource; - LV2_URID atom_Sequence; - LV2_URID time_Position; - LV2_URID time_barBeat; - LV2_URID time_beatsPerMinute; - LV2_URID time_speed; -} MetroURIs; - static const double attack_s = 0.005; static const double decay_s = 0.075; @@ -79,7 +67,6 @@ typedef enum { typedef struct { LV2_URID_Map* map; // URID map feature LV2_Log_Logger logger; // Logger API - MetroURIs uris; // Cache of mapped URIDs struct { LV2_Atom_Sequence* control; @@ -167,20 +154,6 @@ instantiate(const LV2_Descriptor* descriptor, return NULL; } - // Map URIS - MetroURIs* const uris = &self->uris; - LV2_URID_Map* const map = self->map; - uris->atom_Blank = map->map(map->handle, LV2_ATOM__Blank); - uris->atom_Float = map->map(map->handle, LV2_ATOM__Float); - uris->atom_Object = map->map(map->handle, LV2_ATOM__Object); - uris->atom_Path = map->map(map->handle, LV2_ATOM__Path); - uris->atom_Resource = map->map(map->handle, LV2_ATOM__Resource); - uris->atom_Sequence = map->map(map->handle, LV2_ATOM__Sequence); - uris->time_Position = map->map(map->handle, LV2_TIME__Position); - uris->time_barBeat = map->map(map->handle, LV2_TIME__barBeat); - uris->time_beatsPerMinute = map->map(map->handle, LV2_TIME__beatsPerMinute); - uris->time_speed = map->map(map->handle, LV2_TIME__speed); - // Initialise instance fields self->rate = rate; self->bpm = 120.0f; @@ -263,24 +236,22 @@ play(Metro* self, uint32_t begin, uint32_t end) static void update_position(Metro* self, const LV2_Atom_Object* obj) { - const MetroURIs* uris = &self->uris; - // Received new transport position/speed LV2_Atom *beat = NULL, *bpm = NULL, *speed = NULL; lv2_atom_object_get(obj, - uris->time_barBeat, &beat, - uris->time_beatsPerMinute, &bpm, - uris->time_speed, &speed, + LV2_URID_TIME_barBeat, &beat, + LV2_URID_TIME_beatsPerMinute, &bpm, + LV2_URID_TIME_speed, &speed, NULL); - if (bpm && bpm->type == uris->atom_Float) { + if (bpm && bpm->type == LV2_URID_ATOM_Float) { // Tempo changed, update BPM self->bpm = ((LV2_Atom_Float*)bpm)->body; } - if (speed && speed->type == uris->atom_Float) { + if (speed && speed->type == LV2_URID_ATOM_Float) { // Speed changed, e.g. 0 (stop) to 1 (play) self->speed = ((LV2_Atom_Float*)speed)->body; } - if (beat && beat->type == uris->atom_Float) { + if (beat && beat->type == LV2_URID_ATOM_Float) { // Received a beat position, synchronise // This hard sync may cause clicks, a real plugin would be more graceful const float frames_per_beat = 60.0f / self->bpm * self->rate; @@ -300,8 +271,7 @@ update_position(Metro* self, const LV2_Atom_Object* obj) static void run(LV2_Handle instance, uint32_t sample_count) { - Metro* self = (Metro*)instance; - const MetroURIs* uris = &self->uris; + Metro* self = (Metro*)instance; // Work forwards in time frame by frame, handling events as we go const LV2_Atom_Sequence* in = self->ports.control; @@ -315,10 +285,10 @@ run(LV2_Handle instance, uint32_t sample_count) // Check if this event is an Object // (or deprecated Blank to tolerate old hosts) - if (ev->body.type == uris->atom_Object || - ev->body.type == uris->atom_Blank) { + if (ev->body.type == LV2_URID_ATOM_Object || + ev->body.type == LV2_URID_ATOM_Blank) { const LV2_Atom_Object* obj = (const LV2_Atom_Object*)&ev->body; - if (obj->body.otype == uris->time_Position) { + if (obj->body.otype == LV2_URID_TIME_Position) { // Received position information, update update_position(self, obj); } |