comparison projects/heavy/circularBuffer/MessageQueue.h @ 163:20b52283c7b4 heavy-updated

- added circular buffer pd/heavy example (works but process needs to be killed manually if launched via ssh?)
author chnrx <chris.heinrichs@gmail.com>
date Thu, 12 Nov 2015 15:55:30 +0000
parents
children
comparison
equal deleted inserted replaced
162:c3e8226a5651 163:20b52283c7b4
1 /**
2 * Copyright (c) 2014, 2015, Enzien Audio Ltd.
3 *
4 * Permission to use, copy, modify, and/or distribute this software for any
5 * purpose with or without fee is hereby granted, provided that the above
6 * copyright notice and this permission notice appear in all copies.
7 *
8 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
9 * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
10 * AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
11 * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
12 * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
13 * OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
14 * PERFORMANCE OF THIS SOFTWARE.
15 */
16
17 #ifndef _MESSAGE_QUEUE_H_
18 #define _MESSAGE_QUEUE_H_
19
20 #include "HvMessage.h"
21 #include "MessagePool.h"
22
23 struct HvBase;
24
25 typedef struct MessageNode {
26 struct MessageNode *prev; // doubly linked list
27 struct MessageNode *next;
28 HvMessage *m;
29 void (*sendMessage)(struct HvBase *, int, const HvMessage *);
30 int let;
31 } MessageNode;
32
33 /** A doubly linked list containing scheduled messages. */
34 typedef struct MessageQueue {
35 MessageNode *head; // the head of the queue
36 MessageNode *tail; // the tail of the queue
37 MessageNode *pool; // the head of the reserve pool
38 MessagePool mp;
39 } MessageQueue;
40
41 hv_size_t mq_init(MessageQueue *q);
42
43 void mq_initWithPoolSize(MessageQueue *q, hv_size_t poolSizeKB);
44
45 void mq_free(MessageQueue *q);
46
47 int mq_size(MessageQueue *q);
48
49 static inline HvMessage *mq_node_getMessage(MessageNode *n) {
50 return n->m;
51 }
52
53 static inline int mq_node_getLet(MessageNode *n) {
54 return n->let;
55 }
56
57 static inline bool mq_hasMessage(MessageQueue *q) {
58 return (q->head != NULL);
59 }
60
61 // true if there is a message and it occurs before (<) timestamp
62 static inline bool mq_hasMessageBefore(MessageQueue *const q, const hv_uint32_t timestamp) {
63 return mq_hasMessage(q) && (msg_getTimestamp(mq_node_getMessage(q->head)) < timestamp);
64 }
65
66 static inline MessageNode *mq_peek(MessageQueue *q) {
67 return q->head;
68 }
69
70 /** Appends the message to the end of the queue. */
71 HvMessage *mq_addMessage(MessageQueue *q, const HvMessage *m, int let,
72 void (*sendMessage)(struct HvBase *, int, const HvMessage *));
73
74 /** Insert in ascending order the message acccording to its timestamp. */
75 HvMessage *mq_addMessageByTimestamp(MessageQueue *q, HvMessage *m, int let,
76 void (*sendMessage)(struct HvBase *, int, const HvMessage *));
77
78 /** Pop the message at the head of the queue (and free its memory). */
79 void mq_pop(MessageQueue *q);
80
81 /** Remove a message from the queue (and free its memory) */
82 void mq_removeMessage(MessageQueue *q, HvMessage *m,
83 void (*sendMessage)(struct HvBase *, int, const HvMessage *));
84
85 /** Clears (and frees) all messages in the queue. */
86 void mq_clear(MessageQueue *q);
87
88 /** Removes all messages occuring at or after the given timestamp. */
89 void mq_clearAfter(MessageQueue *q, const double timestamp);
90
91 #endif // _MESSAGE_QUEUE_H_