|
- /*
- Copyright (C) 2010 Devin Anderson
-
- This program is free software; you can redistribute it and/or modify
- it under the terms of the GNU Lesser General Public License as published by
- the Free Software Foundation; either version 2.1 of the License, or
- (at your option) any later version.
-
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU Lesser General Public License for more details.
-
- You should have received a copy of the GNU Lesser General Public License
- along with this program; if not, write to the Free Software
- Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
-
- */
-
- #ifndef __JackMidiAsyncQueue__
- #define __JackMidiAsyncQueue__
-
- #include "JackMidiPort.h"
- #include "JackMidiReadQueue.h"
- #include "JackMidiWriteQueue.h"
- #include "ringbuffer.h"
-
- namespace Jack {
-
- /**
- * This is a MIDI message queue designed to allow one thread to pass MIDI
- * messages to another thread (though it can also be used to buffer events
- * internally). This is especially useful if the MIDI API you're
- * attempting to interface with doesn't provide the ability to schedule
- * MIDI events ahead of time and/or has blocking send/receive calls, as it
- * allows a separate thread to handle input/output while the JACK process
- * thread copies events from a MIDI buffer to this queue, or vice versa.
- */
-
- class SERVER_EXPORT JackMidiAsyncQueue:
- public JackMidiReadQueue, public JackMidiWriteQueue {
-
- private:
-
- static const size_t INFO_SIZE =
- sizeof(jack_nframes_t) + sizeof(size_t);
-
- jack_ringbuffer_t *byte_ring;
- jack_midi_data_t *data_buffer;
- jack_midi_event_t dequeue_event;
- jack_ringbuffer_t *info_ring;
- size_t max_bytes;
-
- public:
-
- using JackMidiWriteQueue::EnqueueEvent;
-
- /**
- * Creates a new asynchronous MIDI message queue. The queue can store
- * up to `max_messages` MIDI messages and up to `max_bytes` of MIDI
- * data before it starts rejecting messages.
- */
-
- JackMidiAsyncQueue(size_t max_bytes=4096, size_t max_messages=1024);
-
- virtual
- ~JackMidiAsyncQueue();
-
- /**
- * Dequeues and returns a MIDI event. Returns '0' if there are no MIDI
- * events available. This method may be overridden.
- */
-
- virtual jack_midi_event_t *
- DequeueEvent();
-
- /**
- * Enqueues the MIDI event specified by the arguments. The return
- * value indicates whether or not the event was successfully enqueued.
- * This method may be overridden.
- */
-
- virtual EnqueueResult
- EnqueueEvent(jack_nframes_t time, size_t size,
- jack_midi_data_t *buffer);
-
- /**
- * Returns the maximum size event that can be enqueued right *now*.
- */
-
- size_t
- GetAvailableSpace();
-
- };
-
- }
-
- #endif
|