Add ability, in win32 version, to specify height and width on wine's

commandline -- to ease debugging of layout code.
This commit is contained in:
ehouse 2006-05-12 07:54:59 +00:00
parent 121163e586
commit dbab3bc4fd
2 changed files with 79 additions and 10 deletions

View file

@ -50,6 +50,7 @@ STRIP = i586-mingw32msvc-strip
TARGET_OS_DEF = -DTARGET_OS_WIN32 TARGET_OS_DEF = -DTARGET_OS_WIN32
CELIBS += -lws2_32 CELIBS += -lws2_32
CFLAGS += -DCANT_DO_CMDBAR -DBEYOND_IR -DDRAW_LINK_DIRECT CFLAGS += -DCANT_DO_CMDBAR -DBEYOND_IR -DDRAW_LINK_DIRECT
#CFLAGS += -DFORCE_HEIGHT=240 -DFORCE_WIDTH=320
endif endif
endif endif

View file

@ -154,6 +154,68 @@ static void messageBoxStream( CEAppGlobals* globals, XWStreamCtxt* stream,
wchar_t* title ); wchar_t* title );
static XP_Bool ceQueryFromStream( CEAppGlobals* globals, XWStreamCtxt* stream); static XP_Bool ceQueryFromStream( CEAppGlobals* globals, XWStreamCtxt* stream);
#if defined DEBUG && ! defined _WIN32_WCE
/* Very basic cmdline args meant at first to let me vary the size of the
* screen. Form is of arg=digits, with no spaces and digits having to be an
* integer. Right now only width and height work: e.g.
* "wine obj_win32_dbg/xwords4.exe height=240 width=320"
*/
static int g_dbWidth = 0;
static int g_dbHeight = 0;
static void
doCmd( const char* cmd )
{
struct { char* p; int* v; } params[] = {
{ "width", &g_dbWidth },
{ "height", &g_dbHeight }
};
int i;
for ( i = 0; i < sizeof(params)/sizeof(params[0]); ++i ) {
char* p = params[i].p;
int len = strlen(p);
if ( 0 == strncmp( p, cmd, len ) ) {
cmd += len;
if ( *cmd == '=' ) {
++cmd;
*(params[i].v) = atoi(cmd);
break;
}
}
}
if ( i == sizeof(params)/sizeof(params[0]) ) {
XP_LOGF( "failed to match cmdline arg \"%s\"", cmd );
}
} /* doCmd */
static void
parseCmdLine( const char* cmdline )
{
for ( ; ; ) {
const char* cmd;
char ch;
char buf[64];
int len;
for ( cmd = cmdline ; ; ++cmd ) {
ch = *cmd;
if ( ch == '\0' || ch == ' ' ) {
break;
}
}
len = cmd - cmdline;
memcpy( buf, cmdline, cmd - cmdline );
buf[len] = '\0';
doCmd( buf );
if ( ch == '\0' ) {
break;
}
cmdline = ++cmd;
}
}
#endif
// Forward declarations of functions included in this code module: // Forward declarations of functions included in this code module:
ATOM MyRegisterClass (HINSTANCE, LPTSTR); ATOM MyRegisterClass (HINSTANCE, LPTSTR);
@ -174,6 +236,10 @@ WinMain( HINSTANCE hInstance,
MSG msg; MSG msg;
HACCEL hAccelTable; HACCEL hAccelTable;
#if defined DEBUG && ! defined _WIN32_WCE
parseCmdLine( lpCmdLine );
#endif
// Perform application initialization: // Perform application initialization:
if (!InitInstance (hInstance, nCmdShow)) { if (!InitInstance (hInstance, nCmdShow)) {
return FALSE; return FALSE;
@ -374,7 +440,7 @@ hideScroller( CEAppGlobals* globals )
# define CE_MIN_SCORE_WIDTH 24 /* for vertical score case */ # define CE_MIN_SCORE_WIDTH 24 /* for vertical score case */
#else #else
# define MIN_TRAY_HEIGHT 40 # define MIN_TRAY_HEIGHT 40
# define CE_MIN_SCORE_WIDTH 34 # define CE_MIN_SCORE_WIDTH 36
#endif #endif
#define TRAY_PADDING 1 #define TRAY_PADDING 1
@ -441,15 +507,16 @@ figureBoardParms( CEAppGlobals* globals, XP_U16 nRows, CEBoardParms* bparms )
XP_U16 scrollWidth = 0; XP_U16 scrollWidth = 0;
GetClientRect( globals->hWnd, &rc ); GetClientRect( globals->hWnd, &rc );
#if 1
#ifndef _WIN32_WCE #ifndef _WIN32_WCE
{ #if defined FORCE_HEIGHT && defined FORCE_WIDTH
int width = rc.right - rc.left; rc.right = rc.left + FORCE_WIDTH;
int height = rc.bottom - rc.top; rc.bottom = rc.top + FORCE_HEIGHT;
if ( width > height ) { #else
width = (height * 3) / 4; if ( g_dbWidth != 0 ) {
rc.right = rc.left + width; rc.right = rc.left + g_dbWidth;
} }
if ( g_dbHeight != 0 ) {
rc.bottom = rc.top + g_dbHeight;
} }
#endif #endif
#endif #endif
@ -472,6 +539,7 @@ figureBoardParms( CEAppGlobals* globals, XP_U16 nRows, CEBoardParms* bparms )
if ( horiz ) { if ( horiz ) {
scoreWidth = scrnWidth; scoreWidth = scrnWidth;
hScale = boardWidth / nRows; hScale = boardWidth / nRows;
boardWidth = nRows * hScale;
/* center the board */ /* center the board */
boardWidth += scrollWidth; boardWidth += scrollWidth;
boardLeft = (scrnWidth - boardWidth) / 2; /* center it all */ boardLeft = (scrnWidth - boardWidth) / 2; /* center it all */