diff options
author | Jonas Suhr Christensen <jsc@umbraculum.org> | 2014-03-07 04:25:52 +0100 |
---|---|---|
committer | Jonas Suhr Christensen <jsc@umbraculum.org> | 2014-03-07 04:25:52 +0100 |
commit | 74b8a63270c1c0b01b33e861c26b1e2a59eeb82b (patch) | |
tree | 799aaec0d88e50172e17b61af37ca391a83d59d3 /lv2 | |
parent | 75702e36ddb30ca2924cb42dc0b44ddfbdac36e5 (diff) |
Changed midi handling from event extension to atom extension.
Diffstat (limited to 'lv2')
-rw-r--r-- | lv2/drumgizmo.ttl | 11 | ||||
-rw-r--r-- | lv2/input_lv2.cc | 17 | ||||
-rw-r--r-- | lv2/input_lv2.h | 4 | ||||
-rw-r--r-- | lv2/lv2.cc | 5 |
4 files changed, 20 insertions, 17 deletions
diff --git a/lv2/drumgizmo.ttl b/lv2/drumgizmo.ttl index c72b34a..23345f3 100644 --- a/lv2/drumgizmo.ttl +++ b/lv2/drumgizmo.ttl @@ -16,7 +16,7 @@ @prefix doap: <http://usefulinc.com/ns/doap#> . @prefix foaf: <http://xmlns.com/foaf/0.1/> . @prefix lv2: <http://lv2plug.in/ns/lv2core#> . -@prefix lv2ev: <http://lv2plug.in/ns/ext/event#> . +@prefix atom: <http://lv2plug.in/ns/ext/atom#> . @prefix uiext: <http://lv2plug.in/ns/extensions/ui#> . @prefix state: <http://lv2plug.in/ns/ext/state#> . @@ -38,10 +38,11 @@ lv2:optionalFeature <http://lv2plug.in/ns/ext/event> ; lv2:extensionData state:interface ; lv2:port [ - a lv2:InputPort , - lv2ev:EventPort ; - lv2ev:supportsEvent <http://lv2plug.in/ns/ext/midi#MidiEvent> ; - lv2:index 0 ; + a atom:AtomPort , + lv2:InputPort; + atom:bufferType atom:Sequence ; + atom:supports <http://lv2plug.in/ns/ext/midi#MidiEvent> ; + lv2:index 0 ; lv2:symbol "control" ; lv2:name "Control" ] , [ diff --git a/lv2/input_lv2.cc b/lv2/input_lv2.cc index 0d97760..d995e75 100644 --- a/lv2/input_lv2.cc +++ b/lv2/input_lv2.cc @@ -26,6 +26,8 @@ */ #include "input_lv2.h" +#include "lv2/lv2plug.in/ns/ext/atom/util.h" + #include <midimapparser.h> #include <hugin.hpp> @@ -70,14 +72,12 @@ event_t *InputLV2::run(size_t pos, size_t len, size_t *nevents) list = (event_t *)malloc(sizeof(event_t) * 1000); listsize = 0; - LV2_Event_Iterator iterator; - for(lv2_event_begin(&iterator, eventPort); - lv2_event_is_valid(&iterator); - lv2_event_increment(&iterator)) { - - LV2_Event* ev = lv2_event_get(&iterator, NULL); + LV2_Atom_Event* ev = lv2_atom_sequence_begin(&eventPort->body); - uint8_t* const data = (uint8_t* const)(ev + 1); + while(!lv2_atom_sequence_is_end(&eventPort->body, + eventPort->atom.size, + ev)) { + uint8_t* const data = (uint8_t*)(ev+1); if ((data[0] & 0xF0) == 0x80) { // note off int key = data[1]; @@ -96,7 +96,7 @@ event_t *InputLV2::run(size_t pos, size_t len, size_t *nevents) list[listsize].type = TYPE_ONSET; list[listsize].instrument = i; list[listsize].velocity = velocity / 127.0; - list[listsize].offset = ev->frames; + list[listsize].offset = ev->time.frames; listsize++; } /* @@ -105,6 +105,7 @@ event_t *InputLV2::run(size_t pos, size_t len, size_t *nevents) plugin->play = true; */ } + ev = lv2_atom_sequence_next(ev); } *nevents = listsize; diff --git a/lv2/input_lv2.h b/lv2/input_lv2.h index aa39a23..32e2fd8 100644 --- a/lv2/input_lv2.h +++ b/lv2/input_lv2.h @@ -29,7 +29,7 @@ #include <audioinputenginemidi.h> -#include <lv2/lv2plug.in/ns/ext/event/event-helpers.h> +#include <lv2/lv2plug.in/ns/ext/atom/atom.h> class InputLV2 : public AudioInputEngineMidi { public: @@ -47,7 +47,7 @@ public: event_t *run(size_t pos, size_t len, size_t *nevents); void post(); - LV2_Event_Buffer *eventPort; + LV2_Atom_Sequence *eventPort; private: Instruments *instruments; @@ -27,6 +27,7 @@ #include <lv2/lv2plug.in/ns/lv2core/lv2.h> #include <stdlib.h> +#include <string.h> #include "lv2_gui.h" @@ -34,7 +35,7 @@ #include <hugin.hpp> -#define MIDI_EVENT_URI "http://lv2plug.in/ns/ext/midi#MidiEvent" +#include <lv2/lv2plug.in/ns/ext/atom/atom.h> #define NS_ATOM "http://lv2plug.in/ns/ext/atom#" #define NS_DG "http://drumgizmo.org/lv2/atom#" @@ -310,7 +311,7 @@ void connect_port(LV2_Handle instance, DGLV2 *dglv2 = (DGLV2 *)instance; if(port == 0) {// MIDI in - dglv2->in->eventPort = (LV2_Event_Buffer*)data_location; + dglv2->in->eventPort = (LV2_Atom_Sequence*)data_location; } else {// Audio Port if(port - 1 < NUM_OUTPUTS) { dglv2->out->outputPorts[port - 1].samples = (sample_t*)data_location; |