mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-22 07:28:16 +01:00
snapshot: using alert() and confirm()
This commit is contained in:
parent
3c791b0f3c
commit
656f433d57
7 changed files with 300 additions and 40 deletions
BIN
xwords4/wasm/assets_dir/ic_downarrow.png
Normal file
BIN
xwords4/wasm/assets_dir/ic_downarrow.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 955 B |
BIN
xwords4/wasm/assets_dir/ic_origin.png
Normal file
BIN
xwords4/wasm/assets_dir/ic_origin.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.7 KiB |
BIN
xwords4/wasm/assets_dir/ic_rightarrow.png
Normal file
BIN
xwords4/wasm/assets_dir/ic_rightarrow.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 1,011 B |
|
@ -36,21 +36,29 @@
|
||||||
EM_JS(bool, call_confirm, (const char* str), {
|
EM_JS(bool, call_confirm, (const char* str), {
|
||||||
return confirm(UTF8ToString(str));
|
return confirm(UTF8ToString(str));
|
||||||
});
|
});
|
||||||
|
EM_JS(void, call_alert, (const char* str), {
|
||||||
|
alert(UTF8ToString(str));
|
||||||
|
});
|
||||||
|
|
||||||
static void
|
static void
|
||||||
initGlobals( Globals* globals )
|
initGlobals( Globals* globals )
|
||||||
{
|
{
|
||||||
globals->cp.showBoardArrow = XP_TRUE;
|
globals->cp.showBoardArrow = XP_TRUE;
|
||||||
globals->cp.allowPeek = XP_TRUE;
|
globals->cp.allowPeek = XP_TRUE;
|
||||||
|
globals->cp.showRobotScores = XP_TRUE;
|
||||||
|
globals->cp.sortNewTiles = XP_TRUE;
|
||||||
|
|
||||||
globals->gi.serverRole = SERVER_STANDALONE;
|
globals->gi.serverRole = SERVER_STANDALONE;
|
||||||
|
globals->gi.phoniesAction = PHONIES_WARN;
|
||||||
|
|
||||||
globals->gi.nPlayers = 2;
|
globals->gi.nPlayers = 2;
|
||||||
globals->gi.boardSize = 15;
|
globals->gi.boardSize = 15;
|
||||||
globals->gi.dictName = "myDict";
|
globals->gi.dictName = "myDict";
|
||||||
globals->gi.players[0].name = "Eric";
|
globals->gi.players[0].name = "You";
|
||||||
globals->gi.players[0].isLocal = XP_TRUE;
|
globals->gi.players[0].isLocal = XP_TRUE;
|
||||||
globals->gi.players[1].name = "Kati";
|
globals->gi.players[1].name = "Robot";
|
||||||
globals->gi.players[1].isLocal = XP_TRUE;
|
globals->gi.players[1].isLocal = XP_TRUE;
|
||||||
|
globals->gi.players[1].robotIQ = 99;
|
||||||
|
|
||||||
globals->mpool = mpool_make( "wasm" );
|
globals->mpool = mpool_make( "wasm" );
|
||||||
globals->vtMgr = make_vtablemgr( globals->mpool );
|
globals->vtMgr = make_vtablemgr( globals->mpool );
|
||||||
|
@ -99,20 +107,33 @@ getCurMS()
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static XP_Bool
|
||||||
checkForTimers( Globals* globals )
|
checkForTimers( Globals* globals )
|
||||||
{
|
{
|
||||||
|
XP_Bool draw = XP_FALSE;
|
||||||
time_t now = getCurMS();
|
time_t now = getCurMS();
|
||||||
for ( XWTimerReason why = 0; why < NUM_TIMERS_PLUS_ONE; ++why ) {
|
for ( XWTimerReason why = 0; why < NUM_TIMERS_PLUS_ONE; ++why ) {
|
||||||
TimerState* timer = &globals->timers[why];
|
TimerState* timer = &globals->timers[why];
|
||||||
XWTimerProc proc = timer->proc;
|
XWTimerProc proc = timer->proc;
|
||||||
if ( !!proc && now >= timer->when ) {
|
if ( !!proc && now >= timer->when ) {
|
||||||
timer->proc = NULL;
|
timer->proc = NULL;
|
||||||
XP_LOGFF( "timer fired (why=%d): calling proc", why );
|
|
||||||
(*proc)( timer->closure, NULL, why );
|
(*proc)( timer->closure, NULL, why );
|
||||||
XP_LOGFF( "back from proc" );
|
draw = XP_TRUE; /* just in case */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return draw;
|
||||||
|
}
|
||||||
|
|
||||||
|
static XP_Bool
|
||||||
|
checkForIdle( Globals* globals )
|
||||||
|
{
|
||||||
|
XP_Bool draw = XP_FALSE;
|
||||||
|
IdleProc proc = globals->idleProc;
|
||||||
|
if ( !!proc ) {
|
||||||
|
globals->idleProc = NULL;
|
||||||
|
draw = (*proc)(globals->idleClosure);
|
||||||
|
}
|
||||||
|
return draw;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -134,7 +155,21 @@ main_query( Globals* globals, const XP_UCHAR* query, QueryProc proc, void* closu
|
||||||
(*proc)( closure, ok );
|
(*proc)( closure, ok );
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
void
|
||||||
|
main_alert( Globals* globals, const XP_UCHAR* msg )
|
||||||
|
{
|
||||||
|
call_alert( msg );
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
main_set_idle( Globals* globals, IdleProc proc, void* closure )
|
||||||
|
{
|
||||||
|
XP_ASSERT( !globals->idleProc );
|
||||||
|
globals->idleProc = proc;
|
||||||
|
globals->idleClosure = closure;
|
||||||
|
}
|
||||||
|
|
||||||
|
static XP_Bool
|
||||||
checkForEvent( Globals* globals )
|
checkForEvent( Globals* globals )
|
||||||
{
|
{
|
||||||
XP_Bool handled;
|
XP_Bool handled;
|
||||||
|
@ -165,20 +200,24 @@ checkForEvent( Globals* globals )
|
||||||
}
|
}
|
||||||
|
|
||||||
// XP_LOGFF( "draw: %d", draw );
|
// XP_LOGFF( "draw: %d", draw );
|
||||||
if ( draw ) {
|
return draw;
|
||||||
SDL_RenderClear( globals->renderer );
|
|
||||||
board_draw( globals->game.board, NULL );
|
|
||||||
wasm_draw_render( globals->draw, globals->renderer );
|
|
||||||
SDL_RenderPresent( globals->renderer );
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
looper( void* closure )
|
looper( void* closure )
|
||||||
{
|
{
|
||||||
Globals* globals = (Globals*)closure;
|
Globals* globals = (Globals*)closure;
|
||||||
checkForTimers( globals );
|
XP_Bool draw = checkForTimers( globals );
|
||||||
checkForEvent( globals );
|
draw = checkForIdle( globals ) || draw;
|
||||||
|
draw = checkForEvent( globals ) || draw;
|
||||||
|
|
||||||
|
if ( draw ) {
|
||||||
|
SDL_RenderClear( globals->renderer );
|
||||||
|
board_draw( globals->game.board, NULL );
|
||||||
|
wasm_draw_render( globals->draw, globals->renderer );
|
||||||
|
SDL_RenderPresent( globals->renderer );
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int main( int argc, char** argv )
|
int main( int argc, char** argv )
|
||||||
|
|
|
@ -14,6 +14,7 @@ typedef struct _TimerState {
|
||||||
time_t when;
|
time_t when;
|
||||||
} TimerState;
|
} TimerState;
|
||||||
|
|
||||||
|
typedef XP_Bool (*IdleProc)(void* closure);
|
||||||
|
|
||||||
typedef struct _Globals {
|
typedef struct _Globals {
|
||||||
SDL_Window* window;
|
SDL_Window* window;
|
||||||
|
@ -30,6 +31,9 @@ typedef struct _Globals {
|
||||||
|
|
||||||
TimerState timers[NUM_TIMERS_PLUS_ONE];
|
TimerState timers[NUM_TIMERS_PLUS_ONE];
|
||||||
|
|
||||||
|
IdleProc idleProc;
|
||||||
|
void* idleClosure;
|
||||||
|
|
||||||
MemPoolCtx* mpool;
|
MemPoolCtx* mpool;
|
||||||
} Globals;
|
} Globals;
|
||||||
|
|
||||||
|
@ -37,9 +41,10 @@ void main_set_timer( Globals* globals, XWTimerReason why, XP_U16 when,
|
||||||
XWTimerProc proc, void* closure );
|
XWTimerProc proc, void* closure );
|
||||||
|
|
||||||
typedef void (*QueryProc)(void* closure, XP_Bool confirmed);
|
typedef void (*QueryProc)(void* closure, XP_Bool confirmed);
|
||||||
|
|
||||||
void main_query( Globals* globals, const XP_UCHAR* query,
|
void main_query( Globals* globals, const XP_UCHAR* query,
|
||||||
QueryProc proc, void* closure );
|
QueryProc proc, void* closure );
|
||||||
|
|
||||||
|
void main_set_idle( Globals* globals, IdleProc proc, void* closure );
|
||||||
|
|
||||||
|
void main_alert( Globals* globals, const XP_UCHAR* msg );
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
#include <SDL2/SDL.h>
|
#include <SDL2/SDL.h>
|
||||||
#include <SDL2/SDL_ttf.h>
|
#include <SDL2/SDL_ttf.h>
|
||||||
|
#include <SDL2/SDL_image.h>
|
||||||
|
|
||||||
#include "comtypes.h"
|
#include "comtypes.h"
|
||||||
#include "wasmdraw.h"
|
#include "wasmdraw.h"
|
||||||
|
@ -17,6 +18,10 @@ typedef struct _WasmDrawCtx {
|
||||||
TTF_Font* font36;
|
TTF_Font* font36;
|
||||||
TTF_Font* font48;
|
TTF_Font* font48;
|
||||||
|
|
||||||
|
SDL_Surface* arrowDown;
|
||||||
|
SDL_Surface* arrowRight;
|
||||||
|
SDL_Surface* origin;
|
||||||
|
|
||||||
int trayOwner;
|
int trayOwner;
|
||||||
} WasmDrawCtx;
|
} WasmDrawCtx;
|
||||||
|
|
||||||
|
@ -116,8 +121,8 @@ textInRect( WasmDrawCtx* wdctx, const XP_UCHAR* text, const XP_Rect* rect,
|
||||||
|
|
||||||
int width, height;
|
int width, height;
|
||||||
SDL_QueryTexture( texture, NULL, NULL, &width, &height );
|
SDL_QueryTexture( texture, NULL, NULL, &width, &height );
|
||||||
XP_LOGFF( "have w: %d; h: %d; got w: %d; h: %d",
|
/* XP_LOGFF( "have w: %d; h: %d; got w: %d; h: %d", */
|
||||||
tmpR.width, tmpR.height, width, height );
|
/* tmpR.width, tmpR.height, width, height ); */
|
||||||
tmpR.width = XP_MIN( width, tmpR.width );
|
tmpR.width = XP_MIN( width, tmpR.width );
|
||||||
tmpR.height = XP_MIN( height, tmpR.height );
|
tmpR.height = XP_MIN( height, tmpR.height );
|
||||||
|
|
||||||
|
@ -127,6 +132,16 @@ textInRect( WasmDrawCtx* wdctx, const XP_UCHAR* text, const XP_Rect* rect,
|
||||||
SDL_DestroyTexture( texture );
|
SDL_DestroyTexture( texture );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
imgInRect( WasmDrawCtx* wdctx, SDL_Surface* img, const XP_Rect* rect )
|
||||||
|
{
|
||||||
|
SDL_Texture* texture = SDL_CreateTextureFromSurface( wdctx->renderer, img );
|
||||||
|
SDL_Rect sdlr;
|
||||||
|
rectXPToSDL( &sdlr, rect );
|
||||||
|
SDL_RenderCopy( wdctx->renderer, texture, NULL, &sdlr );
|
||||||
|
SDL_DestroyTexture( texture );
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
drawTile( WasmDrawCtx* wdctx, const XP_UCHAR* face, int val,
|
drawTile( WasmDrawCtx* wdctx, const XP_UCHAR* face, int val,
|
||||||
int owner, const XP_Rect* rect )
|
int owner, const XP_Rect* rect )
|
||||||
|
@ -323,6 +338,9 @@ wasm_draw_drawCell( DrawCtx* dctx, XWEnv xwe, const XP_Rect* rect,
|
||||||
} else {
|
} else {
|
||||||
fillRect( wdctx, rect, sBonusColors[bonus-1] );
|
fillRect( wdctx, rect, sBonusColors[bonus-1] );
|
||||||
}
|
}
|
||||||
|
if ( 0 != (flags & CELL_ISSTAR) ) {
|
||||||
|
imgInRect( wdctx, wdctx->origin, rect );
|
||||||
|
}
|
||||||
} else if ( !!text ) {
|
} else if ( !!text ) {
|
||||||
textInRect( wdctx, text, rect, NULL );
|
textInRect( wdctx, text, rect, NULL );
|
||||||
}
|
}
|
||||||
|
@ -400,10 +418,11 @@ wasm_draw_drawBoardArrow ( DrawCtx* dctx, XWEnv xwe,
|
||||||
XWBonusType bonus, XP_Bool vert,
|
XWBonusType bonus, XP_Bool vert,
|
||||||
HintAtts hintAtts, CellFlags flags )
|
HintAtts hintAtts, CellFlags flags )
|
||||||
{
|
{
|
||||||
LOG_FUNC();
|
|
||||||
WasmDrawCtx* wdctx = (WasmDrawCtx*)dctx;
|
WasmDrawCtx* wdctx = (WasmDrawCtx*)dctx;
|
||||||
const XP_UCHAR* str = vert ? "|" : "-";
|
const XP_UCHAR* str = vert ? "|" : "-";
|
||||||
textInRect( wdctx, str, rect, NULL );
|
SDL_Surface* img = vert ? wdctx->arrowDown : wdctx->arrowRight;
|
||||||
|
|
||||||
|
imgInRect( wdctx, img, rect );
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -453,6 +472,10 @@ wasm_draw_make( MPFORMAL int width, int height )
|
||||||
wdctx->font36 = TTF_OpenFont( "assets_dir/FreeSans.ttf", 36 );
|
wdctx->font36 = TTF_OpenFont( "assets_dir/FreeSans.ttf", 36 );
|
||||||
wdctx->font48 = TTF_OpenFont( "assets_dir/FreeSans.ttf", 48 );
|
wdctx->font48 = TTF_OpenFont( "assets_dir/FreeSans.ttf", 48 );
|
||||||
|
|
||||||
|
wdctx->arrowDown = IMG_Load( "assets_dir/ic_downarrow.png" );
|
||||||
|
wdctx->arrowRight = IMG_Load( "assets_dir/ic_rightarrow.png" );
|
||||||
|
wdctx->origin = IMG_Load( "assets_dir/ic_origin.png" );
|
||||||
|
|
||||||
wdctx->vtable = XP_MALLOC( mpool, sizeof(*wdctx->vtable) );
|
wdctx->vtable = XP_MALLOC( mpool, sizeof(*wdctx->vtable) );
|
||||||
|
|
||||||
SET_VTABLE_ENTRY( wdctx->vtable, draw_clearRect, wasm );
|
SET_VTABLE_ENTRY( wdctx->vtable, draw_clearRect, wasm );
|
||||||
|
|
|
@ -2,6 +2,7 @@
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
#include "comtypes.h"
|
#include "comtypes.h"
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
|
#include "dbgutil.h"
|
||||||
|
|
||||||
typedef struct _WasmUtilCtx {
|
typedef struct _WasmUtilCtx {
|
||||||
XW_UtilCtxt super;
|
XW_UtilCtxt super;
|
||||||
|
@ -44,10 +45,159 @@ wasm_util_getSquareBonus( XW_UtilCtxt* uc, XWEnv xwe, XP_U16 boardSize,
|
||||||
return s_buttsBoard[row][col];
|
return s_buttsBoard[row][col];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const XP_UCHAR*
|
||||||
|
wasm_getErrString( UtilErrID id, XP_Bool* silent )
|
||||||
|
{
|
||||||
|
*silent = XP_FALSE;
|
||||||
|
const char* message = NULL;
|
||||||
|
|
||||||
|
switch( (int)id ) {
|
||||||
|
case ERR_TILES_NOT_IN_LINE:
|
||||||
|
message = "All tiles played must be in a line.";
|
||||||
|
break;
|
||||||
|
case ERR_NO_EMPTIES_IN_TURN:
|
||||||
|
message = "Empty squares cannot separate tiles played.";
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ERR_TOO_FEW_TILES_LEFT_TO_TRADE:
|
||||||
|
message = "Too few tiles left to trade.";
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ERR_TWO_TILES_FIRST_MOVE:
|
||||||
|
message = "Must play two or more pieces on the first move.";
|
||||||
|
break;
|
||||||
|
case ERR_TILES_MUST_CONTACT:
|
||||||
|
message = "New pieces must contact others already in place (or "
|
||||||
|
"the middle square on the first move).";
|
||||||
|
break;
|
||||||
|
case ERR_NOT_YOUR_TURN:
|
||||||
|
message = "You can't do that; it's not your turn!";
|
||||||
|
break;
|
||||||
|
case ERR_NO_PEEK_ROBOT_TILES:
|
||||||
|
message = "No peeking at the robot's tiles!";
|
||||||
|
break;
|
||||||
|
|
||||||
|
#ifndef XWFEATURE_STANDALONE_ONLY
|
||||||
|
case ERR_NO_PEEK_REMOTE_TILES:
|
||||||
|
message = "No peeking at remote players' tiles!";
|
||||||
|
break;
|
||||||
|
case ERR_REG_UNEXPECTED_USER:
|
||||||
|
message = "Refused attempt to register unexpected user[s].";
|
||||||
|
break;
|
||||||
|
case ERR_SERVER_DICT_WINS:
|
||||||
|
message = "Conflict between Host and Guest dictionaries; Host wins.";
|
||||||
|
XP_WARNF( "GTK may have problems here." );
|
||||||
|
break;
|
||||||
|
case ERR_REG_SERVER_SANS_REMOTE:
|
||||||
|
message = "At least one player must be marked remote for a game "
|
||||||
|
"started as Host.";
|
||||||
|
break;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
case ERR_NO_EMPTY_TRADE:
|
||||||
|
message = "No tiles selected; trade cancelled.";
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ERR_TOO_MANY_TRADE:
|
||||||
|
message = "More tiles selected than remain in pool.";
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ERR_NO_HINT_FOUND:
|
||||||
|
message = "Unable to suggest any moves.";
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ERR_CANT_UNDO_TILEASSIGN:
|
||||||
|
message = "Tile assignment can't be undone.";
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ERR_CANT_HINT_WHILE_DISABLED:
|
||||||
|
message = "The hint feature is disabled for this game. Enable "
|
||||||
|
"it for a new game using the Preferences dialog.";
|
||||||
|
break;
|
||||||
|
|
||||||
|
/* case INFO_REMOTE_CONNECTED: */
|
||||||
|
/* message = "Another device has joined the game"; */
|
||||||
|
/* break; */
|
||||||
|
|
||||||
|
case ERR_RELAY_BASE + XWRELAY_ERROR_LOST_OTHER:
|
||||||
|
*silent = XP_TRUE;
|
||||||
|
message = "XWRELAY_ERROR_LOST_OTHER";
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ERR_RELAY_BASE + XWRELAY_ERROR_TIMEOUT:
|
||||||
|
message = "The relay timed you out; other players "
|
||||||
|
"have left or never showed up.";
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ERR_RELAY_BASE + XWRELAY_ERROR_HEART_YOU:
|
||||||
|
message = "You were disconnected from relay because it didn't "
|
||||||
|
"hear from you in too long.";
|
||||||
|
break;
|
||||||
|
case ERR_RELAY_BASE + XWRELAY_ERROR_HEART_OTHER:
|
||||||
|
/* *silent = XP_TRUE; */
|
||||||
|
message = "The relay has lost contact with a device in this game.";
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ERR_RELAY_BASE + XWRELAY_ERROR_OLDFLAGS:
|
||||||
|
message = "You need to upgrade your copy of Crosswords.";
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ERR_RELAY_BASE + XWRELAY_ERROR_SHUTDOWN:
|
||||||
|
message = "Relay disconnected you to shut down (and probably reboot).";
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ERR_RELAY_BASE + XWRELAY_ERROR_BADPROTO:
|
||||||
|
message = "XWRELAY_ERROR_BADPROTO";
|
||||||
|
break;
|
||||||
|
case ERR_RELAY_BASE + XWRELAY_ERROR_RELAYBUSY:
|
||||||
|
message = "XWRELAY_ERROR_RELAYBUSY";
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ERR_RELAY_BASE + XWRELAY_ERROR_OTHER_DISCON:
|
||||||
|
*silent = XP_TRUE; /* happens all the time, and shouldn't matter */
|
||||||
|
message = "XWRELAY_ERROR_OTHER_DISCON";
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ERR_RELAY_BASE + XWRELAY_ERROR_NO_ROOM:
|
||||||
|
message = "No such room. Has the host connected yet to reserve it?";
|
||||||
|
break;
|
||||||
|
case ERR_RELAY_BASE + XWRELAY_ERROR_DUP_ROOM:
|
||||||
|
message = "That room is reserved by another host. Rename your room, "
|
||||||
|
"become a guest, or try again in a few minutes.";
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ERR_RELAY_BASE + XWRELAY_ERROR_TOO_MANY:
|
||||||
|
message = "You tried to supply more players than the host expected.";
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ERR_RELAY_BASE + XWRELAY_ERROR_DELETED:
|
||||||
|
message = "Game deleted .";
|
||||||
|
break;
|
||||||
|
case ERR_RELAY_BASE + XWRELAY_ERROR_NORECONN:
|
||||||
|
message = "Cannot reconnect.";
|
||||||
|
break;
|
||||||
|
case ERR_RELAY_BASE + XWRELAY_ERROR_DEADGAME:
|
||||||
|
message = "Game is listed as dead on relay.";
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
XP_LOGF( "no code for error: %d", id );
|
||||||
|
message = "<unrecognized error code reported>";
|
||||||
|
}
|
||||||
|
|
||||||
|
return (XP_UCHAR*)message;
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
wasm_util_userError( XW_UtilCtxt* uc, XWEnv xwe, UtilErrID id )
|
wasm_util_userError( XW_UtilCtxt* uc, XWEnv xwe, UtilErrID id )
|
||||||
{
|
{
|
||||||
LOG_FUNC();
|
WasmUtilCtx* wuctxt = (WasmUtilCtx*)uc;
|
||||||
|
Globals* globals = (Globals*)wuctxt->closure;
|
||||||
|
XP_Bool silent;
|
||||||
|
const XP_UCHAR* str = wasm_getErrString( id, &silent );
|
||||||
|
if ( !silent ) {
|
||||||
|
main_alert( globals, str );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -81,6 +231,7 @@ wasm_util_notifyTrade( XW_UtilCtxt* uc, XWEnv xwe, const XP_UCHAR** tiles,
|
||||||
{
|
{
|
||||||
LOG_FUNC();
|
LOG_FUNC();
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
wasm_util_notifyPickTileBlank( XW_UtilCtxt* uc, XWEnv xwe, XP_U16 playerNum,
|
wasm_util_notifyPickTileBlank( XW_UtilCtxt* uc, XWEnv xwe, XP_U16 playerNum,
|
||||||
XP_U16 col, XP_U16 row,
|
XP_U16 col, XP_U16 row,
|
||||||
|
@ -138,7 +289,15 @@ static void
|
||||||
wasm_util_informMove( XW_UtilCtxt* uc, XWEnv xwe, XP_S16 turn,
|
wasm_util_informMove( XW_UtilCtxt* uc, XWEnv xwe, XP_S16 turn,
|
||||||
XWStreamCtxt* expl, XWStreamCtxt* words )
|
XWStreamCtxt* expl, XWStreamCtxt* words )
|
||||||
{
|
{
|
||||||
LOG_FUNC();
|
XWStreamCtxt* useMe = expl; /*!!words ? words : expl;*/
|
||||||
|
XP_U16 len = stream_getSize( useMe );
|
||||||
|
XP_UCHAR buf[len+1];
|
||||||
|
stream_getBytes( useMe, buf, len );
|
||||||
|
buf[len] = '\0';
|
||||||
|
|
||||||
|
WasmUtilCtx* wuctxt = (WasmUtilCtx*)uc;
|
||||||
|
Globals* globals = (Globals*)wuctxt->closure;
|
||||||
|
main_alert( globals, buf );
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -160,13 +319,16 @@ wasm_util_informNetDict( XW_UtilCtxt* uc, XWEnv xwe, XP_LangCode lang,
|
||||||
static void
|
static void
|
||||||
wasm_util_notifyGameOver( XW_UtilCtxt* uc, XWEnv xwe, XP_S16 quitter )
|
wasm_util_notifyGameOver( XW_UtilCtxt* uc, XWEnv xwe, XP_S16 quitter )
|
||||||
{
|
{
|
||||||
LOG_FUNC();
|
WasmUtilCtx* wuctxt = (WasmUtilCtx*)uc;
|
||||||
|
Globals* globals = (Globals*)wuctxt->closure;
|
||||||
|
main_alert( globals, "Game over" );
|
||||||
}
|
}
|
||||||
|
|
||||||
static XP_Bool wasm_util_engineProgressCallback( XW_UtilCtxt* uc, XWEnv xwe )
|
static XP_Bool
|
||||||
|
wasm_util_engineProgressCallback( XW_UtilCtxt* uc, XWEnv xwe )
|
||||||
{
|
{
|
||||||
LOG_FUNC();
|
// LOG_RETURN_VOID();
|
||||||
return XP_FALSE;
|
return XP_TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -186,10 +348,20 @@ wasm_util_clearTimer( XW_UtilCtxt* uc, XWEnv xwe, XWTimerReason why )
|
||||||
LOG_FUNC();
|
LOG_FUNC();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static XP_Bool
|
||||||
|
on_idle( void* closure )
|
||||||
|
{
|
||||||
|
WasmUtilCtx* wuctxt = (WasmUtilCtx*)closure;
|
||||||
|
Globals* globals = (Globals*)wuctxt->closure;
|
||||||
|
return server_do( globals->game.server, NULL );
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
wasm_util_requestTime( XW_UtilCtxt* uc, XWEnv xwe )
|
wasm_util_requestTime( XW_UtilCtxt* uc, XWEnv xwe )
|
||||||
{
|
{
|
||||||
LOG_FUNC();
|
WasmUtilCtx* wuctxt = (WasmUtilCtx*)uc;
|
||||||
|
Globals* globals = (Globals*)wuctxt->closure;
|
||||||
|
main_set_idle( globals, on_idle, wuctxt );
|
||||||
}
|
}
|
||||||
|
|
||||||
static XP_Bool
|
static XP_Bool
|
||||||
|
@ -210,18 +382,36 @@ static void
|
||||||
wasm_util_notifyIllegalWords( XW_UtilCtxt* uc, XWEnv xwe, BadWordInfo* bwi,
|
wasm_util_notifyIllegalWords( XW_UtilCtxt* uc, XWEnv xwe, BadWordInfo* bwi,
|
||||||
XP_U16 turn, XP_Bool turnLost )
|
XP_U16 turn, XP_Bool turnLost )
|
||||||
{
|
{
|
||||||
LOG_FUNC();
|
XP_UCHAR words[256];
|
||||||
|
int offset = 0;
|
||||||
|
|
||||||
|
for ( int ii = 0; ; ) {
|
||||||
|
offset += XP_SNPRINTF( &words[offset], VSIZE(words) - offset, "%s",
|
||||||
|
bwi->words[ii] );
|
||||||
|
if ( ++ii >= bwi->nWords ) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
offset += XP_SNPRINTF( &words[offset], VSIZE(words) - offset, ", " );
|
||||||
|
}
|
||||||
|
|
||||||
|
XP_UCHAR buf[256];
|
||||||
|
XP_SNPRINTF( buf, VSIZE(buf), "Word[s] \"%s\" not in the current "
|
||||||
|
"dictionary (%s). Use anyway?", words, bwi->dictName );
|
||||||
|
|
||||||
|
WasmUtilCtx* wuctxt = (WasmUtilCtx*)uc;
|
||||||
|
Globals* globals = (Globals*)wuctxt->closure;
|
||||||
|
main_query( globals, buf, query_proc_notifyMove, uc );
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
wasm_util_remSelected(XW_UtilCtxt* uc, XWEnv xwe)
|
wasm_util_remSelected( XW_UtilCtxt* uc, XWEnv xwe )
|
||||||
{
|
{
|
||||||
LOG_FUNC();
|
LOG_FUNC();
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
wasm_util_timerSelected(XW_UtilCtxt* uc, XWEnv xwe, XP_Bool inDuplicateMode,
|
wasm_util_timerSelected( XW_UtilCtxt* uc, XWEnv xwe, XP_Bool inDuplicateMode,
|
||||||
XP_Bool canPause)
|
XP_Bool canPause )
|
||||||
{
|
{
|
||||||
LOG_FUNC();
|
LOG_FUNC();
|
||||||
}
|
}
|
||||||
|
@ -317,7 +507,6 @@ wasm_util_make( MPFORMAL CurGameInfo* gi, XW_DUtilCtxt* dctxt, void* closure )
|
||||||
SET_VTABLE_ENTRY( wuctxt->super.vtable, util_userError, wasm );
|
SET_VTABLE_ENTRY( wuctxt->super.vtable, util_userError, wasm );
|
||||||
SET_VTABLE_ENTRY( wuctxt->super.vtable, util_makeStreamFromAddr, wasm );
|
SET_VTABLE_ENTRY( wuctxt->super.vtable, util_makeStreamFromAddr, wasm );
|
||||||
SET_VTABLE_ENTRY( wuctxt->super.vtable, util_getSquareBonus, wasm );
|
SET_VTABLE_ENTRY( wuctxt->super.vtable, util_getSquareBonus, wasm );
|
||||||
SET_VTABLE_ENTRY( wuctxt->super.vtable, util_userError, wasm );
|
|
||||||
|
|
||||||
SET_VTABLE_ENTRY( wuctxt->super.vtable, util_notifyMove, wasm );
|
SET_VTABLE_ENTRY( wuctxt->super.vtable, util_notifyMove, wasm );
|
||||||
SET_VTABLE_ENTRY( wuctxt->super.vtable, util_notifyTrade, wasm );
|
SET_VTABLE_ENTRY( wuctxt->super.vtable, util_notifyTrade, wasm );
|
||||||
|
@ -334,6 +523,7 @@ wasm_util_make( MPFORMAL CurGameInfo* gi, XW_DUtilCtxt* dctxt, void* closure )
|
||||||
SET_VTABLE_ENTRY( wuctxt->super.vtable, util_informUndo, wasm );
|
SET_VTABLE_ENTRY( wuctxt->super.vtable, util_informUndo, wasm );
|
||||||
SET_VTABLE_ENTRY( wuctxt->super.vtable, util_informNetDict, wasm );
|
SET_VTABLE_ENTRY( wuctxt->super.vtable, util_informNetDict, wasm );
|
||||||
SET_VTABLE_ENTRY( wuctxt->super.vtable, util_notifyGameOver, wasm );
|
SET_VTABLE_ENTRY( wuctxt->super.vtable, util_notifyGameOver, wasm );
|
||||||
|
SET_VTABLE_ENTRY( wuctxt->super.vtable, util_engineProgressCallback, wasm );
|
||||||
#ifdef XWFEATURE_HILITECELL
|
#ifdef XWFEATURE_HILITECELL
|
||||||
SET_VTABLE_ENTRY( wuctxt->super.vtable, util_hiliteCell, wasm );
|
SET_VTABLE_ENTRY( wuctxt->super.vtable, util_hiliteCell, wasm );
|
||||||
#endif
|
#endif
|
||||||
|
@ -359,6 +549,9 @@ wasm_util_make( MPFORMAL CurGameInfo* gi, XW_DUtilCtxt* dctxt, void* closure )
|
||||||
SET_VTABLE_ENTRY( wuctxt->super.vtable, util_showChat, wasm );
|
SET_VTABLE_ENTRY( wuctxt->super.vtable, util_showChat, wasm );
|
||||||
SET_VTABLE_ENTRY( wuctxt->super.vtable, util_getDevUtilCtxt, wasm );
|
SET_VTABLE_ENTRY( wuctxt->super.vtable, util_getDevUtilCtxt, wasm );
|
||||||
|
|
||||||
|
size_t sizeInBytes = sizeof(*wuctxt->super.vtable);
|
||||||
|
assertTableFull( wuctxt->super.vtable, sizeInBytes, "wasmutilctx" );
|
||||||
|
|
||||||
LOG_RETURNF( "%p", wuctxt );
|
LOG_RETURNF( "%p", wuctxt );
|
||||||
return (XW_UtilCtxt*)wuctxt;
|
return (XW_UtilCtxt*)wuctxt;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue