]> ncurses.scripts.mit.edu Git - ncurses.git/blobdiff - ncurses/base/safe_sprintf.c
ncurses 5.6 - patch 20070728
[ncurses.git] / ncurses / base / safe_sprintf.c
index 81fe44f0c783d6945e0618af7eee095d0ea8914a..8fc5d89dd210053c6bad037606b35498032efadb 100644 (file)
@@ -1,5 +1,5 @@
 /****************************************************************************
- * Copyright (c) 1998-2001,2003 Free Software Foundation, Inc.              *
+ * Copyright (c) 1998-2003,2007 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            *
@@ -33,7 +33,7 @@
 #include <curses.priv.h>
 #include <ctype.h>
 
-MODULE_ID("$Id: safe_sprintf.c,v 1.18 2003/08/09 21:52:04 tom Exp $")
+MODULE_ID("$Id: safe_sprintf.c,v 1.20 2007/04/21 22:28:06 tom Exp $")
 
 #if USE_SAFE_SPRINTF
 
@@ -207,56 +207,58 @@ _nc_printf_length(const char *fmt, va_list ap)
 }
 #endif
 
+#define my_buffer _nc_globals.safeprint_buf
+#define my_length _nc_globals.safeprint_used
+
 /*
  * Wrapper for vsprintf that allocates a buffer big enough to hold the result.
  */
 NCURSES_EXPORT(char *)
 _nc_printf_string(const char *fmt, va_list ap)
 {
-    static char *buf;
-    static size_t used;
     char *result = 0;
 
     if (fmt != 0) {
 #if USE_SAFE_SPRINTF
        int len = _nc_printf_length(fmt, ap);
 
-       if ((int) used < len + 1) {
-           used = 2 * (len + 1);
-           buf = typeRealloc(char, used, buf);
+       if ((int) my_length < len + 1) {
+           my_length = 2 * (len + 1);
+           my_buffer = typeRealloc(char, my_length, my_buffer);
        }
-       if (buf != 0) {
-           *buf = '\0';
+       if (my_buffer != 0) {
+           *my_buffer = '\0';
            if (len >= 0) {
-               vsprintf(buf, fmt, ap);
+               vsprintf(my_buffer, fmt, ap);
            }
-           result = buf;
+           result = my_buffer;
        }
 #else
-       static int rows, cols;
+#define MyCols _nc_globals.safeprint_cols
+#define MyRows _nc_globals.safeprint_rows
 
-       if (screen_lines > rows || screen_columns > cols) {
-           if (screen_lines > rows)
-               rows = screen_lines;
-           if (screen_columns > cols)
-               cols = screen_columns;
-           used = (rows * (cols + 1)) + 1;
-           buf = typeRealloc(char, used, buf);
+       if (screen_lines > MyRows || screen_columns > MyCols) {
+           if (screen_lines > MyRows)
+               MyRows = screen_lines;
+           if (screen_columns > MyCols)
+               MyCols = screen_columns;
+           my_length = (MyRows * (MyCols + 1)) + 1;
+           my_buffer = typeRealloc(char, my_length, my_buffer);
        }
 
-       if (buf != 0) {
+       if (my_buffer != 0) {
 # if HAVE_VSNPRINTF
-           vsnprintf(buf, used, fmt, ap);      /* GNU extension */
+           vsnprintf(my_buffer, my_length, fmt, ap);   /* GNU extension */
 # else
-           vsprintf(buf, fmt, ap);     /* ANSI */
+           vsprintf(my_buffer, fmt, ap);       /* ANSI */
 # endif
-           result = buf;
+           result = my_buffer;
        }
 #endif
-    } else if (buf != 0) {     /* see _nc_freeall() */
-       free(buf);
-       buf = 0;
-       used = 0;
+    } else if (my_buffer != 0) {       /* see _nc_freeall() */
+       free(my_buffer);
+       my_buffer = 0;
+       my_length = 0;
     }
     return result;
 }