From 4d115fa60ada0e8be73c456efe6d6f56c8a56792 Mon Sep 17 00:00:00 2001 From: Hans-Christoph Steiner Date: Fri, 11 Mar 2011 05:41:46 +0000 Subject: flushed out API with objects for all the current levels svn path=/trunk/externals/log/; revision=15026 --- debug.c | 77 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 77 insertions(+) create mode 100644 debug.c (limited to 'debug.c') diff --git a/debug.c b/debug.c new file mode 100644 index 0000000..51d4048 --- /dev/null +++ b/debug.c @@ -0,0 +1,77 @@ + +#include "m_pd.h" + +static t_class *debug_class; + +typedef struct _debug +{ + t_object x_obj; + int level; + t_symbol* tag; +} t_debug; + +static t_symbol* args2symbol(int argc, t_atom *argv) +{ + t_symbol* s; + char* buf; + int bufsize; + t_binbuf *bb = binbuf_new(); + binbuf_add(bb, argc, argv); + binbuf_gettext(bb, &buf, &bufsize); + buf = resizebytes(buf, bufsize, bufsize+1); + buf[bufsize] = 0; + s = gensym(buf); + freebytes(buf, bufsize+1); + binbuf_free(bb); + return s; +} + +static void debug_bang(t_debug *x) +{ + logpost(x, x->level, "%s%sbang", + x->tag->s_name, (*x->tag->s_name ? ": " : "")); +} + +static void debug_pointer(t_debug *x, t_gpointer *gp) +{ + logpost(x, x->level, "%s%s(pointer %lx)", + x->tag->s_name, (*x->tag->s_name ? ": " : ""), gp); +} + +static void debug_float(t_debug *x, t_float f) +{ + logpost(x, (const int)x->level, "%s%s%g", + x->tag->s_name, (*x->tag->s_name ? ": " : ""), f); +} + +static void debug_anything(t_debug *x, t_symbol *s, int argc, t_atom *argv) +{ + t_symbol* output = args2symbol(argc, argv); + logpost(x, (const int)x->level, "%s%s%s %s", + x->tag->s_name, (*x->tag->s_name ? ": " : ""), + s->s_name, output->s_name); +} + +static void *debug_new(t_symbol *s, int argc, t_atom *argv) +{ + t_debug *x = (t_debug *)pd_new(debug_class); + x->tag = &s_; + x->level = 3; + if (argc > 0) + x->tag = args2symbol(argc, argv); + return (x); +} + +void debug_setup(void) +{ + debug_class = class_new(gensym("debug"), + (t_newmethod)debug_new, + 0, + sizeof(t_debug), + CLASS_DEFAULT, + A_GIMME, 0); + class_addbang(debug_class, debug_bang); + class_addfloat(debug_class, debug_float); + class_addpointer(debug_class, debug_pointer); + class_addanything(debug_class, debug_anything); +} -- cgit v1.2.1