aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/putget~.h133
1 files changed, 133 insertions, 0 deletions
diff --git a/src/putget~.h b/src/putget~.h
new file mode 100644
index 0000000..e585791
--- /dev/null
+++ b/src/putget~.h
@@ -0,0 +1,133 @@
+#include "m_pd.h"
+
+/*
+ typedef struct _param_inlet2
+{
+ t_object x_obj;
+ t_param *p_owner;
+} t_param_inlet2;
+
+*/
+
+struct putget {
+ t_symbol* name;
+ t_sample a[64];
+ t_sample b[64];
+ t_sample* w;
+ t_sample* r;
+ int writers;
+ //int written;
+ int users;
+ struct putget* next;
+ struct putget* previous;
+ t_clock* clock;
+ int armed;
+};
+
+
+struct putget* PUTGETS;
+
+// This should be triggered by the clock
+static void putget_swap(struct putget* pg) {
+ //post("clock");
+
+ t_sample* temp = pg->r;
+ pg->r = pg->w;
+ pg->w = temp;
+
+ int i;
+ t_sample* samples = pg->w;
+ for (i=0;i<64;i++) {
+ *samples++ = 0;
+
+ }
+
+ pg->armed = 0;
+
+ //if (pg == NULL) post("ouc");
+ //pg->written = 0;
+
+}
+
+static struct putget* putget_register(t_symbol* name, int is_writer) {
+
+ struct putget* new_putget;
+
+ is_writer = is_writer ? 1 : 0;
+
+ struct putget* pg = PUTGETS;
+
+ if ( pg != NULL) {
+
+ // Search for previous putget
+ while( pg ) {
+ if ( pg->name == name) {
+ //#ifdef PARAMDEBUG
+ // post("Found put/get with same name");
+ //#endif
+ pg->writers = pg->writers + is_writer;
+ pg->users = pg->users + 1;
+ return pg;
+ }
+ if ( pg->next == NULL ) break;
+ pg = pg->next;
+ }
+ }
+
+
+ //post("Appending new put/get");
+ // Append new putget
+ new_putget = getbytes(sizeof(*new_putget));
+ new_putget->name = name;
+ new_putget->writers = is_writer;
+ new_putget->users = 1;
+ new_putget->armed = 0;
+
+ new_putget->clock = clock_new(new_putget, (t_method)putget_swap);
+
+ new_putget->r = new_putget->a;
+ new_putget->w = new_putget->b;
+
+ new_putget->previous = pg;
+ if ( pg) {
+ pg->next = new_putget;
+ } else {
+ PUTGETS = new_putget;
+ }
+
+ return new_putget;
+
+}
+
+
+static void putget_unregister(struct putget* pg, int is_writer) {
+
+ //post("Trying to remove %s",pg->name->s_name);
+
+ if ( is_writer) pg->writers = pg->writers - 1;
+ pg->users = pg->users - 1;
+ if ( pg->users <= 0) {
+ //post("Removing last put/get of this name");
+ if (pg->previous) {
+ pg->previous->next = pg->next;
+ if (pg->next) pg->next->previous = pg->previous;
+ } else {
+ PUTGETS = pg->next;
+ if ( pg->next != NULL) pg->next->previous = NULL;
+ }
+ clock_free(pg->clock);
+ freebytes(pg, sizeof *(pg) );
+ }
+}
+
+
+static void putget_arm(struct putget* pg) {
+
+ if (!pg->armed) {
+ pg->armed = 1;
+ clock_delay(pg->clock, 0);
+ }
+
+}
+
+