mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-17 18:12:01 +01:00
fix major leakage by closing one game before opening another.
This commit is contained in:
parent
be219b71f2
commit
3859e84c52
1 changed files with 14 additions and 14 deletions
|
@ -144,6 +144,7 @@ static XP_Bool ceMsgFromStream( CEAppGlobals* globals, XWStreamCtxt* stream,
|
||||||
static void RECTtoXPR( XP_Rect* dest, const RECT* src );
|
static void RECTtoXPR( XP_Rect* dest, const RECT* src );
|
||||||
static XP_Bool ceDoNewGame( CEAppGlobals* globals );
|
static XP_Bool ceDoNewGame( CEAppGlobals* globals );
|
||||||
static XP_Bool ceSaveCurGame( CEAppGlobals* globals, XP_Bool autoSave );
|
static XP_Bool ceSaveCurGame( CEAppGlobals* globals, XP_Bool autoSave );
|
||||||
|
static void closeGame( CEAppGlobals* globals );
|
||||||
static void ceInitPrefs( CEAppGlobals* globals, CEAppPrefs* prefs );
|
static void ceInitPrefs( CEAppGlobals* globals, CEAppPrefs* prefs );
|
||||||
static void updateForColors( CEAppGlobals* globals );
|
static void updateForColors( CEAppGlobals* globals );
|
||||||
static XWStreamCtxt* make_generic_stream( CEAppGlobals* globals );
|
static XWStreamCtxt* make_generic_stream( CEAppGlobals* globals );
|
||||||
|
@ -1475,10 +1476,7 @@ ceChooseAndOpen( CEAppGlobals* globals )
|
||||||
} else if ( ceSaveCurGame( globals, XP_FALSE )
|
} else if ( ceSaveCurGame( globals, XP_FALSE )
|
||||||
|| queryBoxChar( globals, "Do you really want to "
|
|| queryBoxChar( globals, "Do you really want to "
|
||||||
"overwrite the current game?" ) ) {
|
"overwrite the current game?" ) ) {
|
||||||
|
closeGame( globals );
|
||||||
if ( globals->curGameName != NULL ) {
|
|
||||||
XP_FREE( globals->mpool, globals->curGameName );
|
|
||||||
}
|
|
||||||
|
|
||||||
globals->curGameName = name;
|
globals->curGameName = name;
|
||||||
if ( ceLoadSavedGame( globals ) ) {
|
if ( ceLoadSavedGame( globals ) ) {
|
||||||
|
@ -1662,6 +1660,17 @@ ceConfirmAndSave( CEAppGlobals* globals )
|
||||||
return confirmed;
|
return confirmed;
|
||||||
} /* ceConfirmAndSave */
|
} /* ceConfirmAndSave */
|
||||||
|
|
||||||
|
static void
|
||||||
|
closeGame( CEAppGlobals* globals )
|
||||||
|
{
|
||||||
|
game_dispose( &globals->game );
|
||||||
|
gi_disposePlayerInfo( MPPARM(globals->mpool) &globals->gameInfo );
|
||||||
|
|
||||||
|
if ( globals->curGameName ) {
|
||||||
|
XP_FREE( globals->mpool, globals->curGameName );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
freeGlobals( CEAppGlobals* globals )
|
freeGlobals( CEAppGlobals* globals )
|
||||||
{
|
{
|
||||||
|
@ -1671,12 +1680,7 @@ freeGlobals( CEAppGlobals* globals )
|
||||||
|
|
||||||
draw_destroyCtxt( globals->draw );
|
draw_destroyCtxt( globals->draw );
|
||||||
|
|
||||||
game_dispose( &globals->game );
|
closeGame( globals );
|
||||||
gi_disposePlayerInfo( MPPARM(mpool) &globals->gameInfo );
|
|
||||||
|
|
||||||
if ( globals->curGameName ) {
|
|
||||||
XP_FREE( mpool, globals->curGameName );
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( !!globals->vtMgr ) {
|
if ( !!globals->vtMgr ) {
|
||||||
vtmgr_destroy( MPPARM(mpool) globals->vtMgr );
|
vtmgr_destroy( MPPARM(mpool) globals->vtMgr );
|
||||||
|
@ -2459,7 +2463,6 @@ makeTimeStamp( XP_UCHAR* timeStamp, XP_U16 XP_UNUSED_DBG(size) )
|
||||||
void
|
void
|
||||||
wince_warnf(const XP_UCHAR* format, ...)
|
wince_warnf(const XP_UCHAR* format, ...)
|
||||||
{
|
{
|
||||||
#if 1
|
|
||||||
XP_UCHAR buf[256];
|
XP_UCHAR buf[256];
|
||||||
va_list ap;
|
va_list ap;
|
||||||
XP_U16 slen;
|
XP_U16 slen;
|
||||||
|
@ -2475,9 +2478,6 @@ wince_warnf(const XP_UCHAR* format, ...)
|
||||||
widebuf, slen );
|
widebuf, slen );
|
||||||
|
|
||||||
MessageBox( NULL, widebuf, L"WARNF", MB_OK );
|
MessageBox( NULL, widebuf, L"WARNF", MB_OK );
|
||||||
#else
|
|
||||||
MessageBox( NULL, L"warnf", L"WARNF", MB_OK );
|
|
||||||
#endif
|
|
||||||
} /* wince_warnf */
|
} /* wince_warnf */
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|
Loading…
Reference in a new issue