From 9be3da42a71d99ba23db575c6a70c1486b253366 Mon Sep 17 00:00:00 2001 From: Bent Bisballe Nyeng Date: Sun, 21 Apr 2013 21:07:31 +0200 Subject: Fixed accumulating events in the acitve events queue. --- src/drumgizmo.cc | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/src/drumgizmo.cc b/src/drumgizmo.cc index 49ea787..c6259d4 100644 --- a/src/drumgizmo.cc +++ b/src/drumgizmo.cc @@ -252,6 +252,8 @@ bool DrumGizmo::run(size_t pos, sample_t *samples, size_t nsamples) // Read new events // + //DEBUG(engine, "Number of active events: %d\n", activeevents[0].size()); + size_t nev; event_t *evs = ie->run(pos, nsamples, &nev); @@ -315,7 +317,7 @@ bool DrumGizmo::run(size_t pos, sample_t *samples, size_t nsamples) if(af == NULL || !af->isValid()) { //printf("Missing AudioFile.\n"); } else { - DEBUG(drumgizmo, "Adding event %d.\n", evs[e].offset); + //DEBUG(drumgizmo, "Adding event %d.\n", evs[e].offset); Event *evt = new EventSample(ch.num, 1.0, af, i->group(), i); evt->offset = evs[e].offset + pos; activeevents[ch.num].push_back(evt); @@ -427,7 +429,7 @@ void DrumGizmo::getSamples(int ch, int pos, sample_t *s, size_t sz) } - if(evt->t > af->size) removeevent = true; + if(evt->t >= af->size) removeevent = true; } break; } -- cgit v1.2.3