Support new tri-part enabled type; add "game info" dialog/menu to test

read-only side; support new attributes for column head and nplayers
label; hide labels as well as controls that go with them.
This commit is contained in:
ehouse 2006-06-10 05:50:27 +00:00
parent 44abbc4493
commit b80808bc57
5 changed files with 89 additions and 25 deletions

View file

@ -50,6 +50,10 @@ enum {
STRD_TRADED,
STR_LOSTTURN,
STR_LOCALPLAYERS,
STR_TOTALPLAYERS,
STR_REMOTE,
STRS_VALUES_HEADER,
STR_LAST

View file

@ -539,7 +539,7 @@ new_game( GtkWidget* widget, GtkAppGlobals* globals )
{
gboolean confirmed;
confirmed = newGameDialog( globals );
confirmed = newGameDialog( globals, XP_TRUE );
if ( confirmed ) {
CurGameInfo* gi = &globals->cGlobals.params->gi;
XP_Bool isClient = gi->serverRole == SERVER_ISCLIENT;
@ -568,6 +568,16 @@ new_game( GtkWidget* widget, GtkAppGlobals* globals )
} /* new_game */
static void
game_info( GtkWidget* widget, GtkAppGlobals* globals )
{
/* Anything to do if OK is clicked? Changed names etc. already saved. Try
server_do in case one's become a robot. */
if ( newGameDialog( globals, XP_FALSE ) ) {
(void)server_do( globals->cGlobals.game.server ); /* assign tiles, etc. */
}
}
static void
load_game( GtkWidget* widget, GtkAppGlobals* globals )
{
@ -689,6 +699,8 @@ makeMenus( GtkAppGlobals* globals, int argc, char** argv )
(void)createAddItem( fileMenu, "New game",
GTK_SIGNAL_FUNC(new_game), globals );
(void)createAddItem( fileMenu, "Game info",
GTK_SIGNAL_FUNC(game_info), globals );
(void)createAddItem( fileMenu, "Load game",
GTK_SIGNAL_FUNC(load_game), globals );

View file

@ -47,10 +47,13 @@ typedef struct GtkNewGameState {
GtkWidget* remoteChecks[MAX_NUM_PLAYERS];
#endif
GtkWidget* robotChecks[MAX_NUM_PLAYERS];
GtkWidget* nameLabels[MAX_NUM_PLAYERS];
GtkWidget* nameFields[MAX_NUM_PLAYERS];
GtkWidget* passwdLabels[MAX_NUM_PLAYERS];
GtkWidget* passwdFields[MAX_NUM_PLAYERS];
GtkWidget* nPlayersMenu;
GtkWidget* roleMenu;
GtkWidget* nPlayersLabel;
GtkWidget* roleMenuItems[3];
} GtkNewGameState;
@ -199,7 +202,7 @@ makeButton( char* text, GCallback func, gpointer data )
} /* makeButton */
static GtkWidget*
makeNewGameDialog( GtkNewGameState* state )
makeNewGameDialog( GtkNewGameState* state, XP_Bool isNewGame )
{
GtkWidget* dialog;
GtkWidget* vbox;
@ -209,6 +212,7 @@ makeNewGameDialog( GtkNewGameState* state )
GtkWidget* nPlayersMenu;
GtkWidget* boardSizeMenu;
GtkWidget* opt;
GtkWidget* juggleButton;
CurGameInfo* gi;
short i;
char* roles[] = { "Standalone", "Host", "Guest" };
@ -239,8 +243,8 @@ makeNewGameDialog( GtkNewGameState* state )
/* NPlayers menu */
hbox = gtk_hbox_new( FALSE, 0 );
gtk_box_pack_start( GTK_BOX(hbox), gtk_label_new("Number of players"),
FALSE, TRUE, 0 );
state->nPlayersLabel = gtk_label_new("");
gtk_box_pack_start( GTK_BOX(hbox), state->nPlayersLabel, FALSE, TRUE, 0 );
opt = gtk_option_menu_new();
nPlayersMenu = gtk_menu_new();
@ -260,10 +264,10 @@ makeNewGameDialog( GtkNewGameState* state )
gtk_widget_show( opt );
gtk_box_pack_start( GTK_BOX(hbox), opt, FALSE, TRUE, 0 );
gtk_box_pack_start( GTK_BOX(hbox),
makeButton( "Juggle", GTK_SIGNAL_FUNC(handle_juggle),
state ),
FALSE, TRUE, 0 );
juggleButton = makeButton( "Juggle", GTK_SIGNAL_FUNC(handle_juggle),
state );
gtk_box_pack_start( GTK_BOX(hbox), juggleButton, FALSE, TRUE, 0 );
gtk_widget_set_sensitive( juggleButton, isNewGame );
gtk_widget_show( hbox );
gtk_box_pack_start( GTK_BOX(vbox), hbox, FALSE, TRUE, 0 );
@ -294,6 +298,7 @@ makeNewGameDialog( GtkNewGameState* state )
gtk_box_pack_start( GTK_BOX(hbox), label, FALSE, TRUE, 0 );
gtk_widget_show( label );
state->nameLabels[i] = label;
gtk_box_pack_start( GTK_BOX(hbox), nameField, FALSE, TRUE, 0 );
gtk_widget_show( nameField );
@ -306,6 +311,7 @@ makeNewGameDialog( GtkNewGameState* state )
label = gtk_label_new("Passwd:");
gtk_box_pack_start( GTK_BOX(hbox), label, FALSE, TRUE, 0 );
gtk_widget_show( label );
state->passwdLabels[i] = label;
gtk_box_pack_start( GTK_BOX(hbox), passwdField, FALSE, TRUE, 0 );
gtk_widget_show( passwdField );
@ -395,16 +401,43 @@ widgetForCol( const GtkNewGameState* state, XP_U16 player, NewGameColumn col )
return widget;
} /* widgetForCol */
static void
gtk_newgame_col_enable( void* closure, XP_U16 player, NewGameColumn col,
XP_Bool enable )
static GtkWidget*
labelForCol( const GtkNewGameState* state, XP_U16 player, NewGameColumn col )
{
GtkNewGameState* state = (GtkNewGameState*)closure;
gtk_widget_set_sensitive( widgetForCol( state, player, col ), enable );
}
GtkWidget* widget = NULL;
if ( col == NG_COL_NAME ) {
widget = state->nameLabels[player];
} else if ( col == NG_COL_PASSWD ) {
widget = state->passwdLabels[player];
}
return widget;
} /* widgetForCol */
static void
gtk_newgame_attr_enable( void* closure, NewGameAttr attr, XP_Bool enable )
gtk_newgame_col_enable( void* closure, XP_U16 player, NewGameColumn col,
NewGameEnable enable )
{
GtkNewGameState* state = (GtkNewGameState*)closure;
GtkWidget* widget = widgetForCol( state, player, col );
GtkWidget* label = labelForCol( state, player, col );
if ( enable == NGEnableHidden ) {
gtk_widget_hide( widget );
if ( !!label ) {
gtk_widget_hide( label );
}
} else {
gtk_widget_show( widget );
gtk_widget_set_sensitive( widget, enable == NGEnableEnabled );
if ( !!label ) {
gtk_widget_show( label );
gtk_widget_set_sensitive( label, enable == NGEnableEnabled );
}
}
} /* gtk_newgame_col_enable */
static void
gtk_newgame_attr_enable( void* closure, NewGameAttr attr, NewGameEnable enable )
{
GtkNewGameState* state = (GtkNewGameState*)closure;
GtkWidget* menu = NULL;
@ -413,8 +446,9 @@ gtk_newgame_attr_enable( void* closure, NewGameAttr attr, XP_Bool enable )
} else if ( attr == NG_ATTR_ROLE ) {
menu = state->roleMenu;
}
XP_ASSERT( !!menu );
gtk_widget_set_sensitive( menu, enable );
if ( !!menu ) {
gtk_widget_set_sensitive( menu, enable == NGEnableEnabled );
}
}
static void
@ -476,11 +510,15 @@ gtk_newgame_attr_set( void* closure, NewGameAttr attr, NGValue value )
gtk_menu_set_active( GTK_MENU(state->nPlayersMenu), i-1 );
} else if ( attr == NG_ATTR_ROLE ) {
} else if ( attr == NG_ATTR_REMHEADER ) {
/* ignored on GTK: no headers at all */
} else if ( attr == NG_ATTR_NPLAYHEADER ) {
gtk_label_set_text( GTK_LABEL(state->nPlayersLabel), value.ng_cp );
}
}
gboolean
newGameDialog( GtkAppGlobals* globals/* , GtkGameInfo* gameInfo */ )
newGameDialog( GtkAppGlobals* globals, XP_Bool isNewGame )
{
GtkNewGameState state;
XP_MEMSET( &state, 0, sizeof(state) );
@ -488,8 +526,8 @@ newGameDialog( GtkAppGlobals* globals/* , GtkGameInfo* gameInfo */ )
state.globals = globals;
state.newGameCtxt = newg_make( MPPARM(globals->cGlobals.params
->util->mpool)
XP_TRUE, /* does gtk have concept of new
game yet? */
isNewGame,
globals->cGlobals.params->util,
gtk_newgame_col_enable,
gtk_newgame_attr_enable,
gtk_newgame_col_get,
@ -499,21 +537,22 @@ newGameDialog( GtkAppGlobals* globals/* , GtkGameInfo* gameInfo */ )
/* returns when button handler calls gtk_main_quit */
do {
GtkWidget* dialog = makeNewGameDialog( &state );
GtkWidget* dialog = makeNewGameDialog( &state, isNewGame );
state.revert = FALSE;
newg_load( state.newGameCtxt,
&globals->cGlobals.params->gi );
&globals->cGlobals.params->gi );
gtk_main();
if ( !state.cancelled && !state.revert ) {
newg_store( state.newGameCtxt, &globals->cGlobals.params->gi );
}
newg_destroy( state.newGameCtxt );
gtk_widget_destroy( dialog );
} while ( state.revert );
newg_destroy( state.newGameCtxt );
return !state.cancelled;
} /* newGameDialog */

View file

@ -25,7 +25,7 @@
#include "gtkmain.h"
gboolean newGameDialog( GtkAppGlobals* globals );
gboolean newGameDialog( GtkAppGlobals* globals, XP_Bool isNewGame );
#endif /* _GTKNEWGAME_H_ */
#endif /* PLATFORM_GTK */

View file

@ -532,6 +532,15 @@ linux_util_getUserString( XW_UtilCtxt* uc, XP_U16 code )
case STR_LOSTTURN:
return (XP_UCHAR*)"Lost turn";
#ifndef XWFEATURE_STANDALONE_ONLY
case STR_LOCALPLAYERS:
return (XP_UCHAR*)"Local players";
case STR_REMOTE:
return (XP_UCHAR*)"Remote";
#endif
case STR_TOTALPLAYERS:
return (XP_UCHAR*)"Total players";
case STRS_VALUES_HEADER:
return (XP_UCHAR*)"%s counts/values:\n";