aboutsummaryrefslogtreecommitdiff
path: root/externals/sprinkler/sprinkler.c
diff options
context:
space:
mode:
authorBryan Jurish <mukau@users.sourceforge.net>2004-02-23 00:32:33 +0000
committerBryan Jurish <mukau@users.sourceforge.net>2004-02-23 00:32:33 +0000
commit95bf21f70657b8acada4120e51207d64c97445cd (patch)
tree9d70f5c62395ad5cb4a123856229bcdf03b375bf /externals/sprinkler/sprinkler.c
parente5d8a75e00f005eb4e350d0ca2e5bb3dc263de00 (diff)
sprinkler v0.05
+ added pass-through outlet for unbound destination symbols + added hack to prevent 'bang's being sprinkled as 'normal' symbols svn path=/trunk/; revision=1345
Diffstat (limited to 'externals/sprinkler/sprinkler.c')
-rw-r--r--externals/sprinkler/sprinkler.c37
1 files changed, 30 insertions, 7 deletions
diff --git a/externals/sprinkler/sprinkler.c b/externals/sprinkler/sprinkler.c
index 56ab209d..44e6bde9 100644
--- a/externals/sprinkler/sprinkler.c
+++ b/externals/sprinkler/sprinkler.c
@@ -58,13 +58,14 @@ static char sprinkler_errbuf[EBUFSIZE];
* Structures and Types
*=====================================================================*/
-static char *sprinkler_version = "\nsprinkler version 0.03 by Bryan Jurish : dynamic message dissemination";
+static char *sprinkler_banner = "\nsprinkler version %s by Bryan Jurish : dynamic message dissemination";
static t_class *sprinkler_class;
typedef struct _sprinkler
{
- t_object x_obj;
+ t_object x_obj;
+ t_outlet *x_thru; //-- pass-through outlet
} t_sprinkler;
@@ -98,7 +99,12 @@ static void sprinkler_anything(t_sprinkler *x, t_symbol *dst, int argc, t_atom *
pd_typedmess(dst->s_thing,&s_float,argc,argv);
return;
case A_SYMBOL:
- pd_typedmess(dst->s_thing,&s_symbol,argc,argv);
+ //-- special handling for 'bang'
+ if (argv->a_w.w_symbol == &s_bang) {
+ pd_typedmess(dst->s_thing,&s_bang,0,0);
+ } else {
+ pd_typedmess(dst->s_thing,&s_symbol,argc,argv);
+ }
return;
case A_POINTER:
pd_typedmess(dst->s_thing,&s_pointer,argc,argv);
@@ -114,13 +120,17 @@ static void sprinkler_anything(t_sprinkler *x, t_symbol *dst, int argc, t_atom *
case A_GIMME:
case A_CANT:
default:
- // just fall though
- ; // empty statement to keep VC++ happy
+ // just fall though
}
}
// default -- sprinkler anything else with 'pd_forwardmess'
pd_forwardmess(dst->s_thing,argc,argv);
+ return;
}
+
+ //post("sprinkler: no destination for `%s'", dst ? dst->s_name : "(null)");
+ //-- pass through
+ outlet_anything(x->x_thru, dst, argc, argv);
}
static void sprinkler_list(t_sprinkler *x, t_symbol *s, int argc, t_atom *argv)
@@ -131,19 +141,32 @@ static void sprinkler_list(t_sprinkler *x, t_symbol *s, int argc, t_atom *argv)
sprinkler_anything(x,atom_getsymbol(argv),--argc,++argv);
}
+
+/*--------------------------------------------------------------------
+ * newmethod, freemethod
+ */
void *sprinkler_new(t_symbol *s)
{
t_sprinkler *x = (t_sprinkler *)pd_new(sprinkler_class);
+ x->x_thru = outlet_new(&x->x_obj, &s_anything);
return (x);
}
+void sprinkler_free(t_sprinkler *x) {
+ outlet_free(x->x_thru);
+}
+
/*--------------------------------------------------------------------
* setup
*--------------------------------------------------------------------*/
void sprinkler_setup(void)
{
- post(sprinkler_version);
- sprinkler_class = class_new(gensym("sprinkler"), (t_newmethod)sprinkler_new, 0, sizeof(t_sprinkler), 0, 0);
+ post(sprinkler_banner, PACKAGE_VERSION);
+ sprinkler_class = class_new(gensym("sprinkler"),
+ (t_newmethod)sprinkler_new,
+ (t_method)sprinkler_free,
+ sizeof(t_sprinkler),
+ 0, 0);
#ifdef NON_MAX_FORWARD
// add aliases [forward] and [fw]