|
- /*
- 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 __JackMidiAsyncWaitQueue__
- #define __JackMidiAsyncWaitQueue__
-
- #include "JackMidiAsyncQueue.h"
-
- namespace Jack {
-
- /**
- * This is an asynchronous wait queue that allows a thread to wait for a
- * message, either indefinitely or for a specified time. This is one
- * example of a way that the `JackMidiAsyncQueue` class can be extended so
- * that process threads can interact with non-process threads to send MIDI
- * events.
- *
- * XXX: As of right now, this code hasn't been tested. Also, note the
- * warning in the JackMidiAsyncWaitQueue.cpp about semaphore wait
- * resolution.
- */
-
- class SERVER_EXPORT JackMidiAsyncWaitQueue: public JackMidiAsyncQueue {
-
- private:
-
- JackSynchro semaphore;
-
- public:
-
- using JackMidiAsyncQueue::EnqueueEvent;
-
- /**
- * Creates a new asynchronous MIDI wait 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.
- */
-
- JackMidiAsyncWaitQueue(size_t max_bytes=4096,
- size_t max_messages=1024);
-
- ~JackMidiAsyncWaitQueue();
-
- /**
- * Dequeues and returns a MIDI event. Returns '0' if there are no MIDI
- * events available right now.
- */
-
- jack_midi_event_t *
- DequeueEvent();
-
- /**
- * Waits a specified time for a MIDI event to be available, or
- * indefinitely if the time is negative. Returns the MIDI event, or
- * '0' if time runs out and no MIDI event is available.
- */
-
- jack_midi_event_t *
- DequeueEvent(long usecs);
-
- /**
- * Waits until the specified frame for a MIDI event to be available.
- * Returns the MIDI event, or '0' if time runs out and no MIDI event is
- * available.
- */
-
- jack_midi_event_t *
- DequeueEvent(jack_nframes_t frame);
-
- /**
- * Enqueues the MIDI event specified by the arguments. The return
- * value indicates whether or not the event was successfully enqueued.
- */
-
- EnqueueResult
- EnqueueEvent(jack_nframes_t time, size_t size,
- jack_midi_data_t *buffer);
-
- };
-
- }
-
- #endif
|