From 39c3c396f515ae727f00c14b71326ef2da201178 Mon Sep 17 00:00:00 2001
From: Ivica Ico Bukvic <ico@vt.edu>
Date: Thu, 21 Feb 2013 12:56:55 -0500
Subject: [PATCH] bug fix
 http://sourceforge.net/tracker/?func=detail&aid=3605384&group_id=55736&atid=478072

---
 pd/src/x_interface.c | 28 +++++++++++++++++++---------
 1 file changed, 19 insertions(+), 9 deletions(-)

diff --git a/pd/src/x_interface.c b/pd/src/x_interface.c
index 8a94e64a5..d21c0094c 100644
--- a/pd/src/x_interface.c
+++ b/pd/src/x_interface.c
@@ -19,24 +19,31 @@ typedef struct _print
     t_symbol *x_sym;
 } t_print;
 
-static void *print_new(t_symbol *s, int argc, t_atom *argv)
+static void *print_new(t_symbol *sel, int argc, t_atom *argv)
 {
-    int bufsize;
-    char *buf;
     t_print *x = (t_print *)pd_new(print_class);
-    if (argc)
+    if (argc == 0)
+        x->x_sym = gensym("print");
+    else if (argc == 1 && argv->a_type == A_SYMBOL)
+    {
+        t_symbol *s = atom_getsymbolarg(0, argc, argv);
+        if (!strcmp(s->s_name, "-n"))
+            x->x_sym = &s_;
+        else x->x_sym = s;
+    }
+    else
     {
+        int bufsize;
+        char *buf;
         t_binbuf *bb = binbuf_new();
         binbuf_add(bb, argc, argv);
         binbuf_gettext(bb, &buf, &bufsize);
+        buf = resizebytes(buf, bufsize, bufsize+1);
         buf[bufsize] = 0;
         x->x_sym = gensym(buf);
+        freebytes(buf, bufsize+1);
         binbuf_free(bb);
     }
-    else 
-    {
-        x->x_sym = gensym("print");
-    }
     return (x);
 }
 
@@ -58,7 +65,10 @@ static void print_float(t_print *x, t_float f)
 static void print_list(t_print *x, t_symbol *s, int argc, t_atom *argv)
 {
     int i;
-    if (argc && argv->a_type != A_SYMBOL) startpost("%s:", x->x_sym->s_name);
+    if (argc && argv->a_type != A_SYMBOL)
+		startpost("%s%s%g", x->x_sym->s_name,
+            (*x->x_sym->s_name ? ": " : ""),
+            atom_getfloatarg(0, argc--, argv++));
     else startpost("%s: %s", x->x_sym->s_name,
         (argc > 1 ? s_list.s_name : (argc == 1 ? s_symbol.s_name :
             s_bang.s_name)));
-- 
GitLab