Blame SOURCES/a2ps-mb.patch

f97431
diff -up a2ps-4.14/lib/psgen.c.mb a2ps-4.14/lib/psgen.c
f97431
--- a2ps-4.14/lib/psgen.c.mb	2008-09-24 15:29:30.000000000 +0100
f97431
+++ a2ps-4.14/lib/psgen.c	2008-09-24 15:29:30.000000000 +0100
f97431
@@ -96,7 +96,8 @@ ps_escape_char (a2ps_job * job, uchar c,
f97431
   /* Printable, but not 7bit clean caracters */
f97431
   if (encoding_char_exists (job->encoding, job->status->face, c)
f97431
       && ((0177 < c) || (c < 040))) {
f97431
-    sprintf ((char *)res, "%s\\%o", res, c);
f97431
+    char *p = res + strlen (res);
f97431
+    sprintf (p, "\\%o", c);
f97431
     return 1;
f97431
   }
f97431
 
f97431
@@ -893,8 +894,8 @@ ps_print_char (a2ps_job * job, int c, en
f97431
   if (c > 127 && encoding_get_composite_flag (job->encoding) &&
f97431
       job->status->face != Symbol) {
f97431
     if (mb_flag) {
f97431
-        nchars = ps_escape_char (job, mb_flag, buf) + 
f97431
-	         ps_escape_char (job, c, buf);
f97431
+        nchars = ps_escape_char (job, mb_flag, buf);
f97431
+	nchars += ps_escape_char (job, c, buf);
f97431
 	job->status->wx += char_composite_WX(job, c);
f97431
 	job->status->column += nchars;
f97431
 	if (line_full) {