1998-03-01 12:21:12 +08:00
|
|
|
/****************************************************************************
|
2009-04-19 08:38:07 +08:00
|
|
|
* Copyright (c) 1998-2008,2009 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
|
|
|
|
2009-04-19 08:38:07 +08:00
|
|
|
MODULE_ID("$Id: lib_tracedmp.c,v 1.32 2009/04/18 21:01:38 tom Exp $")
|
1997-05-15 12:00:00 +08:00
|
|
|
|
1999-10-24 12:32:42 +08:00
|
|
|
#ifdef TRACE
|
2007-04-22 08:57:08 +08:00
|
|
|
|
|
|
|
#define my_buffer _nc_globals.tracedmp_buf
|
|
|
|
#define my_length _nc_globals.tracedmp_used
|
|
|
|
|
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
|
|
|
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;
|
2007-04-22 08:57:08 +08:00
|
|
|
if (++width + 1 > (int) my_length) {
|
2009-04-19 08:38:07 +08:00
|
|
|
my_length = (unsigned) (2 * (width + 1));
|
2007-04-22 08:57:08 +08:00
|
|
|
my_buffer = typeRealloc(char, my_length, my_buffer);
|
2002-10-13 11:35:53 +08:00
|
|
|
}
|
1997-05-15 12:00:00 +08:00
|
|
|
|
2002-10-13 11:35:53 +08:00
|
|
|
for (n = 0; n <= win->_maxy; ++n) {
|
2007-04-22 08:57:08 +08:00
|
|
|
char *ep = my_buffer;
|
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) {
|
2009-04-19 08:38:07 +08:00
|
|
|
chtype test = (chtype) CharOf(win->_line[n].text[j]);
|
2008-08-17 09:51:55 +08:00
|
|
|
ep[j] = (char) ((UChar(test) == test
|
2002-10-13 11:35:53 +08:00
|
|
|
#if USE_WIDEC_SUPPORT
|
2008-08-17 09:51:55 +08:00
|
|
|
&& (win->_line[n].text[j].chars[1] == 0)
|
2002-10-13 11:35:53 +08:00
|
|
|
#endif
|
2008-08-17 09:51:55 +08:00
|
|
|
)
|
|
|
|
? (iscntrl(UChar(test))
|
|
|
|
? '.'
|
|
|
|
: UChar(test))
|
|
|
|
: '?');
|
2002-10-13 11:35:53 +08:00
|
|
|
}
|
|
|
|
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
|
|
|
|
2007-07-01 08:42:27 +08:00
|
|
|
/* if there are multi-column characters on the line, print them now */
|
|
|
|
if_WIDEC({
|
|
|
|
bool multicolumn = FALSE;
|
|
|
|
for (j = 0; j < width; ++j)
|
|
|
|
if (WidecExt(win->_line[n].text[j]) != 0) {
|
|
|
|
multicolumn = TRUE;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
if (multicolumn) {
|
|
|
|
ep = my_buffer;
|
|
|
|
for (j = 0; j < width; ++j) {
|
2009-04-19 08:38:07 +08:00
|
|
|
chtype test = WidecExt(win->_line[n].text[j]);
|
2007-07-01 08:42:27 +08:00
|
|
|
if (test) {
|
2008-08-17 09:51:55 +08:00
|
|
|
ep[j] = (char) (test + '0');
|
2007-07-01 08:42:27 +08:00
|
|
|
} else {
|
|
|
|
ep[j] = ' ';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
ep[j] = '\0';
|
|
|
|
_tracef("%*s[%2d]%*s='%s'", (int) strlen(name),
|
|
|
|
"widec", n, 8, " ", my_buffer);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
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) {
|
2007-04-22 08:57:08 +08:00
|
|
|
ep = my_buffer;
|
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)
|
2008-08-17 09:51:55 +08:00
|
|
|
ep[j] = (char) (pair + 'A');
|
2005-10-10 02:41:57 +08:00
|
|
|
else if (pair >= 10)
|
2008-08-17 09:51:55 +08:00
|
|
|
ep[j] = (char) (pair + 'a');
|
2005-10-10 02:41:57 +08:00
|
|
|
else if (pair >= 1)
|
2008-08-17 09:51:55 +08:00
|
|
|
ep[j] = (char) (pair + '0');
|
2005-10-10 02:41:57 +08:00
|
|
|
else
|
|
|
|
ep[j] = ' ';
|
|
|
|
}
|
2002-10-13 11:35:53 +08:00
|
|
|
ep[j] = '\0';
|
|
|
|
_tracef("%*s[%2d]%*s='%s'", (int) strlen(name),
|
2007-04-22 08:57:08 +08:00
|
|
|
"colors", n, 8, " ", my_buffer);
|
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";
|
2009-04-19 08:38:07 +08:00
|
|
|
attr_t mask = (attr_t) (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) {
|
2007-04-22 08:57:08 +08:00
|
|
|
ep = my_buffer;
|
2002-10-13 11:35:53 +08:00
|
|
|
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) -
|
2007-04-22 08:57:08 +08:00
|
|
|
1, "attrs", i, n, 8, " ", my_buffer);
|
1997-05-15 12:00:00 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2002-10-13 11:35:53 +08:00
|
|
|
#if NO_LEAKS
|
2007-04-22 08:57:08 +08:00
|
|
|
free(my_buffer);
|
|
|
|
my_buffer = 0;
|
|
|
|
my_length = 0;
|
2002-10-13 11:35:53 +08:00
|
|
|
#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
|
2008-08-05 09:06:16 +08:00
|
|
|
EMPTY_MODULE(_nc_lib_tracedmp)
|
1999-10-24 12:32:42 +08:00
|
|
|
#endif /* TRACE */
|