annotate projects/heavy/circularBuffer/Heavy.c @ 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
rev   line source
chris@163 1 /**
chris@163 2 * Copyright (c) 2014, 2015, Enzien Audio Ltd.
chris@163 3 *
chris@163 4 * Permission to use, copy, modify, and/or distribute this software for any
chris@163 5 * purpose with or without fee is hereby granted, provided that the above
chris@163 6 * copyright notice and this permission notice appear in all copies.
chris@163 7 *
chris@163 8 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
chris@163 9 * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
chris@163 10 * AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
chris@163 11 * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
chris@163 12 * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
chris@163 13 * OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
chris@163 14 * PERFORMANCE OF THIS SOFTWARE.
chris@163 15 */
chris@163 16
chris@163 17 #include "HvBase.h"
chris@163 18 #include "HvTable.h"
chris@163 19
chris@163 20 #if !HV_WIN
chris@163 21 #pragma mark - Heavy Table
chris@163 22 #endif
chris@163 23
chris@163 24 int hv_table_resize(HvTable *o, hv_uint32_t newLength) {
chris@163 25 return hTable_resize(o, newLength);
chris@163 26 }
chris@163 27
chris@163 28 float *hv_table_getBuffer(HvTable *o) {
chris@163 29 return hTable_getBuffer(o);
chris@163 30 }
chris@163 31
chris@163 32 hv_size_t hv_table_getLength(HvTable *o) {
chris@163 33 return hTable_getLength(o);
chris@163 34 }
chris@163 35
chris@163 36
chris@163 37
chris@163 38 #if !HV_WIN
chris@163 39 #pragma mark - Heavy Message
chris@163 40 #endif
chris@163 41
chris@163 42 hv_size_t hv_msg_getByteSize (hv_uint32_t numElements) {
chris@163 43 return msg_getByteSize(numElements);
chris@163 44 }
chris@163 45
chris@163 46 void hv_msg_init(HvMessage *m, int numElements, hv_uint32_t timestamp) {
chris@163 47 msg_init(m, numElements, timestamp);
chris@163 48 }
chris@163 49
chris@163 50 hv_size_t hv_msg_getNumElements(const HvMessage *const m) {
chris@163 51 return msg_getNumElements(m);
chris@163 52 }
chris@163 53
chris@163 54 double hv_msg_getTimestamp(const HvMessage *const m) {
chris@163 55 return msg_getTimestamp(m);
chris@163 56 }
chris@163 57
chris@163 58 void hv_msg_setTimestamp(HvMessage *m, hv_uint32_t timestamp) {
chris@163 59 msg_setTimestamp(m, timestamp);
chris@163 60 }
chris@163 61
chris@163 62 bool hv_msg_isBang(const HvMessage *const m, int i) {
chris@163 63 return msg_isBang(m,i);
chris@163 64 }
chris@163 65
chris@163 66 void hv_msg_setBang(HvMessage *m, int i) {
chris@163 67 msg_setBang(m,i);
chris@163 68 }
chris@163 69
chris@163 70 bool hv_msg_isFloat(const HvMessage *const m, int i) {
chris@163 71 return msg_isFloat(m, i);
chris@163 72 }
chris@163 73
chris@163 74 float hv_msg_getFloat(const HvMessage *const m, int i) {
chris@163 75 return msg_getFloat(m,i);
chris@163 76 }
chris@163 77
chris@163 78 void hv_msg_setFloat(HvMessage *m, int i, float f) {
chris@163 79 msg_setFloat(m,i,f);
chris@163 80 }
chris@163 81
chris@163 82 bool hv_msg_isSymbol(const HvMessage *const m, int i) {
chris@163 83 return msg_isSymbol(m,i);
chris@163 84 }
chris@163 85
chris@163 86 char *hv_msg_getSymbol(const HvMessage *const m, int i) {
chris@163 87 return msg_getSymbol(m,i);
chris@163 88 }
chris@163 89
chris@163 90 void hv_msg_setSymbol(HvMessage *m, int i, char *s) {
chris@163 91 msg_setSymbol(m,i,s);
chris@163 92 }
chris@163 93
chris@163 94 bool hv_msg_isHash(const HvMessage *const m, int i) {
chris@163 95 return msg_isHash(m, i);
chris@163 96 }
chris@163 97
chris@163 98 unsigned int hv_msg_getHash(const HvMessage *const m, int i) {
chris@163 99 return msg_getHash(m, i);
chris@163 100 }
chris@163 101
chris@163 102 bool hv_msg_hasFormat(const HvMessage *const m, const char *fmt) {
chris@163 103 return msg_hasFormat(m, fmt);
chris@163 104 }
chris@163 105
chris@163 106 char *hv_msg_toString(const HvMessage *const m) {
chris@163 107 return msg_toString(m);
chris@163 108 }
chris@163 109
chris@163 110 HvMessage *hv_msg_copy(HvMessage *m) {
chris@163 111 return msg_copy(m);
chris@163 112 }
chris@163 113
chris@163 114 void hv_msg_free(HvMessage *m) {
chris@163 115 msg_free(m);
chris@163 116 }
chris@163 117
chris@163 118
chris@163 119
chris@163 120 #if !HV_WIN
chris@163 121 #pragma mark - Heavy Common
chris@163 122 #endif
chris@163 123
chris@163 124 double hv_getSampleRate(HvBase *c) {
chris@163 125 return ctx_getSampleRate(c);
chris@163 126 }
chris@163 127
chris@163 128 int hv_getNumInputChannels(HvBase *c) {
chris@163 129 return ctx_getNumInputChannels(c);
chris@163 130 }
chris@163 131
chris@163 132 int hv_getNumOutputChannels(HvBase *c) {
chris@163 133 return ctx_getNumOutputChannels(c);
chris@163 134 }
chris@163 135
chris@163 136 const char *hv_getName(HvBase *c) {
chris@163 137 return ctx_getName(c);
chris@163 138 }
chris@163 139
chris@163 140 void hv_setPrintHook(HvBase *c, void (*f)(double, const char *, const char *, void *)) {
chris@163 141 ctx_setPrintHook(c, f);
chris@163 142 }
chris@163 143
chris@163 144 void hv_setSendHook(HvBase *c, void (*f)(double, const char *, const HvMessage *const, void *)) {
chris@163 145 ctx_setSendHook(c, f);
chris@163 146 }
chris@163 147
chris@163 148 void hv_vscheduleMessageForReceiver(HvBase *c, const char *receiverName, const double delayMs, const char *format, ...) {
chris@163 149 va_list ap;
chris@163 150 va_start(ap, format);
chris@163 151
chris@163 152 const int numElem = (int) hv_strlen(format);
chris@163 153 HvMessage *m = HV_MESSAGE_ON_STACK(numElem);
chris@163 154 msg_init(m, numElem, c->blockStartTimestamp + (hv_uint32_t) (hv_max_d(0.0, delayMs)*ctx_getSampleRate(c)/1000.0));
chris@163 155 for (int i = 0; i < numElem; i++) {
chris@163 156 switch (format[i]) {
chris@163 157 case 'b': msg_setBang(m,i); break;
chris@163 158 case 'f': msg_setFloat(m, i, (float) va_arg(ap, double)); break;
chris@163 159 case 's': msg_setSymbol(m, i, (char *) va_arg(ap, char *)); break;
chris@163 160 default: break;
chris@163 161 }
chris@163 162 }
chris@163 163 ctx_scheduleMessageForReceiver(c, receiverName, m);
chris@163 164
chris@163 165 va_end(ap);
chris@163 166 }
chris@163 167
chris@163 168 void hv_scheduleMessageForReceiver(HvBase *c, const char *receiverName, double delayMs, HvMessage *m) {
chris@163 169 hv_assert(delayMs >= 0.0);
chris@163 170 msg_setTimestamp(m, c->blockStartTimestamp + (hv_uint32_t) (delayMs*ctx_getSampleRate(c)/1000.0));
chris@163 171 ctx_scheduleMessageForReceiver(c, receiverName, m);
chris@163 172 }
chris@163 173
chris@163 174 HvTable *hv_getTableForName(HvBase *c, const char *tableName) {
chris@163 175 return ctx_getTableForName(c, tableName);
chris@163 176 }
chris@163 177
chris@163 178 void hv_cancelMessage(HvBase *c, HvMessage *m) {
chris@163 179 ctx_cancelMessage(c, m, NULL);
chris@163 180 }
chris@163 181
chris@163 182 double hv_getCurrentTime(HvBase *c) {
chris@163 183 return ((double) c->blockStartTimestamp)/c->sampleRate;
chris@163 184 }
chris@163 185
chris@163 186 void *hv_getUserData(HvBase *c) {
chris@163 187 return ctx_getUserData(c);
chris@163 188 }
chris@163 189
chris@163 190 void hv_setUserData(HvBase *c, void *userData) {
chris@163 191 ctx_setUserData(c, userData);
chris@163 192 }
chris@163 193
chris@163 194 void hv_setBasePath(HvBase *c, const char *basePath) {
chris@163 195 ctx_setBasePath(c, basePath);
chris@163 196 }