Fix dictionary-search code to look in top-level temporary directories

rather than hard-coded "SD Card" etc. to work in non-English cases;
fix password dialog to fit, and simplify it; fix backspace on
smartphone for all dialogs with EDIT fields to actually backspace
rather than exiting app; and in main window have it raise focus.  This
change requires SHSendBackToFocusWindow(), which is not yet in cegcc.
Until I get a patch accepted this breaks wince builds.
This commit is contained in:
ehouse 2008-05-31 22:07:29 +00:00
parent e60d338488
commit 7da66696ed
17 changed files with 209 additions and 177 deletions

View file

@ -20,6 +20,7 @@
#include "ceaskpwd.h" #include "ceaskpwd.h"
#include "cemain.h" #include "cemain.h"
#include "ceutil.h" #include "ceutil.h"
#include "debhacks.h"
#include <stdio.h> /* swprintf */ #include <stdio.h> /* swprintf */
static void static void
@ -48,6 +49,9 @@ PasswdDlg(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
SetWindowLong( hDlg, GWL_USERDATA, lParam ); SetWindowLong( hDlg, GWL_USERDATA, lParam );
pState = (PasswdDialogState*)lParam; pState = (PasswdDialogState*)lParam;
ceDlgSetup( pState->globals, hDlg );
trapBackspaceKey( hDlg );
nameToLabel( hDlg, pState->name, IDC_PWDLABEL ); nameToLabel( hDlg, pState->name, IDC_PWDLABEL );
return TRUE; return TRUE;
@ -56,6 +60,14 @@ PasswdDlg(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
if ( !!pState ) { if ( !!pState ) {
switch ( message ) { switch ( message ) {
#ifdef _WIN32_WCE
case WM_HOTKEY:
if ( VK_TBACK == HIWORD(lParam) ) {
SHSendBackToFocusWindow( message, wParam, lParam );
return TRUE;
}
break;
#endif
case WM_COMMAND: case WM_COMMAND:
id = LOWORD(wParam); id = LOWORD(wParam);
switch( id ) { switch( id ) {

View file

@ -24,6 +24,7 @@
#include "cemain.h" #include "cemain.h"
typedef struct PasswdDialogState { typedef struct PasswdDialogState {
CEAppGlobals* globals;
const XP_UCHAR* name; const XP_UCHAR* name;
XP_UCHAR* buf; XP_UCHAR* buf;
XP_U16* lenp; XP_U16* lenp;

View file

@ -1,6 +1,6 @@
/* -*-mode: C; fill-column: 77; c-basic-offset: 4; -*- */ /* -*-mode: C; fill-column: 77; c-basic-offset: 4; -*- */
/* /*
* Copyright 2002 by Eric House (xwords@eehouse.org). All rights reserved. * Copyright 2002,2008 by Eric House (xwords@eehouse.org). All rights reserved.
* *
* This program is free software; you can redistribute it and/or * This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License * modify it under the terms of the GNU General Public License
@ -20,6 +20,7 @@
#include "ceblank.h" #include "ceblank.h"
#include "cemain.h" #include "cemain.h"
#include "ceutil.h" #include "ceutil.h"
#include "debhacks.h"
static void static void
loadLettersList( HWND hDlg, BlankDialogState* bState ) loadLettersList( HWND hDlg, BlankDialogState* bState )
@ -37,7 +38,7 @@ loadLettersList( HWND hDlg, BlankDialogState* bState )
widebuf, VSIZE(widebuf) ); widebuf, VSIZE(widebuf) );
widebuf[len] = 0; widebuf[len] = 0;
SendDlgItemMessage( hDlg, BLANKFACE_LIST, LB_ADDSTRING, SendDlgItemMessage( hDlg, BLANKFACE_LIST, ADDSTRING,
0, (long)widebuf ); 0, (long)widebuf );
} }
ce_selectAndShow( hDlg, BLANKFACE_LIST, 0 ); ce_selectAndShow( hDlg, BLANKFACE_LIST, 0 );
@ -95,15 +96,15 @@ BlankDlg(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
} else { } else {
XP_ASSERT( bState->pi->why == PICK_FOR_BLANK ); XP_ASSERT( bState->pi->why == PICK_FOR_BLANK );
ceShowOrHide( hDlg, IDC_CPICK, XP_FALSE ); ceShowOrHide( hDlg, IDC_CPICK, XP_FALSE );
ceShowOrHide( hDlg, IDC_PICKALL, XP_FALSE );
ceShowOrHide( hDlg, IDC_PICKMSG, XP_FALSE ); ceShowOrHide( hDlg, IDC_PICKMSG, XP_FALSE );
} }
ceShowOrHide( hDlg, IDC_BACKUP, bState->canBackup = (bState->pi->why == PICK_FOR_CHEAT)
bState->pi->why == PICK_FOR_CHEAT && (bState->pi->thisPick > 0);
&& bState->pi->thisPick > 0 ); ceShowOrHide( hDlg, IDC_BACKUP, bState->canBackup );
#endif #endif
ceDlgSetup( bState->globals, hDlg ); ceDlgSetup( bState->globals, hDlg );
trapBackspaceKey( hDlg );
loadLettersList( hDlg, bState ); loadLettersList( hDlg, bState );
} else { } else {
@ -111,14 +112,25 @@ BlankDlg(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
if ( !!bState ) { if ( !!bState ) {
switch ( message ) { switch ( message ) {
case WM_KEYDOWN: /* key down. Select a list item? */ /* case WM_KEYDOWN: /\* key down. Select a list item? *\/ */
XP_LOGF( "got WM_KEYDOWN" ); /* XP_LOGF( "got WM_KEYDOWN" ); */
/* break; */
#ifdef _WIN32_WCE
case WM_HOTKEY:
if ( VK_TBACK == HIWORD(lParam) ) {
if ( bState->canBackup ) {
bState->result = PICKER_BACKUP;
EndDialog( hDlg, IDC_BACKUP );
return TRUE;
}
}
break; break;
#endif
case WM_COMMAND: case WM_COMMAND:
id = LOWORD(wParam); id = LOWORD(wParam);
if ( 0 ) { if ( 0 ) {
#ifdef FEATURE_TRAY_EDIT #ifdef FEATURE_TRAY_EDIT
} else if ( id == IDC_PICKALL ) { } else if ( id == IDCANCEL ) {
bState->result = PICKER_PICKALL; bState->result = PICKER_PICKALL;
} else if ( id == IDC_BACKUP ) { } else if ( id == IDC_BACKUP ) {
bState->result = PICKER_BACKUP; bState->result = PICKER_BACKUP;
@ -126,7 +138,7 @@ BlankDlg(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
} else if ( id == IDOK ) { } else if ( id == IDOK ) {
bState->result = bState->result =
(XP_S16)SendDlgItemMessage( hDlg, BLANKFACE_LIST, (XP_S16)SendDlgItemMessage( hDlg, BLANKFACE_LIST,
LB_GETCURSEL, 0, 0 ); GETCURSEL, 0, 0 );
} else { } else {
break; break;
} }

View file

@ -1,6 +1,6 @@
/* -*-mode: C; fill-column: 77; c-basic-offset: 4; -*- */ /* -*-mode: C; fill-column: 77; c-basic-offset: 4; -*- */
/* /*
* Copyright 2002 by Eric House (xwords@eehouse.org). All rights reserved. * Copyright 2002, 2008 by Eric House (xwords@eehouse.org). All rights reserved.
* *
* This program is free software; you can redistribute it and/or * This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License * modify it under the terms of the GNU General Public License
@ -30,6 +30,7 @@ typedef struct BlankDialogState {
const XP_UCHAR4* texts; const XP_UCHAR4* texts;
XP_U16 nTiles; XP_U16 nTiles;
XP_S16 result; XP_S16 result;
XP_Bool canBackup;
} BlankDialogState; } BlankDialogState;
LRESULT CALLBACK BlankDlg(HWND, UINT, WPARAM, LPARAM); LRESULT CALLBACK BlankDlg(HWND, UINT, WPARAM, LPARAM);

View file

@ -146,6 +146,7 @@ EditColorsDlg( HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam )
eState->inited = XP_FALSE; eState->inited = XP_FALSE;
ceDlgSetup( eState->globals, hDlg ); ceDlgSetup( eState->globals, hDlg );
trapBackspaceKey( hDlg );
wchar_t label[32]; wchar_t label[32];
XP_U16 len = SendDlgItemMessage( eState->parent, eState->labelID, XP_U16 len = SendDlgItemMessage( eState->parent, eState->labelID,
@ -197,7 +198,14 @@ EditColorsDlg( HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam )
break; break;
} }
break; break;
#ifdef _WIN32_WCE
case WM_HOTKEY:
if ( VK_TBACK == HIWORD(lParam) ) {
SHSendBackToFocusWindow( message, wParam, lParam );
return TRUE;
}
break;
#endif
case WM_COMMAND: case WM_COMMAND:
wid = LOWORD(wParam); wid = LOWORD(wParam);
switch( wid ) { switch( wid ) {

View file

@ -23,11 +23,13 @@
#include <string.h> /* _snwprintf */ #include <string.h> /* _snwprintf */
#include "stdafx.h" #include "stdafx.h"
/* #include <accctrl.h> */
#include <commdlg.h> #include <commdlg.h>
#include "dictnryp.h" #include "dictnryp.h"
#include "strutils.h" #include "strutils.h"
#include "cedict.h" #include "cedict.h"
#include "debhacks.h" #include "debhacks.h"
#include "cedebug.h"
typedef struct CEDictionaryCtxt { typedef struct CEDictionaryCtxt {
DictionaryCtxt super; DictionaryCtxt super;
@ -621,123 +623,49 @@ locateOneDir( MPFORMAL wchar_t* path, OnePathCB cb, void* ctxt, XP_U16 nSought,
return done; return done;
} /* locateOneDir */ } /* locateOneDir */
#define USE_FOREACH /* FOREACH avoids code duplication, but may not be worth
the extra complexity. Size is the same. */
#ifdef USE_FOREACH
/* return true when done */
typedef XP_Bool (*ForEachCB)( wchar_t* dir, void* ctxt );
static void
forEachDictDir( HINSTANCE hInstance, ForEachCB cb, void* ctxt )
{
UINT id;
for ( id = IDS_DICTDIRS; ; ++id ) {
wchar_t pathBuf[CE_MAX_PATH_LEN+1];
if ( 0 >= LoadString( hInstance, id, pathBuf,
VSIZE(pathBuf) ) ) {
break;
}
if ( (*cb)( pathBuf, ctxt ) ) {
break;
}
}
} /* forEachDictDir */
typedef struct LocateOneData {
XP_U16 nFound;
XP_U16 nSought;
OnePathCB cb;
void* ctxt;
MPSLOT
} LocateOneData;
static XP_Bool static XP_Bool
locateOneDirCB( wchar_t* dir, void* ctxt ) getDictDir( wchar_t* buf )
{ {
LocateOneData* datap = (LocateOneData*)ctxt; /* BOOL found = SHGetKnownFolderPath(HWND,LPWSTR,int,BOOL); */
// temporary hack until I figure SHGetKnownFolderPath out
return locateOneDir( MPPARM(datap->mpool) dir, datap->cb, wsprintf( buf, L"\\Program Files\\Crosswords" );
datap->ctxt, datap->nSought, &datap->nFound ) return XP_TRUE;
|| datap->nFound >= datap->nSought;
} /* locateOneDirCB */
XP_U16
ceLocateNDicts( MPFORMAL HINSTANCE hInstance, XP_U16 nSought,
OnePathCB cb, void* ctxt )
{
LocateOneData data;
data.nFound = 0;
data.nSought = nSought;
data.cb = cb;
data.ctxt = ctxt;
#ifdef MEM_DEBUG
data.mpool = mpool;
#endif
forEachDictDir( hInstance, locateOneDirCB, &data );
return data.nFound;
} }
typedef struct FormatDirsData {
XWStreamCtxt* stream;
XP_Bool firstPassDone;
} FormatDirsData;
static XP_Bool
formatDirsCB( wchar_t* dir, void* ctxt )
{
FormatDirsData* datap = (FormatDirsData*)ctxt;
XP_UCHAR narrow[CE_MAX_PATH_LEN+1];
int len;
if ( datap->firstPassDone ) {
stream_putString( datap->stream, ", " );
} else {
datap->firstPassDone = XP_TRUE;
}
len = WideCharToMultiByte( CP_ACP, 0, dir, -1,
narrow, VSIZE(narrow),
NULL, NULL );
stream_putString( datap->stream, narrow );
return XP_FALSE;
} /* formatDirsCB */
void
ceFormatDictDirs( XWStreamCtxt* stream, HINSTANCE hInstance )
{
FormatDirsData data;
data.stream = stream;
data.firstPassDone = XP_FALSE;
forEachDictDir( hInstance, formatDirsCB, &data );
}
#else
XP_U16 XP_U16
ceLocateNDicts( MPFORMAL HINSTANCE hInstance, XP_U16 nSought, ceLocateNDicts( MPFORMAL XP_U16 nSought, OnePathCB cb, void* ctxt )
OnePathCB cb, void* ctxt )
{ {
XP_U16 nFound = 0; XP_U16 nFound = 0;
UINT id; wchar_t path[CE_MAX_PATH_LEN+1];
for ( id = IDS_DICTDIRS; ; ++id ) { if ( getDictDir( path ) ) {
wchar_t pathBuf[CE_MAX_PATH_LEN+1]; locateOneDir( MPPARM(mpool) path, cb, ctxt, nSought, &nFound );
if ( 0 >= LoadString( hInstance, id, pathBuf, }
VSIZE(pathBuf) ) ) {
if ( nFound < nSought ) {
WIN32_FIND_DATA data;
HANDLE fileH;
XP_MEMSET( &data, 0, sizeof(data) );
fileH = FindFirstFile( L"\\*", &data );
while ( fileH != INVALID_HANDLE_VALUE ) {
if ( ((data.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY) != 0)
&& (((data.dwFileAttributes & FILE_ATTRIBUTE_TEMPORARY) != 0) ) ) {
wsprintf( path, L"\\%s\\Crosswords", data.cFileName );
XP_LOGW( "looking in:", path );
locateOneDir( MPPARM(mpool) path, cb, ctxt, nSought, &nFound );
}
if ( nFound >= nSought ) {
break; break;
} }
locateOneDir( MPPARM(mpool) pathBuf, cb, ctxt, nSought, &nFound ); if ( !FindNextFile( fileH, &data ) ) {
if ( nFound >= nSought ) {
break; break;
} }
} }
}
return nFound; return nFound;
} /* ceLocateNDicts */ } /* ceLocateNDicts */
@ -745,28 +673,19 @@ ceLocateNDicts( MPFORMAL HINSTANCE hInstance, XP_U16 nSought,
void void
ceFormatDictDirs( XWStreamCtxt* stream, HINSTANCE hInstance ) ceFormatDictDirs( XWStreamCtxt* stream, HINSTANCE hInstance )
{ {
UINT id; wchar_t path[CE_MAX_PATH_LEN+1];
if ( getDictDir( path ) ) {
for ( id = IDS_DICTDIRS; ; ++id ) { char narrowName[CE_MAX_PATH_LEN+1];
wchar_t wide[CE_MAX_PATH_LEN+1]; int len = wcslen( path );
XP_UCHAR narrow[CE_MAX_PATH_LEN+1]; len = WideCharToMultiByte( CP_ACP, 0, path, len + 1,
XP_U16 len; narrowName, len + 1, NULL, NULL );
stream_putString( stream, narrowName );
if ( 0 >= LoadString( hInstance, id, wide, stream_putString( stream, " or" );
VSIZE(wide) ) ) {
break;
} }
if ( id != IDS_DICTDIRS ) { const char* rest = " on an external card, e.g. in \\Storage Card\\Crosswords";
stream_putString( stream, ", " ); stream_putString( stream, rest );
}
len = WideCharToMultiByte( CP_ACP, 0, wide, -1,
narrow, VSIZE(narrow),
NULL, NULL );
stream_putString( stream, narrow );
}
} }
#endif /* USE_FOREACH */
typedef struct FindOneData { typedef struct FindOneData {
wchar_t* result; wchar_t* result;
@ -807,8 +726,7 @@ findAlternateDict( CEAppGlobals* globals, wchar_t* path )
data.sought = wbname( shortPath, sizeof(shortPath), path ); data.sought = wbname( shortPath, sizeof(shortPath), path );
data.result = path; data.result = path;
(void)ceLocateNDicts( MPPARM(globals->mpool) globals->hInst, CE_MAXDICTS, (void)ceLocateNDicts( MPPARM(globals->mpool) CE_MAXDICTS, matchShortName, &data );
matchShortName, &data );
return data.found; return data.found;
} /* findAlternateDict */ } /* findAlternateDict */

View file

@ -41,8 +41,7 @@ typedef XP_Bool (*OnePathCB)( const wchar_t* wPath, XP_U16 index, void* ctxt );
* dict files. Return the number actually found. Caller is responsible for * dict files. Return the number actually found. Caller is responsible for
* making sure bufs contains nSought slots. * making sure bufs contains nSought slots.
*/ */
XP_U16 ceLocateNDicts( MPFORMAL HINSTANCE hInstance, XP_U16 nSought, XP_U16 ceLocateNDicts( MPFORMAL XP_U16 nSought, OnePathCB cb, void* ctxt );
OnePathCB cb, void* ctxt );
void ceFormatDictDirs( XWStreamCtxt* stream, HINSTANCE hInstance ); void ceFormatDictDirs( XWStreamCtxt* stream, HINSTANCE hInstance );
/* return just the name, no extension, of dict, written to buf, pointed to by /* return just the name, no extension, of dict, written to buf, pointed to by

View file

@ -900,7 +900,7 @@ DRAW_FUNC_NAME(score_pendingScore)( DrawCtx* p_dctx, const XP_Rect* rect,
wchar_t widebuf[5]; wchar_t widebuf[5];
XP_UCHAR buf[5]; XP_UCHAR buf[5];
RECT rt; RECT rt, clip;
XP_U16 bkIndex = (flags & CELL_ISCURSOR) == 0? XP_U16 bkIndex = (flags & CELL_ISCURSOR) == 0?
CE_BKG_COLOR : CE_FOCUS_COLOR; CE_BKG_COLOR : CE_FOCUS_COLOR;
@ -912,7 +912,11 @@ DRAW_FUNC_NAME(score_pendingScore)( DrawCtx* p_dctx, const XP_Rect* rect,
XPRtoRECT( &rt, rect ); XPRtoRECT( &rt, rect );
FillRect( hdc, &rt, dctx->brushes[bkIndex] ); FillRect( hdc, &rt, dctx->brushes[bkIndex] );
ceClipToRect( hdc, &rt ); /* Use a separate rect for clipping since shrinking puts text to close
together on smartphone's small screen. */
clip = rt;
InsetRect( &clip, 2, 2 );
ceClipToRect( hdc, &clip );
DrawText(hdc, L"Pts", -1, &rt, DT_SINGLELINE | DT_TOP | DT_CENTER); DrawText(hdc, L"Pts", -1, &rt, DT_SINGLELINE | DT_TOP | DT_CENTER);

View file

@ -26,6 +26,7 @@
#include "cecondlg.h" #include "cecondlg.h"
#include "strutils.h" #include "strutils.h"
#include "cedebug.h" #include "cedebug.h"
#include "debhacks.h"
#define NUM_COLS 4 #define NUM_COLS 4
#define MENUDICTS_INCR 16 #define MENUDICTS_INCR 16
@ -181,7 +182,7 @@ loadFromGameInfo( HWND hDlg, CEAppGlobals* globals, GameInfoState* giState )
(XP_U16)XP_STRLEN(gi->dictName)+1 ); (XP_U16)XP_STRLEN(gi->dictName)+1 );
} }
if ( giState->isNewGame ) { if ( giState->isNewGame ) {
(void)ceLocateNDicts( MPPARM(globals->mpool) globals->hInst, (void)ceLocateNDicts( MPPARM(globals->mpool)
CE_MAXDICTS, addDictToState, giState ); CE_MAXDICTS, addDictToState, giState );
} else { } else {
wchar_t wPath[CE_MAX_PATH_LEN+1]; wchar_t wPath[CE_MAX_PATH_LEN+1];
@ -495,6 +496,7 @@ GameInfo(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
globals = giState->globals; globals = giState->globals;
ceDlgSetup( globals, hDlg ); ceDlgSetup( globals, hDlg );
trapBackspaceKey( hDlg );
giState->newGameCtx = newg_make( MPPARM(globals->mpool) giState->newGameCtx = newg_make( MPPARM(globals->mpool)
giState->isNewGame, giState->isNewGame,
@ -513,6 +515,7 @@ GameInfo(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
if ( giState->isNewGame ) { if ( giState->isNewGame ) {
(void)SetWindowText( hDlg, L"New game" ); (void)SetWindowText( hDlg, L"New game" );
} }
result = TRUE; result = TRUE;
} else { } else {
@ -521,7 +524,14 @@ GameInfo(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
globals = giState->globals; globals = giState->globals;
switch (message) { switch (message) {
#ifdef _WIN32_WCE
case WM_HOTKEY:
if ( VK_TBACK == HIWORD(lParam) ) {
SHSendBackToFocusWindow( message, wParam, lParam );
result = TRUE;
}
break;
#endif
case WM_VSCROLL: case WM_VSCROLL:
result = ceDoDlgScroll( globals, hDlg, wParam ); result = ceDoDlgScroll( globals, hDlg, wParam );
break; break;

View file

@ -1064,7 +1064,7 @@ doDictsMovedAlert( CEAppGlobals* globals )
stream_putString( stream, stream_putString( stream,
"Please be aware that starting with this version " "Please be aware that starting with this version "
"Crosswords will not find dictionaries unless they " "Crosswords will not find dictionaries unless they "
"are located in one of these directories: " ); "are located in " );
ceFormatDictDirs( stream, globals->hInst ); ceFormatDictDirs( stream, globals->hInst );
stream_putString( stream, ". From now on, dictionaries will be " stream_putString( stream, ". From now on, dictionaries will be "
"available as .cab files which will put them in the " "available as .cab files which will put them in the "
@ -1239,15 +1239,15 @@ InitInstance(HINSTANCE hInstance, int nCmdShow)
/* choose one. If none found it's an error. */ /* choose one. If none found it's an error. */
#ifndef STUBBED_DICT #ifndef STUBBED_DICT
result = 1 == ceLocateNDicts( MPPARM(mpool) hInstance, 1, ceSetDictName, result = 1 == ceLocateNDicts( MPPARM(mpool) 1, ceSetDictName,
globals ); globals );
if ( !result ) { if ( !result ) {
XWStreamCtxt* stream = make_generic_stream( globals ); XWStreamCtxt* stream = make_generic_stream( globals );
stream_putString( stream, "Please install a Crosswords dictionary " stream_putString( stream, "Please install a Crosswords dictionary "
"in one of these directories: " ); "in " );
ceFormatDictDirs( stream, hInstance ); ceFormatDictDirs( stream, hInstance );
stream_putString( stream, ". Download dictionaries from " stream_putString( stream, ". Download dictionaries from "
"http://xwords.sf.net." ); "http://xwords.sf.net or http://eehouse.org/xwords." );
messageBoxStream( globals, stream, L"Dictionary Not Found", MB_OK ); messageBoxStream( globals, stream, L"Dictionary Not Found", MB_OK );
stream_destroy( stream ); stream_destroy( stream );
result = FALSE; result = FALSE;
@ -1284,6 +1284,8 @@ InitInstance(HINSTANCE hInstance, int nCmdShow)
} }
} }
trapBackspaceKey( hWnd );
ShowWindow(hWnd, nCmdShow); ShowWindow(hWnd, nCmdShow);
UpdateWindow(hWnd); UpdateWindow(hWnd);
#ifdef _WIN32_WCE #ifdef _WIN32_WCE
@ -1995,7 +1997,7 @@ WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)
XP_Bool draw = XP_FALSE; XP_Bool draw = XP_FALSE;
XWTimerReason why; XWTimerReason why;
CEAppGlobals* globals; CEAppGlobals* globals;
XP_Bool handled; XP_Bool handled = XP_FALSE;
XP_Bool callDefault = XP_FALSE; XP_Bool callDefault = XP_FALSE;
if ( message == WM_CREATE ) { if ( message == WM_CREATE ) {
@ -2206,6 +2208,23 @@ WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)
} }
break; break;
#ifdef _WIN32_WCE
/* Make the back key mean raise focus, but only if dived.
Otherwise allow the OS to do what it wants. Which means
exit? */
case WM_HOTKEY:
if ( VK_TBACK == HIWORD(lParam) ) {
if ( !!globals->game.board ) {
draw = board_handleKey( globals->game.board,
XP_RAISEFOCUS_KEY, &handled );
}
}
if ( !draw || !handled ) {
callDefault = XP_TRUE;
}
break;
#endif
#ifdef KEYBOARD_NAV #ifdef KEYBOARD_NAV
case WM_KEYDOWN: case WM_KEYDOWN:
case WM_KEYUP: case WM_KEYUP:
@ -2798,6 +2817,7 @@ ce_util_askPassword( XW_UtilCtxt* uc, const XP_UCHAR* name,
CEAppGlobals* globals = (CEAppGlobals*)uc->closure; CEAppGlobals* globals = (CEAppGlobals*)uc->closure;
XP_MEMSET( &state, 0, sizeof(state) ); XP_MEMSET( &state, 0, sizeof(state) );
state.globals = globals;
state.name = name; state.name = name;
state.buf = buf; state.buf = buf;
state.lenp = len; state.lenp = len;

View file

@ -263,6 +263,7 @@ PrefsDlg(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
adjustForChoice( hDlg, pState ); adjustForChoice( hDlg, pState );
ceDlgSetup( globals, hDlg ); ceDlgSetup( globals, hDlg );
trapBackspaceKey( hDlg );
return TRUE; return TRUE;
@ -276,7 +277,14 @@ PrefsDlg(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
case WM_VSCROLL: case WM_VSCROLL:
ceDoDlgScroll( globals, hDlg, wParam ); ceDoDlgScroll( globals, hDlg, wParam );
break; break;
#ifdef _WIN32_WCE
case WM_HOTKEY:
if ( VK_TBACK == HIWORD(lParam) ) {
SHSendBackToFocusWindow( message, wParam, lParam );
return TRUE;
}
break;
#endif
case WM_NEXTDLGCTL: case WM_NEXTDLGCTL:
ceDoDlgFocusScroll( globals, hDlg, wParam, lParam ); ceDoDlgFocusScroll( globals, hDlg, wParam, lParam );
break; break;

View file

@ -20,11 +20,13 @@
#include <windowsx.h> #include <windowsx.h>
#include "stdafx.h" #include "stdafx.h"
#include <commdlg.h> #include <commdlg.h>
#include <aygshell.h>
#include "cemain.h" #include "cemain.h"
#include "cesvdgms.h" #include "cesvdgms.h"
#include "ceutil.h" #include "ceutil.h"
#include "cedebug.h" #include "cedebug.h"
#include "debhacks.h"
typedef struct CeSaveGameNameState { typedef struct CeSaveGameNameState {
CEAppGlobals* globals; CEAppGlobals* globals;
@ -82,6 +84,7 @@ SaveNameDlg( HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam )
state->inited = XP_FALSE; state->inited = XP_FALSE;
ceDlgSetup( state->globals, hDlg ); ceDlgSetup( state->globals, hDlg );
trapBackspaceKey( hDlg );
result = TRUE; result = TRUE;
} else { } else {
@ -93,6 +96,14 @@ SaveNameDlg( HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam )
} }
switch (message) { switch (message) {
#ifdef _WIN32_WCE
case WM_HOTKEY:
if ( VK_TBACK == HIWORD(lParam) ) {
SHSendBackToFocusWindow( message, wParam, lParam );
result = TRUE;
}
break;
#endif
case WM_COMMAND: case WM_COMMAND:
wid = LOWORD(wParam); wid = LOWORD(wParam);
switch( wid ) { switch( wid ) {

View file

@ -23,6 +23,7 @@
#include "ceutil.h" #include "ceutil.h"
#include "cedefines.h" #include "cedefines.h"
#include "cedebug.h" #include "cedebug.h"
#include "debhacks.h"
#define BUF_SIZE 128 #define BUF_SIZE 128
#define VPADDING 4 #define VPADDING 4
@ -119,8 +120,10 @@ ceGetDlgItemNum( HWND hDlg, XP_U16 id )
void void
ce_selectAndShow( HWND hDlg, XP_U16 resID, XP_U16 index ) ce_selectAndShow( HWND hDlg, XP_U16 resID, XP_U16 index )
{ {
SendDlgItemMessage( hDlg, resID, LB_SETCURSEL, index, 0 ); SendDlgItemMessage( hDlg, resID, SETCURSEL, index, 0 );
#ifdef _WIN32_WCE
SendDlgItemMessage( hDlg, resID, LB_SETANCHORINDEX, index, 0 ); SendDlgItemMessage( hDlg, resID, LB_SETANCHORINDEX, index, 0 );
#endif
} /* ce_selectAndShow */ } /* ce_selectAndShow */
void void
@ -670,3 +673,14 @@ ceSetLeftSoftkey( CEAppGlobals* globals, XP_U16 newId )
#endif #endif
} }
} /* ceSetLeftSoftkey */ } /* ceSetLeftSoftkey */
#ifdef _WIN32_WCE
void
trapBackspaceKey( HWND hDlg )
{
/* Override back key so we can pass it to edit controls */
SendMessage( SHFindMenuBar(hDlg), SHCMBM_OVERRIDEKEY, VK_TBACK,
MAKELPARAM (SHMBOF_NODEFAULT | SHMBOF_NOTIFY,
SHMBOF_NODEFAULT | SHMBOF_NOTIFY));
}
#endif

View file

@ -55,8 +55,11 @@ void ceDoDlgFocusScroll( CEAppGlobals* globals, HWND hDlg,
WPARAM wParam, LPARAM lParam ); WPARAM wParam, LPARAM lParam );
#ifdef _WIN32_WCE #ifdef _WIN32_WCE
void ceSizeIfFullscreen( CEAppGlobals* globals, HWND hWnd ); void ceSizeIfFullscreen( CEAppGlobals* globals, HWND hWnd );
void trapBackspaceKey( HWND hDlg );
#else #else
# define ceSizeIfFullscreen( globals, hWnd ) # define ceSizeIfFullscreen( globals, hWnd )
# define trapBackspaceKey( hDlg )
#endif #endif
#endif #endif

View file

@ -67,6 +67,18 @@ BOOL DH(ResetEvent)(HANDLE);
#endif /* USE_RAW_MINGW */ #endif /* USE_RAW_MINGW */
#ifdef _WIN32_WCE
/* from http://forums.microsoft.com/MSDN/ShowPost.aspx?PostID=1733046&SiteID=1 */
# define SHMBOF_NODEFAULT 0x00000001 // do not do default handling of this key
# define SHMBOF_NOTIFY 0x00000002 // send us the WM_* messages for this key
# define SHCMBM_OVERRIDEKEY (WM_USER + 403)
# define VK_TBACK VK_ESCAPE
#endif
#if 0 #if 0
/* http://forums.microsoft.com/MSDN/ShowPost.aspx?PostID=1591512&SiteID=1 */ /* http://forums.microsoft.com/MSDN/ShowPost.aspx?PostID=1591512&SiteID=1 */
#define IM_SPELL 0 #define IM_SPELL 0

View file

@ -81,7 +81,6 @@
#define IDC_PICKMSG 1053 #define IDC_PICKMSG 1053
#ifdef FEATURE_TRAY_EDIT #ifdef FEATURE_TRAY_EDIT
# define IDC_CPICK 1054 # define IDC_CPICK 1054
# define IDC_PICKALL 1055
# define IDC_BACKUP 1056 # define IDC_BACKUP 1056
#endif #endif
#ifdef XWFEATURE_SEARCHLIMIT #ifdef XWFEATURE_SEARCHLIMIT
@ -171,6 +170,7 @@
#define IDC_NPLAYERSUPDOWN 1115 #define IDC_NPLAYERSUPDOWN 1115
#define IDC_PHONIESUPDOWN 1116 #define IDC_PHONIESUPDOWN 1116
#define IDC_SVGM_UPDOWN 1117 #define IDC_SVGM_UPDOWN 1117
#define IDC_ASKBLANK_UPDOWN 1124
#define IDC_SVGM_SELLAB 1118 #define IDC_SVGM_SELLAB 1118
@ -231,17 +231,13 @@
#define IDS_OK 40005 #define IDS_OK 40005
#define IDS_ABOUT 40006 #define IDS_ABOUT 40006
// Don't use the numbers after 4009: one string needs not to be there
// to stop the progression in cedict.c
#define IDS_DICTDIRS 40009
// Next default values for new objects // Next default values for new objects
// //
#ifdef APSTUDIO_INVOKED #ifdef APSTUDIO_INVOKED
#ifndef APSTUDIO_READONLY_SYMBOLS #ifndef APSTUDIO_READONLY_SYMBOLS
#define _APS_NEXT_RESOURCE_VALUE 125 #define _APS_NEXT_RESOURCE_VALUE 125
#define _APS_NEXT_COMMAND_VALUE 40029 #define _APS_NEXT_COMMAND_VALUE 40029
#define _APS_NEXT_CONTROL_VALUE 1124 #define _APS_NEXT_CONTROL_VALUE 1125
#define _APS_NEXT_SYMED_VALUE 101 #define _APS_NEXT_SYMED_VALUE 101
#endif #endif
#endif #endif

View file

@ -343,23 +343,33 @@ BEGIN
#endif #endif
END END
IDD_ASKBLANK DIALOG DISCARDABLE 0, 0, 131, 90 IDD_ASKBLANK DIALOG DISCARDABLE 0, 0, 80, 90
STYLE DS_MODALFRAME | WS_POPUP | WS_CAPTION | DS_CENTER STYLE DS_MODALFRAME | WS_POPUP | WS_CAPTION | DS_CENTER
CAPTION "Tile picker" CAPTION "Tile picker"
FONT 8, "System" FONT 8, "System"
BEGIN BEGIN
DEFPUSHBUTTON "OK",IDOK,70,70,20,14 LTEXT "Enter a letter for this blank tile.",IDC_BPICK,8,8,50,18
LTEXT "Enter a letter for this blank tile.",IDC_BPICK,8,8,63,18
#ifdef FEATURE_TRAY_EDIT #ifdef FEATURE_TRAY_EDIT
PUSHBUTTON "Pick all!",IDC_PICKALL,8,70,39,14 LTEXT "Pick a tile for your tray.",IDC_CPICK,8,8,50,18
PUSHBUTTON "Del",IDC_BACKUP,48,70,18,14 PUSHBUTTON "Put back",IDC_BACKUP,8,70,28,14
LTEXT "Pick a tile for your tray.",IDC_CPICK,8,8,63,18
EDITTEXT IDC_PICKMSG,8,28,80,30,ES_MULTILINE | ES_READONLY EDITTEXT IDC_PICKMSG,8,28,80,30,ES_MULTILINE | ES_READONLY
#endif #endif
LISTBOX BLANKFACE_LIST,100,5,25,83,LBS_NOINTEGRALHEIGHT |
WS_VSCROLL | WS_TABSTOP #ifdef _WIN32_WCE
LISTBOX BLANKFACE_LIST,65,8,25,12,WS_TABSTOP
CONTROL "", IDC_ASKBLANK_UPDOWN, UPDOWN_CLASS,
UDS_AUTOBUDDY | UDS_HORZ | UDS_ALIGNRIGHT | UDS_WRAP |
UDS_SETBUDDYINT | UDS_EXPANDABLE | UDS_NOSCROLL,
0, 0, 0, 0
#else
COMBOBOX BLANKFACE_LIST,60,5,25,12,
CBS_DROPDOWNLIST | WS_VSCROLL | WS_TABSTOP
DEFPUSHBUTTON "OK",IDOK,70,70,REPOS_BUTTON_WIDTH, BUTTON_HT
PUSHBUTTON "Cancel",IDCANCEL,20,70,REPOS_BUTTON_WIDTH, BUTTON_HT
#endif
END END
#define SVGN_LEFT_COL 2 #define SVGN_LEFT_COL 2
@ -843,19 +853,12 @@ BEGIN
IDS_DUMMY "--" IDS_DUMMY "--"
IDS_CANCEL "Cancel" IDS_CANCEL "Cancel"
IDS_OK "Ok" IDS_OK "Ok"
IDS_ABOUT "Crosswords 4.2b2 (rev " SVN_REV ") "\ IDS_ABOUT "Crosswords 4.2b3 (rev " SVN_REV ") "\
"for PocketPC. Copyright 1998-2008 by "\ "for PocketPC. Copyright 1998-2008 by "\
"Eric House. This software is released under the GNU "\ "Eric House. This software is released under the GNU "\
"Public License.\r\r"\ "Public License.\r\r"\
"For dictionaries, a manual, or source code go to "\ "For dictionaries, a manual, or source code go to "\
"http://xwords.sf.net or http://eehouse.org/xwords/." "http://xwords.sf.net or http://eehouse.org/xwords/."
#ifdef _WIN32_WCE
IDS_DICTDIRS "\\Program Files\\Crosswords"
IDS_DICTDIRS+1 "\\SD Card\\Crosswords"
IDS_DICTDIRS+2 "\\Storage Card\\Crosswords"
#else
IDS_DICTDIRS "."
#endif
END END
#endif // English (U.S.) resources #endif // English (U.S.) resources