-Change: Replace custom ringbuffer code with JACK's ringbuffer interface, as written by people who know better than me :)

git-svn-id: http://svn.fuzzle.org/mloop/trunk@34 ba049829-c6ef-42ef-81ac-908dd8d2e907
master
petern 2009-07-24 14:25:44 +00:00
parent 437d6c2e2b
commit 236f8fadce
2 changed files with 19 additions and 64 deletions

View File

@ -4,27 +4,28 @@
#include <jack/midiport.h>
#include "ringbuffer.h"
bool RingBuffer::PushEvent(jack_midi_event_t &ev)
bool RingBuffer::PushEvent(const jack_midi_event_t &ev)
{
if (Free() <= sizeof ev.time + sizeof ev.size + ev.size) return false;
size_t f = jack_ringbuffer_write_space(m_buffer);
if (f <= sizeof ev.time + sizeof ev.size + ev.size) return false;
Write((uint8_t *)&ev.time, sizeof ev.time);
Write((uint8_t *)&ev.size, sizeof ev.size);
Write((uint8_t* )ev.buffer, ev.size);
jack_ringbuffer_write(m_buffer, (const char *)&ev.size, sizeof ev.size);
jack_ringbuffer_write(m_buffer, (const char *)&ev.time, sizeof ev.time);
jack_ringbuffer_write(m_buffer, (const char *)ev.buffer, ev.size);
return true;
}
bool RingBuffer::PopEvent(jack_midi_event_t &ev)
{
if (Size() >= sizeof ev.time + sizeof ev.size) {
uint8_t *peek;
peek = Peek((uint8_t *)&ev.time, sizeof ev.time, m_read);
peek = Peek((uint8_t *)&ev.size, sizeof ev.size, peek);
if (Size() >= sizeof ev.time + sizeof ev.size + ev.size) {
size_t f = jack_ringbuffer_read_space(m_buffer);
if (f >= sizeof ev.time + sizeof ev.size) {
jack_ringbuffer_peek(m_buffer, (char *)&ev.size, sizeof ev.size);
if (f >= sizeof ev.time + sizeof ev.size + ev.size) {
ev.buffer = (jack_midi_data_t *)malloc(ev.size);
m_read = peek;
Read((uint8_t *)ev.buffer, ev.size);
jack_ringbuffer_read(m_buffer, (char *)&ev.size, sizeof ev.size);
jack_ringbuffer_read(m_buffer, (char *)&ev.time, sizeof ev.time);
jack_ringbuffer_read(m_buffer, (char *)ev.buffer, ev.size);
return true;
}
}

View File

@ -3,70 +3,24 @@
#ifndef RINGBUFFER_H
#define RINGBUFFER_H
#include <jack/ringbuffer.h>
class RingBuffer {
private:
uint8_t *m_buffer;
uint8_t *m_end;
uint8_t *m_write;
uint8_t *m_read;
jack_ringbuffer_t *m_buffer;
public:
RingBuffer(size_t length)
{
m_buffer = (uint8_t *)malloc(length);
m_end = m_buffer + length;
m_write = m_buffer;
m_read = m_buffer;
m_buffer = jack_ringbuffer_create(length);
}
~RingBuffer()
{
free(m_buffer);
jack_ringbuffer_free(m_buffer);
}
void Write(const uint8_t *buffer, size_t length)
{
while (length--) {
if (m_write == m_end) m_write = m_buffer;
*m_write++ = *buffer++;
}
}
void Read(uint8_t *buffer, size_t length)
{
while (length--) {
if (m_read == m_end) m_read = m_buffer;
*buffer++ = *m_read++;
}
}
uint8_t *Peek(uint8_t *buffer, size_t length, uint8_t *peek)
{
while (length--) {
if (peek == m_end) peek = m_buffer;
*buffer++ = *peek++;
}
return peek;
}
size_t Size() const
{
if (m_write >= m_read) return m_write - m_read;
return (m_end - m_read) + (m_write - m_buffer);
}
size_t Free() const
{
return (m_end - m_buffer) - Size();
}
void Reset()
{
m_write = m_buffer;
m_read = m_buffer;
}
bool PushEvent(jack_midi_event_t &event);
bool PushEvent(const jack_midi_event_t &event);
bool PopEvent(jack_midi_event_t &event);
};