aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/receivecanvas.c76
1 files changed, 63 insertions, 13 deletions
diff --git a/src/receivecanvas.c b/src/receivecanvas.c
index b545e78..9250c1c 100644
--- a/src/receivecanvas.c
+++ b/src/receivecanvas.c
@@ -35,16 +35,63 @@
#include <stdio.h>
-/* ------------------------- receivecanvas ---------------------------- */
+static t_class *receivecanvas_class, *receivecanvas_proxy_class;
-static t_class *receivecanvas_class;
+typedef struct _receivecanvas_proxy
+{
+ t_object p_obj;
+ t_symbol*p_sym;
+ t_clock *p_clock;
+ struct _receivecanvas*p_parent;
+} t_receivecanvas_proxy;
typedef struct _receivecanvas
{
- t_object x_obj;
- t_symbol *x_sym;
+ t_object x_obj;
+ t_receivecanvas_proxy*x_proxy;
} t_receivecanvas;
+/* ------------------------- receivecanvas proxy ---------------------------- */
+
+static void receivecanvas_anything(t_receivecanvas *x, t_symbol*s, int argc, t_atom*argv);
+
+static void receivecanvas_proxy_anything(t_receivecanvas_proxy *p, t_symbol*s, int argc, t_atom*argv) {
+ if(p->p_parent)
+ receivecanvas_anything(p->p_parent, s, argc, argv);
+}
+static void receivecanvas_proxy_free(t_receivecanvas_proxy *p)
+{
+ if(p->p_sym)
+ pd_unbind(&p->p_obj.ob_pd, p->p_sym);
+ p->p_sym=NULL;
+
+ clock_free(p->p_clock);
+ p->p_clock=NULL;
+
+ p->p_parent=NULL;
+ pd_free(&p->p_obj.ob_pd);
+
+ p=NULL;
+}
+static t_receivecanvas_proxy*receivecanvas_proxy_new(t_receivecanvas *x, t_symbol*s) {
+ t_receivecanvas_proxy*p=NULL;
+
+ if(!x) return p;
+
+ p=(t_receivecanvas_proxy*)pd_new(receivecanvas_proxy_class);
+
+ p->p_sym=s;
+ if(p->p_sym) {
+ pd_bind(&p->p_obj.ob_pd, p->p_sym);
+ }
+ p->p_parent=x;
+ p->p_clock=clock_new(p, (t_method)receivecanvas_proxy_free);
+
+ return p;
+}
+
+
+/* ------------------------- receivecanvas ---------------------------- */
static void receivecanvas_anything(t_receivecanvas *x, t_symbol*s, int argc, t_atom*argv)
{
outlet_anything(x->x_obj.ob_outlet, s, argc, argv);
@@ -52,8 +99,10 @@ static void receivecanvas_anything(t_receivecanvas *x, t_symbol*s, int argc, t_a
static void receivecanvas_free(t_receivecanvas *x)
{
- if(x->x_sym)
- pd_unbind(&x->x_obj.ob_pd, x->x_sym);
+ if(x->x_proxy) {
+ x->x_proxy->p_parent = NULL;
+ clock_delay(x->x_proxy->p_clock, 0);
+ }
}
static void *receivecanvas_new(t_floatarg f)
@@ -69,15 +118,14 @@ static void *receivecanvas_new(t_floatarg f)
depth--;
}
- x->x_sym=NULL;
+ x->x_proxy=NULL;
if(canvas) {
- char buf[40];
- snprintf(buf, 40, ".x%lx", (t_int)canvas);
- x->x_sym=gensym(buf);
-
- pd_bind(&x->x_obj.ob_pd, x->x_sym);
+ char buf[MAXPDSTRING];
+ snprintf(buf, MAXPDSTRING-1, ".x%lx", (t_int)canvas);
+ buf[MAXPDSTRING-1]=0;
+ x->x_proxy=receivecanvas_proxy_new(x, gensym(buf));
}
outlet_new(&x->x_obj, 0);
@@ -89,5 +137,7 @@ void receivecanvas_setup(void)
{
receivecanvas_class = class_new(gensym("receivecanvas"), (t_newmethod)receivecanvas_new,
(t_method)receivecanvas_free, sizeof(t_receivecanvas), CLASS_NOINLET, A_DEFFLOAT, 0);
- class_addanything(receivecanvas_class, (t_method)receivecanvas_anything);
+
+ receivecanvas_proxy_class = class_new(0, 0, 0, sizeof(t_receivecanvas_proxy), CLASS_NOINLET | CLASS_PD, 0);
+ class_addanything(receivecanvas_proxy_class, receivecanvas_proxy_anything);
}