/* dyn - dynamical object management Copyright (c)2003-2004 Thomas Grill (gr@grrrr.org) For information on usage and redistribution, and for a DISCLAIMER OF ALL WARRANTIES, see the file, "license.txt," in this distribution. */ #ifndef __DYN_PROXY_H #define __DYN_PROXY_H #include "dyn.h" #include "dyn_pd.h" #include <set> class dyn_patchable; class dyn_listen; // attention... no virtual table allowed! class proxy { public: t_object pdobj; // must be first dyn_patchable *object; int n; t_sample *buf; t_sample defsig; void init(dyn_patchable *o) { object = o,n = 0,buf = NULL,defsig = 0; } static void px_exit(proxy *px); }; // proxy for inbound messages class proxyin: public proxy { public: t_outlet *outlet; void Message(const t_symbol *s,int argc,const t_atom *argv) { typedmess((t_pd *)&pdobj,(t_symbol *)s,argc,(t_atom *)argv); } void init(dyn_patchable *obj,bool s = false); void exit() { outlet = NULL; } static void px_method(proxyin *obj,const t_symbol *s,int argc,const t_atom *argv); static void dsp(proxyin *x, t_signal **sp); }; typedef std::set<dyn_listen *> Listeners; // proxy for outbound messages class proxyout: public proxy { public: int outlet; Listeners *listeners; // this is initialized in init static void Add(proxyout *px,dyn_listen *l) { px->listeners->insert(l); } static void Rmv(proxyout *px,dyn_listen *l); void init(dyn_patchable *obj,int o,bool s = false); void exit(); static void px_method(proxyout *obj,const t_symbol *s,int argc,const t_atom *argv); static void dsp(proxyout *x, t_signal **sp); }; #endif