ncurses 5.6 - patch 20070421
[ncurses.git] / ncurses / base / lib_slk.c
index 72fff96d9b3153238bb04812e17b7c64b57f8bc1..5609e3b59024c819f4c58573fc3e613fc04ee576 100644 (file)
@@ -1,5 +1,5 @@
 /****************************************************************************
- * Copyright (c) 1998-2000,2002 Free Software Foundation, Inc.              *
+ * Copyright (c) 1998-2004,2005 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            *
  ****************************************************************************/
 
 /****************************************************************************
- *  Author: Zeyd M. Ben-Halim <zmbenhal@netcom.com> 1992,1995               *
- *     and: Eric S. Raymond <esr@snark.thyrsus.com>                         *
+ *  Authors:                                                                *
+ *          Gerhard Fuernkranz                      1993 (original)         *
+ *          Zeyd M. Ben-Halim                       1992,1995 (sic)         *
+ *          Eric S. Raymond                                                 *
+ *          Juergen Pfeifer                         1996-on                 *
+ *          Thomas E. Dickey                                                *
  ****************************************************************************/
 
 /*
@@ -41,7 +45,7 @@
 #include <ctype.h>
 #include <term.h>              /* num_labels, label_*, plab_norm */
 
-MODULE_ID("$Id: lib_slk.c,v 1.24 2002/09/28 17:46:40 tom Exp $")
+MODULE_ID("$Id: lib_slk.c,v 1.30 2005/01/08 21:56:36 tom Exp $")
 
 /*
  * We'd like to move these into the screen context structure, but cannot,
@@ -64,11 +68,25 @@ slk_paint_info(WINDOW *win)
        wmove(win, 0, 0);
 
        for (i = 0; i < SP->_slk->maxlab; i++) {
-           mvwprintw(win, 0, SP->_slk->ent[i].x, "F%d", i + 1);
+           mvwprintw(win, 0, SP->_slk->ent[i].ent_x, "F%d", i + 1);
        }
     }
 }
 
+/*
+ * Free any memory related to soft labels, return an error.
+ */
+static int
+slk_failed(void)
+{
+    if (SP->_slk) {
+       FreeIfNeeded(SP->_slk->ent);
+       free(SP->_slk);
+       SP->_slk = (SLK *) 0;
+    }
+    return ERR;
+}
+
 /*
  * Initialize soft labels.
  * Called from newterm()
@@ -78,19 +96,26 @@ _nc_slk_initialize(WINDOW *stwin, int cols)
 {
     int i, x;
     int res = OK;
-    char *p;
     unsigned max_length;
 
-    T(("slk_initialize()"));
+    T((T_CALLED("_nc_slk_initialize()")));
 
     if (SP->_slk) {            /* we did this already, so simply return */
-       return (OK);
+       returnCode(OK);
     } else if ((SP->_slk = typeCalloc(SLK, 1)) == 0)
-       return (ERR);
+       returnCode(ERR);
 
     SP->_slk->ent = NULL;
-    SP->_slk->buffer = NULL;
-    SP->_slk->attr = A_STANDOUT;
+
+    /*
+     * If we use colors, vidputs() will suppress video attributes that conflict
+     * with colors.  In that case, we're still guaranteed that "reverse" would
+     * work.
+     */
+    if ((no_color_video & 1) == 0)
+       SetAttr(SP->_slk->attr, A_STANDOUT);
+    else
+       SetAttr(SP->_slk->attr, A_REVERSE);
 
     SP->_slk->maxlab = ((num_labels > 0)
                        ? num_labels
@@ -106,19 +131,20 @@ _nc_slk_initialize(WINDOW *stwin, int cols)
        || SP->_slk->labcnt <= 0
        || (SP->_slk->ent = typeCalloc(slk_ent,
                                       (unsigned) SP->_slk->labcnt)) == NULL)
-       goto exception;
+       returnCode(slk_failed());
 
     max_length = SP->_slk->maxlen;
-    p = SP->_slk->buffer = (char *) calloc((unsigned) (2 * SP->_slk->labcnt),
-                                          (1 + max_length));
-    if (SP->_slk->buffer == NULL)
-       goto exception;
-
     for (i = 0; i < SP->_slk->labcnt; i++) {
-       SP->_slk->ent[i].text = p;
-       p += (1 + max_length);
-       SP->_slk->ent[i].form_text = p;
-       p += (1 + max_length);
+       size_t used = max_length + 1;
+
+       if ((SP->_slk->ent[i].ent_text = (char *) _nc_doalloc(0, used)) == 0)
+           returnCode(slk_failed());
+       memset(SP->_slk->ent[i].ent_text, 0, used);
+
+       if ((SP->_slk->ent[i].form_text = (char *) _nc_doalloc(0, used)) == 0)
+           returnCode(slk_failed());
+       memset(SP->_slk->ent[i].form_text, 0, used);
+
        memset(SP->_slk->ent[i].form_text, ' ', max_length);
        SP->_slk->ent[i].visible = (i < SP->_slk->maxlab);
     }
@@ -129,7 +155,7 @@ _nc_slk_initialize(WINDOW *stwin, int cols)
            gap = 1;
 
        for (i = x = 0; i < SP->_slk->maxlab; i++) {
-           SP->_slk->ent[i].x = x;
+           SP->_slk->ent[i].ent_x = x;
            x += max_length;
            x += (i == 3 || i == 7) ? gap : 1;
        }
@@ -141,7 +167,7 @@ _nc_slk_initialize(WINDOW *stwin, int cols)
            if (gap < 1)
                gap = 1;
            for (i = x = 0; i < SP->_slk->maxlab; i++) {
-               SP->_slk->ent[i].x = x;
+               SP->_slk->ent[i].ent_x = x;
                x += max_length;
                x += (i == 3) ? gap : 1;
            }
@@ -153,24 +179,17 @@ _nc_slk_initialize(WINDOW *stwin, int cols)
                if (gap < 1)
                    gap = 1;
                for (i = x = 0; i < SP->_slk->maxlab; i++) {
-                   SP->_slk->ent[i].x = x;
+                   SP->_slk->ent[i].ent_x = x;
                    x += max_length;
                    x += (i == 2 || i == 4) ? gap : 1;
                }
            } else
-               goto exception;
+               returnCode(slk_failed());
        }
     }
     SP->_slk->dirty = TRUE;
     if ((SP->_slk->win = stwin) == NULL) {
-      exception:
-       if (SP->_slk) {
-           FreeIfNeeded(SP->_slk->buffer);
-           FreeIfNeeded(SP->_slk->ent);
-           free(SP->_slk);
-           SP->_slk = (SLK *) 0;
-           res = (ERR);
-       }
+       returnCode(slk_failed());
     }
 
     /* We now reset the format so that the next newterm has again
@@ -179,7 +198,7 @@ _nc_slk_initialize(WINDOW *stwin, int cols)
      */
     SP->slk_format = _nc_slk_format;
     _nc_slk_format = 0;
-    return (res);
+    returnCode(res);
 }
 
 /*