Alert user of a previous version that dict location is being fixed

This commit is contained in:
ehouse 2006-05-05 12:51:08 +00:00
parent 4c58ee9e2f
commit f4844efd2f
2 changed files with 60 additions and 2 deletions

View file

@ -1,4 +1,4 @@
/* -*- fill-column: 77; c-basic-offset: 4; compile-command: "make TARGET_OS=wince"-*- */ /* -*- fill-column: 77; c-basic-offset: 4; compile-command: "make TARGET_OS=wince DEBUG=TRUE"-*- */
/* /*
* Copyright 2002-2004 by Eric House (xwords@eehouse.org). All rights reserved. * Copyright 2002-2004 by Eric House (xwords@eehouse.org). All rights reserved.
* *
@ -152,6 +152,7 @@ static void ce_send_on_close( XWStreamCtxt* stream, void* closure );
static XP_Bool ceSetDictName( const wchar_t* wPath, XP_U16 index, void* ctxt ); static XP_Bool ceSetDictName( const wchar_t* wPath, XP_U16 index, void* ctxt );
static void messageBoxStream( CEAppGlobals* globals, XWStreamCtxt* stream, static void messageBoxStream( CEAppGlobals* globals, XWStreamCtxt* stream,
wchar_t* title ); wchar_t* title );
static XP_Bool ceQueryFromStream( CEAppGlobals* globals, XWStreamCtxt* stream);
// Forward declarations of functions included in this code module: // Forward declarations of functions included in this code module:
@ -682,6 +683,9 @@ ceSavePrefs( CEAppGlobals* globals )
WriteFile( fileH, &nameLen, sizeof(nameLen), &nWritten, NULL ); WriteFile( fileH, &nameLen, sizeof(nameLen), &nWritten, NULL );
WriteFile( fileH, name, nameLen, &nWritten, NULL ); WriteFile( fileH, name, nameLen, &nWritten, NULL );
WriteFile( fileH, &globals->flags, sizeof(globals->flags), &nWritten,
NULL );
SetEndOfFile( fileH ); /* truncate anything previously there */ SetEndOfFile( fileH ); /* truncate anything previously there */
CloseHandle( fileH ); /* am I not supposed to do this? PENDING */ CloseHandle( fileH ); /* am I not supposed to do this? PENDING */
@ -712,17 +716,27 @@ ceLoadPrefs( CEAppGlobals* globals )
&bytesRead, NULL ) ) { &bytesRead, NULL ) ) {
if ( tmpPrefs.versionFlags == CUR_CE_PREFS_FLAGS ) { if ( tmpPrefs.versionFlags == CUR_CE_PREFS_FLAGS ) {
XP_U16 flags;
XP_MEMCPY( &globals->appPrefs, &tmpPrefs, XP_MEMCPY( &globals->appPrefs, &tmpPrefs,
sizeof(globals->appPrefs) ); sizeof(globals->appPrefs) );
result = XP_TRUE; result = XP_TRUE;
ReadFile( fileH, &nameLen, sizeof(nameLen), &bytesRead, NULL ); ReadFile( fileH, &nameLen, sizeof(nameLen), &bytesRead,
NULL );
name = XP_MALLOC( globals->mpool, nameLen + 1 ); name = XP_MALLOC( globals->mpool, nameLen + 1 );
ReadFile( fileH, name, nameLen, &bytesRead, NULL ); ReadFile( fileH, name, nameLen, &bytesRead, NULL );
name[nameLen] = '\0'; name[nameLen] = '\0';
globals->curGameName = name; globals->curGameName = name;
if ( ReadFile( fileH, &flags, sizeof(flags), &bytesRead,
NULL )
&& bytesRead == sizeof(flags) ) {
} else {
flags = 0;
}
globals->flags = flags;
XP_DEBUGF( "loaded saved name: %s", name ); XP_DEBUGF( "loaded saved name: %s", name );
} }
} }
@ -867,8 +881,42 @@ ceInitPrefs( CEAppGlobals* globals )
globals->appPrefs.cp.showRobotScores = XP_FALSE; globals->appPrefs.cp.showRobotScores = XP_FALSE;
colorsFromRsrc( globals ); colorsFromRsrc( globals );
#ifdef DICTS_MOVED_ALERT
/* The assumption is that if you didn't have prefs already you don't need
to be told to move dicts. */
globals->flags = FLAGS_BIT_SHOWN_NEWDICTLOC;
#endif
} /* ceInitPrefs */ } /* ceInitPrefs */
#ifdef DICTS_MOVED_ALERT
static void
doDictsMovedAlert( CEAppGlobals* globals )
{
XP_Bool hide;
XWStreamCtxt* stream = make_generic_stream( globals );
stream_putString( stream,
"Please be aware that starting with this version "
"Crosswords will not find dictionaries unless they "
"are located in one of these directories: " );
ceFormatDictDirs( stream, globals->hInst );
stream_putString( stream, ". From now on, dictionaries will be "
"available as .cab files which will put them in the "
"right place."
XP_CR
XP_CR
"Do you want to disable this warning?" );
hide = ceMsgFromStream( globals, stream, L"Warning", XP_TRUE, XP_TRUE );
if ( hide ) {
globals->flags |= FLAGS_BIT_SHOWN_NEWDICTLOC;
}
}
#endif
// //
// FUNCTION: InitInstance(HANDLE, int) // FUNCTION: InitInstance(HANDLE, int)
// //
@ -993,6 +1041,10 @@ InitInstance(HINSTANCE hInstance, int nCmdShow)
prevStateExists = ceLoadPrefs( globals ); prevStateExists = ceLoadPrefs( globals );
if ( !prevStateExists ) { if ( !prevStateExists ) {
ceInitPrefs( globals ); ceInitPrefs( globals );
#ifdef DICTS_MOVED_ALERT
} else if ( (globals->flags & FLAGS_BIT_SHOWN_NEWDICTLOC) == 0 ) {
doDictsMovedAlert( globals );
#endif
} }
/* must load prefs before creating draw ctxt */ /* must load prefs before creating draw ctxt */
globals->draw = ce_drawctxt_make( MPPARM(globals->mpool) globals->draw = ce_drawctxt_make( MPPARM(globals->mpool)

View file

@ -85,6 +85,8 @@ typedef struct CEAppGlobals {
TimerProc timerProcs[NUM_TIMERS_PLUS_ONE]; TimerProc timerProcs[NUM_TIMERS_PLUS_ONE];
void* timerClosures[NUM_TIMERS_PLUS_ONE]; void* timerClosures[NUM_TIMERS_PLUS_ONE];
XP_U16 flags; /* bits defined below */
#ifdef CEFEATURE_CANSCROLL #ifdef CEFEATURE_CANSCROLL
XP_U16 nHiddenRows; XP_U16 nHiddenRows;
HWND scrollHandle; HWND scrollHandle;
@ -106,6 +108,10 @@ typedef struct CEAppGlobals {
} CEAppGlobals; } CEAppGlobals;
#ifdef DICTS_MOVED_ALERT
# define FLAGS_BIT_SHOWN_NEWDICTLOC 0x0001
#endif
#define GAME_IN_PROGRESS(g) ((g)->gameInfo.dictName != 0) #define GAME_IN_PROGRESS(g) ((g)->gameInfo.dictName != 0)
enum { enum {