mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-07 05:24:46 +01:00
ask for username if not provided
This commit is contained in:
parent
5abf13c4a2
commit
ae4985e518
1 changed files with 30 additions and 7 deletions
|
@ -38,6 +38,7 @@
|
||||||
#include "wasmutil.h"
|
#include "wasmutil.h"
|
||||||
#include "wasmdutil.h"
|
#include "wasmdutil.h"
|
||||||
#include "wasmdict.h"
|
#include "wasmdict.h"
|
||||||
|
#include "wasmasm.h"
|
||||||
|
|
||||||
#ifdef __EMSCRIPTEN__
|
#ifdef __EMSCRIPTEN__
|
||||||
#include <emscripten.h>
|
#include <emscripten.h>
|
||||||
|
@ -52,6 +53,7 @@
|
||||||
#define BDHEIGHT WINDOW_HEIGHT
|
#define BDHEIGHT WINDOW_HEIGHT
|
||||||
|
|
||||||
#define KEY_GAME "the_game"
|
#define KEY_GAME "the_game"
|
||||||
|
#define KEY_PLAYER_NAME "player_name"
|
||||||
#define DICTNAME "assets_dir/CollegeEng_2to8.xwd"
|
#define DICTNAME "assets_dir/CollegeEng_2to8.xwd"
|
||||||
|
|
||||||
#define BUTTON_OK "OK"
|
#define BUTTON_OK "OK"
|
||||||
|
@ -229,7 +231,7 @@ initDeviceGlobals( Globals* globals )
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
startGame( Globals* globals )
|
startGame( Globals* globals, const char* name )
|
||||||
{
|
{
|
||||||
LOG_FUNC();
|
LOG_FUNC();
|
||||||
BoardDims dims;
|
BoardDims dims;
|
||||||
|
@ -243,6 +245,11 @@ startGame( Globals* globals )
|
||||||
model_setDictionary( globals->game.model, NULL, globals->dict );
|
model_setDictionary( globals->game.model, NULL, globals->dict );
|
||||||
|
|
||||||
if ( SERVER_ISCLIENT == globals->gi.serverRole ) {
|
if ( SERVER_ISCLIENT == globals->gi.serverRole ) {
|
||||||
|
if ( !!name ) {
|
||||||
|
replaceStringIfDifferent( globals->mpool,
|
||||||
|
&globals->gi.players[0].name,
|
||||||
|
name );
|
||||||
|
}
|
||||||
server_initClientConnection( globals->game.server, NULL );
|
server_initClientConnection( globals->game.server, NULL );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -260,6 +267,16 @@ typedef struct _AskReplaceState {
|
||||||
NetLaunchInfo invite;
|
NetLaunchInfo invite;
|
||||||
} AskReplaceState;
|
} AskReplaceState;
|
||||||
|
|
||||||
|
static void
|
||||||
|
onPlayerNamed( void* closure, const char* name )
|
||||||
|
{
|
||||||
|
Globals* globals = (Globals*)closure;
|
||||||
|
if ( !!name ) {
|
||||||
|
set_stored_value( KEY_PLAYER_NAME, name );
|
||||||
|
startGame( globals, name );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
onReplaceConfirmed( void* closure, bool confirmed )
|
onReplaceConfirmed( void* closure, bool confirmed )
|
||||||
{
|
{
|
||||||
|
@ -285,7 +302,14 @@ onReplaceConfirmed( void* closure, bool confirmed )
|
||||||
globals->util, globals->draw,
|
globals->util, globals->draw,
|
||||||
&globals->cp, &globals->procs );
|
&globals->cp, &globals->procs );
|
||||||
|
|
||||||
startGame( globals );
|
const char* name = get_stored_value( KEY_PLAYER_NAME );
|
||||||
|
if ( NULL != name ) {
|
||||||
|
startGame( globals, name );
|
||||||
|
free( (void*)name );
|
||||||
|
} else {
|
||||||
|
const char* msg = "Please enter your name so you opponent knows it's you";
|
||||||
|
call_get_string( msg, "Player 1", onPlayerNamed, globals );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
XP_FREE( globals->mpool, ars );
|
XP_FREE( globals->mpool, ars );
|
||||||
|
@ -295,13 +319,12 @@ static bool
|
||||||
gameFromInvite( Globals* globals, const NetLaunchInfo* invite )
|
gameFromInvite( Globals* globals, const NetLaunchInfo* invite )
|
||||||
{
|
{
|
||||||
bool needsLoad = true;
|
bool needsLoad = true;
|
||||||
XP_LOGFF( "model: %p", globals->game.model );
|
|
||||||
if ( NULL != globals->game.model ) {
|
if ( NULL != globals->game.model ) {
|
||||||
XP_LOGFF( "have game: TRUE" );
|
|
||||||
/* there's a current game. Ignore the invitation if it has the same
|
/* there's a current game. Ignore the invitation if it has the same
|
||||||
gameID. Otherwise ask to replace */
|
gameID. Otherwise ask to replace */
|
||||||
if ( globals->gi.gameID == invite->gameID ) {
|
if ( globals->gi.gameID == invite->gameID ) {
|
||||||
XP_LOGFF( "duplicate invite; ignoring" );
|
call_alert( "Duplicate invitation: game already open" );
|
||||||
needsLoad = false;
|
needsLoad = false;
|
||||||
} else {
|
} else {
|
||||||
AskReplaceState* ars = XP_MALLOC( globals->mpool, sizeof(*ars) );
|
AskReplaceState* ars = XP_MALLOC( globals->mpool, sizeof(*ars) );
|
||||||
|
@ -398,14 +421,14 @@ loadAndDraw( Globals* globals, const NetLaunchInfo* invite,
|
||||||
&globals->cp, &globals->procs );
|
&globals->cp, &globals->procs );
|
||||||
}
|
}
|
||||||
|
|
||||||
startGame( globals );
|
startGame( globals, NULL );
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
main_gameFromInvite( Globals* globals, const NetLaunchInfo* invite )
|
main_gameFromInvite( Globals* globals, const NetLaunchInfo* invite )
|
||||||
{
|
{
|
||||||
if ( gameFromInvite( globals, invite ) ) {
|
if ( gameFromInvite( globals, invite ) ) {
|
||||||
startGame( globals );
|
startGame( globals, NULL );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue