diff options
-rw-r--r-- | src/propertybang.c | 16 |
1 files changed, 14 insertions, 2 deletions
diff --git a/src/propertybang.c b/src/propertybang.c index d100ad3..a2faf40 100644 --- a/src/propertybang.c +++ b/src/propertybang.c @@ -42,6 +42,8 @@ typedef struct _propertybang } t_propertybang; +t_propertiesfn s_orgfun=NULL; + static void propertybang_free(t_propertybang *x) { removeObjectFromCanvases((t_pd*)x); @@ -53,7 +55,10 @@ static void propertybang_bang(t_propertybang *x) { static void propertybang_properties(t_gobj*z, t_glist*owner) { t_iemguts_objlist*objs=objectsInCanvas((t_pd*)z); - while(objs) { + if(NULL==objs) { + s_orgfun(z, owner); + } + while(objs) { t_propertybang*x=(t_propertybang*)objs->obj; propertybang_bang(x); objs=objs->next; @@ -66,9 +71,14 @@ static void *propertybang_new(void) t_glist *glist=(t_glist *)canvas_getcurrent(); t_canvas *canvas=(t_canvas*)glist_getcanvas(glist); t_class *class = ((t_gobj*)canvas)->g_pd; - + t_propertiesfn orgfun=NULL; + outlet_new(&x->x_obj, &s_bang); + orgfun=class_getpropertiesfn(class); + if(orgfun!=propertybang_properties) + s_orgfun=orgfun; + class_setpropertiesfn(class, propertybang_properties); addObjectToCanvas((t_pd*)canvas, (t_pd*)x); @@ -80,4 +90,6 @@ void propertybang_setup(void) propertybang_class = class_new(gensym("propertybang"), (t_newmethod)propertybang_new, (t_method)propertybang_free, sizeof(t_propertybang), CLASS_NOINLET, 0); class_addbang(propertybang_class, propertybang_bang); + + s_orgfun=NULL; } |