rewrite ceLocateNDicts to do recursive searches from a list of

directories stored in resources.  On device this is currently
"\Program Files\Crosswords" and "\SD Card".  (Just "." for win32.)
Later may need to restrict on the card too.  Still to do: make "no
dicts found" Alert list the places searched.
This commit is contained in:
ehouse 2006-04-22 14:05:09 +00:00
parent dc908e52b2
commit d8ab05a04e
6 changed files with 46 additions and 20 deletions

View file

@ -563,11 +563,7 @@ locateOneDir( MPFORMAL wchar_t* path, OnePathCB cb, void* ctxt, XP_U16 nSought,
XP_Bool result = XP_FALSE; XP_Bool result = XP_FALSE;
XP_U16 startLen; XP_U16 startLen;
#if defined TARGET_OS_WINCE
lstrcat( path, L"\\" ); lstrcat( path, L"\\" );
#elif defined TARGET_OS_WIN32
lstrcat( path, L".\\" );
#endif
startLen = wcslen(path); /* record where we were so can back up */ startLen = wcslen(path); /* record where we were so can back up */
lstrcat( path, L"*" ); lstrcat( path, L"*" );
@ -583,14 +579,18 @@ locateOneDir( MPFORMAL wchar_t* path, OnePathCB cb, void* ctxt, XP_U16 nSought,
for ( ; ; ) { for ( ; ; ) {
if ((data.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY) != 0){ if ((data.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY) != 0){
#if defined TARGET_OS_WINCE
/* We don't do recursive search on Win32!!! */ if ( ( data.cFileName[0] == '.' )
&& ( (data.cFileName[1] == '.')
|| (data.cFileName[1] == '\0' ) ) ) {
/* skip . and .. */
} else {
lstrcpy( path+startLen, data.cFileName ); lstrcpy( path+startLen, data.cFileName );
locateOneDir( MPPARM(mpool) path, cb, ctxt, nSought, nFoundP ); locateOneDir( MPPARM(mpool) path, cb, ctxt, nSought, nFoundP );
if ( *nFoundP == nSought ) { if ( *nFoundP == nSought ) {
break; break;
} }
#endif }
} else if ( checkIfDictAndLegal( MPPARM(mpool) path, startLen, } else if ( checkIfDictAndLegal( MPPARM(mpool) path, startLen,
data.cFileName ) ) { data.cFileName ) ) {
XP_U16 len; XP_U16 len;
@ -619,14 +619,27 @@ locateOneDir( MPFORMAL wchar_t* path, OnePathCB cb, void* ctxt, XP_U16 nSought,
} /* locateOneDir */ } /* locateOneDir */
XP_U16 XP_U16
ceLocateNDicts( MPFORMAL XP_U16 nSought, OnePathCB cb, void* ctxt ) ceLocateNDicts( MPFORMAL HINSTANCE hInstance, XP_U16 nSought,
OnePathCB cb, void* ctxt )
{ {
XP_U16 nFound = 0; XP_U16 nFound = 0;
wchar_t pathBuf[CE_MAX_PATH_LEN+1]; UINT id;
pathBuf[0] = 0; for ( id = IDS_DICTDIRS; ; ++id ) {
wchar_t pathBuf[CE_MAX_PATH_LEN+1];
int len = LoadString( hInstance, id, pathBuf, sizeof(pathBuf) );
XP_LOGF( "%s: LoadString => %d", __FUNCTION__, len );
if ( len == 0 ) {
break;
}
locateOneDir( MPPARM(mpool) pathBuf, cb, ctxt, nSought, &nFound ); locateOneDir( MPPARM(mpool) pathBuf, cb, ctxt, nSought, &nFound );
if ( nFound >= nSought ) {
break;
}
}
return nFound; return nFound;
} /* ceLocateNthDict */ } /* ceLocateNthDict */

View file

@ -38,7 +38,8 @@ DictionaryCtxt* ce_dictionary_make_empty( CEAppGlobals* globals );
* making sure bufs contains nSought slots. * making sure bufs contains nSought slots.
*/ */
typedef XP_Bool (*OnePathCB)( const wchar_t* wPath, XP_U16 index, void* ctxt ); typedef XP_Bool (*OnePathCB)( const wchar_t* wPath, XP_U16 index, void* ctxt );
XP_U16 ceLocateNDicts( MPFORMAL XP_U16 nSought, OnePathCB cb, void* ctxt ); XP_U16 ceLocateNDicts( MPFORMAL HINSTANCE hInstance, XP_U16 nSought,
OnePathCB cb, void* ctxt );
XP_UCHAR* bname( XP_UCHAR* in ); XP_UCHAR* bname( XP_UCHAR* in );

View file

@ -211,8 +211,8 @@ 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) 32, addDictToMenu, (void)ceLocateNDicts( MPPARM(globals->mpool) globals->hInst, 32,
giState ); addDictToMenu, giState );
if ( !giState->curSelSet ) { if ( !giState->curSelSet ) {
SendDlgItemMessage( giState->hDlg, IDC_DICTCOMBO, CB_SETCURSEL, SendDlgItemMessage( giState->hDlg, IDC_DICTCOMBO, CB_SETCURSEL,
0, 0L ); 0, 0L );

View file

@ -969,7 +969,8 @@ 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) 1, ceSetDictName, globals ); result = 1 == ceLocateNDicts( MPPARM(mpool) hInstance, 1, ceSetDictName,
globals );
if ( !result ) { if ( !result ) {
messageBoxChar( globals, "Please install at least one Crosswords " messageBoxChar( globals, "Please install at least one Crosswords "
"dictionary.", L"Fatal error" ); "dictionary.", L"Fatal error" );

View file

@ -184,6 +184,10 @@
#define IDS_FILE 40002 #define IDS_FILE 40002
#define IDS_GAME 40003 #define IDS_GAME 40003
#define IDS_MOVE 40004 #define IDS_MOVE 40004
// Don't use the numbers after 4005: one string needs not to be there
// to stop the progression in cedict.c
#define IDS_DICTDIRS 40005
// Next default values for new objects // Next default values for new objects
// //
#ifdef APSTUDIO_INVOKED #ifdef APSTUDIO_INVOKED

View file

@ -249,7 +249,8 @@ BEGIN
EDITTEXT PASS_EDIT4,GAME_PWD_LEFT,PLAYER_ROW_4,20,ROW_HEIGHT, EDITTEXT PASS_EDIT4,GAME_PWD_LEFT,PLAYER_ROW_4,20,ROW_HEIGHT,
ES_PASSWORD | ES_AUTOHSCROLL ES_PASSWORD | ES_AUTOHSCROLL
LTEXT "Dictionary:",IDC_STATIC,LEFT_COL,DICTPICK_ROW,36,8,SS_NOPREFIX LTEXT "Dictionary:",IDC_STATIC,LEFT_COL,DICTPICK_ROW,36,8,
SS_NOPREFIX
COMBOBOX IDC_DICTCOMBO,43,DICTPICK_ROW,85,58, COMBOBOX IDC_DICTCOMBO,43,DICTPICK_ROW,85,58,
CBS_DROPDOWNLIST | WS_VSCROLL | WS_TABSTOP CBS_DROPDOWNLIST | WS_VSCROLL | WS_TABSTOP
@ -662,6 +663,12 @@ BEGIN
IDS_FILE "File" IDS_FILE "File"
IDS_GAME "Game" IDS_GAME "Game"
IDS_MOVE "Move" IDS_MOVE "Move"
#ifdef _WIN32
IDS_DICTDIRS "."
#else
IDS_DICTDIRS "\\Program Files\\Crosswords"
IDS_DICTDIRS+1 "\\SD Card\\Crosswords"
#endif
END END
#endif // English (U.S.) resources #endif // English (U.S.) resources