/* Copyright (c) 1997-1999 Miller Puckette. * For information on usage and redistribution, and for a DISCLAIMER OF ALL * WARRANTIES, see the file, "LICENSE.txt," in this distribution. */ /* miscellaneous: print~; more to come. */ #include "m_pd.h" #include <stdio.h> #include <string.h> /* ------------------------- print~ -------------------------- */ static t_class *print_class; typedef struct _print { t_object x_obj; t_float x_f; t_symbol *x_sym; int x_count; } t_print; static t_int *print_perform(t_int *w) { t_print *x = (t_print *)(w[1]); t_sample *in = (t_sample *)(w[2]); int n = (int)(w[3]); if (x->x_count) { int i=0; startpost("%s:", x->x_sym->s_name); for(i=0; i<n; i++) { if(i%8==0)endpost(); startpost("%.4g ", in[i]); } endpost(); x->x_count--; } return (w+4); } static void print_dsp(t_print *x, t_signal **sp) { dsp_add(print_perform, 3, x, sp[0]->s_vec, sp[0]->s_n); } static void print_float(t_print *x, t_float f) { if (f < 0) f = 0; x->x_count = f; } static void print_bang(t_print *x) { x->x_count = 1; } static void *print_new(t_symbol *s) { t_print *x = (t_print *)pd_new(print_class); x->x_sym = (s->s_name[0]? s : gensym("print~")); x->x_count = 0; x->x_f = 0; return (x); } void print_tilde_setup(void) { print_class = class_new(gensym("print~"), (t_newmethod)print_new, 0, sizeof(t_print), 0, A_DEFSYM, 0); CLASS_MAINSIGNALIN(print_class, t_print, x_f); class_addmethod(print_class, (t_method)print_dsp, gensym("dsp"), 0); class_addbang(print_class, print_bang); class_addfloat(print_class, print_float); }