diff options
-rw-r--r-- | src/canvasname.c | 35 |
1 files changed, 26 insertions, 9 deletions
diff --git a/src/canvasname.c b/src/canvasname.c index 9a469aa..fa852ce 100644 --- a/src/canvasname.c +++ b/src/canvasname.c @@ -45,6 +45,8 @@ typedef struct _canvasname t_object x_obj; t_canvas *x_canvas; + t_outlet*x_nameout; + t_outlet*x_glnameout; } t_canvasname; @@ -54,17 +56,24 @@ static void canvasname_bang(t_canvasname *x) t_binbuf*b=0; t_atom name[1]; - if(!x->x_canvas) return; - b=x->x_canvas->gl_obj.te_binbuf; + if(!c) return; + + if(c->gl_name) + outlet_symbol(x->x_glnameout, c->gl_name); + + + b=c->gl_obj.te_binbuf; + if(b) { /* get the binbufs atomlist */ t_atom*ap=binbuf_getvec(b); t_symbol*s=atom_getsymbol(ap); - outlet_symbol(x->x_obj.ob_outlet, s); - - return; + if(s) + outlet_symbol(x->x_nameout, s); } else { - //post("empty binbuf for %x", x->x_canvas); +#if 0 + post("empty binbuf for %x", x->x_canvas); +#endif } } @@ -73,7 +82,6 @@ static void canvasname_symbol(t_canvasname *x, t_symbol*s) t_canvas*c=x->x_canvas; t_binbuf*b=0; t_atom name[1]; - if(!x->x_canvas) return; b=x->x_canvas->gl_obj.te_binbuf; @@ -85,9 +93,17 @@ static void canvasname_symbol(t_canvasname *x, t_symbol*s) return; } } +static void canvasname_glname(t_canvasname *x, t_symbol*s) +{ + t_canvas*c=x->x_canvas; + if(!c) return; + c->gl_name = s; +} static void canvasname_free(t_canvasname *x) { + if(x->x_nameout )outlet_free(x->x_nameout );x->x_nameout=NULL ; + if(x->x_glnameout)outlet_free(x->x_glnameout);x->x_glnameout=NULL; } static void *canvasname_new(t_floatarg f) @@ -95,7 +111,6 @@ static void *canvasname_new(t_floatarg f) t_canvasname *x = (t_canvasname *)pd_new(canvasname_class); t_glist *glist=(t_glist *)canvas_getcurrent(); t_canvas *canvas=(t_canvas*)glist_getcanvas(glist); - int depth=(int)f; if(depth<0)depth=0; @@ -106,7 +121,8 @@ static void *canvasname_new(t_floatarg f) x->x_canvas = canvas; - outlet_new(&x->x_obj, &s_symbol); + x->x_nameout=outlet_new(&x->x_obj, &s_symbol); + x->x_glnameout=outlet_new(&x->x_obj, &s_symbol); return (x); } @@ -116,5 +132,6 @@ void canvasname_setup(void) canvasname_class = class_new(gensym("canvasname"), (t_newmethod)canvasname_new, (t_method)canvasname_free, sizeof(t_canvasname), 0, A_DEFFLOAT, 0); class_addsymbol(canvasname_class, (t_method)canvasname_symbol); + class_addmethod(canvasname_class, (t_method)canvasname_glname, gensym("display"), A_SYMBOL, 0); class_addbang (canvasname_class, (t_method)canvasname_bang); } |