diff options
author | IOhannes m zmölnig <zmoelnig@users.sourceforge.net> | 2008-07-23 11:41:40 +0000 |
---|---|---|
committer | IOhannes m zmölnig <zmoelnig@users.sourceforge.net> | 2008-07-23 11:41:40 +0000 |
commit | 375a3141c6153cf1f6a0e3102ea919c3d6292dd6 (patch) | |
tree | eccd6a55eba2ea8bf28020d72718c11084f356dc /src/canvasconnection.c | |
parent | 925c6113a59ec5f139de2b663f57ecfc049142fc (diff) |
renamed object
svn path=/trunk/externals/iem/iemguts/; revision=10211
Diffstat (limited to 'src/canvasconnection.c')
-rw-r--r-- | src/canvasconnection.c | 129 |
1 files changed, 0 insertions, 129 deletions
diff --git a/src/canvasconnection.c b/src/canvasconnection.c deleted file mode 100644 index 58f881a..0000000 --- a/src/canvasconnection.c +++ /dev/null @@ -1,129 +0,0 @@ - -/****************************************************** - * - * canvasconnection - implementation file - * - * copyleft (c) IOhannes m zmölnig - * - * 2007:forum::für::umläute:2007 - * - * institute of electronic music and acoustics (iem) - * - ****************************************************** - * - * license: GNU General Public License v.2 - * - ******************************************************/ - - -/* - * this object provides a way to send messages to upstream canvases - * by default it sends messages to the containing canvas, but you can give the - * "depth" as argument; - * e.g. [canvasconnection 1] will send messages to the parent of the containing canvas - */ - -#include "m_pd.h" -#include "g_canvas.h" -#include "m_imp.h" - -int glist_getindex(t_glist *x, t_gobj *y); - -/* ------------------------- canvasconnection ---------------------------- */ - -static t_class *canvasconnection_class; - -typedef struct _canvasconnection -{ - t_object x_obj; - t_canvas *x_parent; - t_object *x_object; - t_outlet *x_out; -} t_canvasconnection; - -static void canvasconnection_outlets(t_canvasconnection *x) -{ - int noutlets=0; - int nout=0; - t_atom at; - - if(0==x->x_object || 0==x->x_parent) - return; - - noutlets=obj_noutlets(x->x_object); - SETFLOAT(&at, (t_float)noutlets); - - outlet_anything(x->x_out, gensym("outlets"), 1, &at); - for(nout=0; nout<noutlets; nout++) { - t_outlet*out=0; - t_outconnect*conn=obj_starttraverseoutlet(x->x_object, &out, nout); - t_object*dest=0; - t_inlet*in=0; - int which=0; - int count=0, i=0; - t_atom*abuf=0; - while(conn) { - conn=obj_nexttraverseoutlet(conn, &dest, &in, &which); - count++; - } - abuf=(t_atom*)getbytes(sizeof(t_atom)*(count+1)); - SETFLOAT(abuf, nout); - conn=obj_starttraverseoutlet(x->x_object, &out, nout); - while(conn) { - t_float connid=0; - conn=obj_nexttraverseoutlet(conn, &dest, &in, &which); - connid = glist_getindex(x->x_parent, (t_gobj*)dest); - SETFLOAT(abuf+1+i, connid); - i++; - } - outlet_anything(x->x_out, gensym("outlet"), count+1, abuf); - freebytes(abuf, sizeof(t_atom)*(count+1)); - } -} - -static void canvasconnection_bang(t_canvasconnection *x) -{ - canvasconnection_outlets(x); -} - - -static void canvasconnection_free(t_canvasconnection *x) -{ - x->x_object=0; - outlet_free(x->x_out); - x->x_out=0; -} - -static void *canvasconnection_new(t_floatarg f) -{ - t_canvasconnection *x = (t_canvasconnection *)pd_new(canvasconnection_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; - - x->x_parent=0; - x->x_object=0; - - while(depth && canvas) { - canvas=canvas->gl_owner; - depth--; - } - - - if(canvas) { - x->x_object = pd_checkobject((t_pd*)canvas); - x->x_parent = canvas->gl_owner; - } - - x->x_out=outlet_new(&x->x_obj, 0); - - return (x); -} - -void canvasconnection_setup(void) -{ - canvasconnection_class = class_new(gensym("canvasconnection"), (t_newmethod)canvasconnection_new, - (t_method)canvasconnection_free, sizeof(t_canvasconnection), 0, A_DEFFLOAT, 0); - class_addbang(canvasconnection_class, (t_method)canvasconnection_bang); -} |