xwords/xwords4/common/dbgutil.c
Eric House e8ab9e0b8b toward compiling with gcc8
My VSIZE is no longer legal, and apparently there's no workaround (no
way to safely figure the length of an array whose size is known at
compile time.) To avoid the risk of duplicating little constants, added
macros that define length in a way a new VSIZE can pick it up. Couldn't
make that work for struct field arrays, however, so there I'm using
constants.
2019-06-23 10:10:00 -07:00

108 lines
2.9 KiB
C

/* -*- compile-command: "cd ../linux && make -j3 MEMDEBUG=TRUE"; -*- */
/*
* Copyright 2006-2012 by Eric House (xwords@eehouse.org). All rights
* reserved.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
#ifdef ENABLE_LOGGING
#include "dbgutil.h"
#include "strutils.h"
#define CASESTR(s) case s: return #s
#define FUNC(f) #f
const char*
XP_Key_2str( XP_Key key )
{
switch( key ) {
CASESTR(XP_KEY_NONE);
CASESTR(XP_CURSOR_KEY_DOWN);
CASESTR(XP_CURSOR_KEY_ALTDOWN);
CASESTR(XP_CURSOR_KEY_RIGHT);
CASESTR(XP_CURSOR_KEY_ALTRIGHT);
CASESTR(XP_CURSOR_KEY_UP);
CASESTR(XP_CURSOR_KEY_ALTUP);
CASESTR(XP_CURSOR_KEY_LEFT);
CASESTR(XP_CURSOR_KEY_ALTLEFT);
CASESTR(XP_CURSOR_KEY_DEL);
CASESTR(XP_RAISEFOCUS_KEY);
CASESTR(XP_RETURN_KEY);
CASESTR(XP_KEY_LAST );
default: return FUNC(__func__) " unknown";
}
}
const char*
DrawFocusState_2str( DrawFocusState dfs )
{
switch( dfs ) {
CASESTR(DFS_NONE);
CASESTR(DFS_TOP);
CASESTR(DFS_DIVED);
default: return FUNC(__func__) " unknown";
}
}
const char*
BoardObjectType_2str( BoardObjectType obj )
{
switch( obj ) {
CASESTR(OBJ_NONE);
CASESTR(OBJ_BOARD);
CASESTR(OBJ_SCORE);
CASESTR(OBJ_TRAY);
default: return FUNC(__func__) " unknown";
}
}
const char*
StackMoveType_2str( StackMoveType typ )
{
switch( typ ) {
CASESTR(ASSIGN_TYPE);
CASESTR(MOVE_TYPE);
CASESTR(TRADE_TYPE);
CASESTR(PHONY_TYPE);
default: return FUNC(__func__) " unknown";
}
}
#undef CASESTR
#endif /* ENABLE_LOGGING */
#ifdef DEBUG
void
dbg_logstream( const XWStreamCtxt* stream, const char* func, int line )
{
if ( !!stream ) {
XP_U16 len = 0;
XWStreamPos end = stream_getPos( stream, POS_WRITE );
stream_copyBits( stream, end, NULL, &len );
XP_U8 buf[len];
stream_copyBits( stream, end, buf, &len );
VDECL( char, comment, 128 );
XP_SNPRINTF( comment, VSIZE(comment), "%s line %d", func, line );
LOG_HEX( buf, len, comment );
} else {
XP_LOGF( "stream from line %d of func %s is null",
line, func );
}
}
#endif