ncurses 6.1 - patch 20191207
[ncurses.git] / ncurses / trace / lib_tracechr.c
index 79cf03b4870cfb96e4f88dac050648b2be7eec24..8977f752b50553c24bf912f8ba23aec98312a3d0 100644 (file)
@@ -1,5 +1,5 @@
 /****************************************************************************
 /****************************************************************************
- * Copyright (c) 1998-2007,2008 Free Software Foundation, Inc.              *
+ * Copyright (c) 1998-2009,2012 Free Software Foundation, Inc.              *
  *                                                                          *
  * Permission is hereby granted, free of charge, to any person obtaining a  *
  * copy of this software and associated documentation files (the            *
  *                                                                          *
  * Permission is hereby granted, free of charge, to any person obtaining a  *
  * copy of this software and associated documentation files (the            *
 
 #include <ctype.h>
 
 
 #include <ctype.h>
 
-MODULE_ID("$Id: lib_tracechr.c,v 1.19 2008/08/03 15:39:29 tom Exp $")
+MODULE_ID("$Id: lib_tracechr.c,v 1.22 2012/02/22 22:40:24 tom Exp $")
 
 #ifdef TRACE
 
 
 #ifdef TRACE
 
+#define MyBufSize sizeof(_nc_globals.tracechr_buf)
+
 NCURSES_EXPORT(char *)
 _nc_tracechar(SCREEN *sp, int ch)
 {
 NCURSES_EXPORT(char *)
 _nc_tracechar(SCREEN *sp, int ch)
 {
@@ -52,22 +54,25 @@ _nc_tracechar(SCREEN *sp, int ch)
                      : _nc_globals.tracechr_buf);
 
     if (ch > KEY_MIN || ch < 0) {
                      : _nc_globals.tracechr_buf);
 
     if (ch > KEY_MIN || ch < 0) {
-       name = _nc_keyname(sp, ch);
+       name = safe_keyname(SP_PARM, ch);
        if (name == 0 || *name == '\0')
            name = "NULL";
        if (name == 0 || *name == '\0')
            name = "NULL";
-       (void) sprintf(MyBuffer, "'%.30s' = %#03o", name, ch);
+       _nc_SPRINTF(MyBuffer, _nc_SLIMIT(MyBufSize)
+                   "'%.30s' = %#03o", name, ch);
     } else if (!is8bits(ch) || !isprint(UChar(ch))) {
        /*
         * workaround for glibc bug:
         * sprintf changes the result from unctrl() to an empty string if it
         * does not correspond to a valid multibyte sequence.
         */
     } else if (!is8bits(ch) || !isprint(UChar(ch))) {
        /*
         * workaround for glibc bug:
         * sprintf changes the result from unctrl() to an empty string if it
         * does not correspond to a valid multibyte sequence.
         */
-       (void) sprintf(MyBuffer, "%#03o", ch);
+       _nc_SPRINTF(MyBuffer, _nc_SLIMIT(MyBufSize)
+                   "%#03o", ch);
     } else {
     } else {
-       name = _nc_unctrl(sp, (chtype) ch);
+       name = safe_unctrl(SP_PARM, (chtype) ch);
        if (name == 0 || *name == 0)
            name = "null";      /* shouldn't happen */
        if (name == 0 || *name == 0)
            name = "null";      /* shouldn't happen */
-       (void) sprintf(MyBuffer, "'%.30s' = %#03o", name, ch);
+       _nc_SPRINTF(MyBuffer, _nc_SLIMIT(MyBufSize)
+                   "'%.30s' = %#03o", name, ch);
     }
     return (MyBuffer);
 }
     }
     return (MyBuffer);
 }
@@ -75,7 +80,7 @@ _nc_tracechar(SCREEN *sp, int ch)
 NCURSES_EXPORT(char *)
 _tracechar(int ch)
 {
 NCURSES_EXPORT(char *)
 _tracechar(int ch)
 {
-    return _nc_tracechar(SP, ch);
+    return _nc_tracechar(CURRENT_SCREEN, ch);
 }
 #else
 EMPTY_MODULE(_nc_lib_tracechr)
 }
 #else
 EMPTY_MODULE(_nc_lib_tracechr)