ncursesw-morphos/ncurses/trace/lib_tracedmp.c

160 lines
5.2 KiB
C
Raw Normal View History

1998-03-01 12:21:12 +08:00
/****************************************************************************
2006-12-18 12:32:42 +08:00
* Copyright (c) 1998-2005,2006 Free Software Foundation, Inc. *
1998-03-01 12:21:12 +08:00
* *
* Permission is hereby granted, free of charge, to any person obtaining a *
* copy of this software and associated documentation files (the *
* "Software"), to deal in the Software without restriction, including *
* without limitation the rights to use, copy, modify, merge, publish, *
* distribute, distribute with modifications, sublicense, and/or sell *
* copies of the Software, and to permit persons to whom the Software is *
* furnished to do so, subject to the following conditions: *
* *
* The above copyright notice and this permission notice shall be included *
* in all copies or substantial portions of the Software. *
* *
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS *
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF *
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. *
* IN NO EVENT SHALL THE ABOVE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, *
* DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR *
* OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR *
* THE USE OR OTHER DEALINGS IN THE SOFTWARE. *
* *
* Except as contained in this notice, the name(s) of the above copyright *
* holders shall not be used in advertising or otherwise to promote the *
* sale, use or other dealings in this Software without prior written *
* authorization. *
****************************************************************************/
1997-05-15 12:00:00 +08:00
1998-03-01 12:21:12 +08:00
/****************************************************************************
2005-10-10 02:41:57 +08:00
* Author: Thomas E. Dickey 1996-on *
2002-10-13 11:35:53 +08:00
* and: Zeyd M. Ben-Halim <zmbenhal@netcom.com> 1992,1995 *
1998-03-01 12:21:12 +08:00
* and: Eric S. Raymond <esr@snark.thyrsus.com> *
****************************************************************************/
1997-05-15 12:00:00 +08:00
/*
* lib_tracedmp.c - Tracing/Debugging routines
*/
#include <curses.priv.h>
2002-10-13 11:35:53 +08:00
#include <ctype.h>
1997-05-15 12:00:00 +08:00
2006-12-18 12:32:42 +08:00
MODULE_ID("$Id: lib_tracedmp.c,v 1.27 2006/10/14 20:43:31 tom Exp $")
1997-05-15 12:00:00 +08:00
1999-10-24 12:32:42 +08:00
#ifdef TRACE
2002-10-13 11:35:53 +08:00
NCURSES_EXPORT(void)
_tracedump(const char *name, WINDOW *win)
1997-05-15 12:00:00 +08:00
{
2002-10-13 11:35:53 +08:00
static char *buf = 0;
static size_t used = 0;
int i, j, n, width;
1997-05-15 12:00:00 +08:00
/* compute narrowest possible display width */
2002-10-13 11:35:53 +08:00
for (width = i = 0; i <= win->_maxy; ++i) {
1997-05-15 12:00:00 +08:00
n = 0;
2005-10-10 02:41:57 +08:00
for (j = 0; j <= win->_maxx; ++j) {
2002-10-13 11:35:53 +08:00
if (CharOf(win->_line[i].text[j]) != L(' ')
2005-10-10 02:41:57 +08:00
|| AttrOf(win->_line[i].text[j]) != A_NORMAL
|| GetPair(win->_line[i].text[j]) != 0) {
2002-10-13 11:35:53 +08:00
n = j;
2005-10-10 02:41:57 +08:00
}
}
1997-05-15 12:00:00 +08:00
if (n > width)
2002-10-13 11:35:53 +08:00
width = n;
1997-05-15 12:00:00 +08:00
}
if (width < win->_maxx)
2002-10-13 11:35:53 +08:00
++width;
if (++width + 1 > (int) used) {
used = 2 * (width + 1);
buf = typeRealloc(char, used, buf);
}
1997-05-15 12:00:00 +08:00
2002-10-13 11:35:53 +08:00
for (n = 0; n <= win->_maxy; ++n) {
char *ep = buf;
1997-05-15 12:00:00 +08:00
bool haveattrs, havecolors;
2002-10-13 11:35:53 +08:00
/*
* Dump A_CHARTEXT part. It is more important to make the grid line up
* in the trace file than to represent control- and wide-characters, so
* we map those to '.' and '?' respectively.
*/
for (j = 0; j < width; ++j) {
chtype test = CharOf(win->_line[n].text[j]);
ep[j] = (UChar(test) == test
#if USE_WIDEC_SUPPORT
&& (win->_line[n].text[j].chars[1] == 0)
#endif
)
? (iscntrl(UChar(test))
? '.'
: UChar(test))
: '?';
}
ep[j] = '\0';
2006-12-18 12:32:42 +08:00
_tracef("%s[%2d] %3ld%3ld ='%s'",
1997-05-15 12:00:00 +08:00
name, n,
2006-12-18 12:32:42 +08:00
(long) win->_line[n].firstchar,
(long) win->_line[n].lastchar,
2002-10-13 11:35:53 +08:00
ep);
1997-05-15 12:00:00 +08:00
/* dump A_COLOR part, will screw up if there are more than 96 */
havecolors = FALSE;
2002-10-13 11:35:53 +08:00
for (j = 0; j < width; ++j)
2005-10-10 02:41:57 +08:00
if (GetPair(win->_line[n].text[j]) != 0) {
1997-05-15 12:00:00 +08:00
havecolors = TRUE;
break;
}
2002-10-13 11:35:53 +08:00
if (havecolors) {
ep = buf;
2005-10-10 02:41:57 +08:00
for (j = 0; j < width; ++j) {
int pair = GetPair(win->_line[n].text[j]);
if (pair >= 52)
ep[j] = '?';
else if (pair >= 36)
ep[j] = pair + 'A';
else if (pair >= 10)
ep[j] = pair + 'a';
else if (pair >= 1)
ep[j] = pair + '0';
else
ep[j] = ' ';
}
2002-10-13 11:35:53 +08:00
ep[j] = '\0';
_tracef("%*s[%2d]%*s='%s'", (int) strlen(name),
"colors", n, 8, " ", buf);
1997-05-15 12:00:00 +08:00
}
2002-10-13 11:35:53 +08:00
for (i = 0; i < 4; ++i) {
const char *hex = " 123456789ABCDEF";
attr_t mask = (0xf << ((i + 4) * 4));
1997-05-15 12:00:00 +08:00
haveattrs = FALSE;
2002-10-13 11:35:53 +08:00
for (j = 0; j < width; ++j)
if (AttrOf(win->_line[n].text[j]) & mask) {
1997-05-15 12:00:00 +08:00
haveattrs = TRUE;
break;
}
2002-10-13 11:35:53 +08:00
if (haveattrs) {
ep = buf;
for (j = 0; j < width; ++j)
ep[j] = hex[(AttrOf(win->_line[n].text[j]) & mask) >>
((i + 4) * 4)];
ep[j] = '\0';
_tracef("%*s%d[%2d]%*s='%s'", (int) strlen(name) -
1, "attrs", i, n, 8, " ", buf);
1997-05-15 12:00:00 +08:00
}
}
}
2002-10-13 11:35:53 +08:00
#if NO_LEAKS
free(buf);
buf = 0;
used = 0;
#endif
1997-05-15 12:00:00 +08:00
}
2002-10-13 11:35:53 +08:00
1999-10-24 12:32:42 +08:00
#else
2002-10-13 11:35:53 +08:00
empty_module(_nc_lib_tracedmp)
1999-10-24 12:32:42 +08:00
#endif /* TRACE */