mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2024-12-30 10:26:58 +01:00
gtk/ncurses support for Rem: focus and showing remaining tiles. Also
rewrite gtkask to use gtk_message_dialog and add sigint handler.
This commit is contained in:
parent
a4eb339c59
commit
6a5454ad74
7 changed files with 116 additions and 115 deletions
|
@ -141,13 +141,17 @@ curses_draw_measureRemText( DrawCtx* XP_UNUSED(dctx),
|
||||||
|
|
||||||
static void
|
static void
|
||||||
curses_draw_drawRemText( DrawCtx* p_dctx, const XP_Rect* rInner,
|
curses_draw_drawRemText( DrawCtx* p_dctx, const XP_Rect* rInner,
|
||||||
const XP_Rect* XP_UNUSED(rOuter), XP_S16 nTilesLeft )
|
const XP_Rect* XP_UNUSED(rOuter), XP_S16 nTilesLeft,
|
||||||
|
XP_Bool focussed )
|
||||||
{
|
{
|
||||||
CursesDrawCtx* dctx = (CursesDrawCtx*)p_dctx;
|
CursesDrawCtx* dctx = (CursesDrawCtx*)p_dctx;
|
||||||
char buf[32];
|
char buf[32];
|
||||||
|
|
||||||
formatRemText( buf, sizeof(buf), nTilesLeft, rInner->width );
|
formatRemText( buf, sizeof(buf), nTilesLeft, rInner->width );
|
||||||
mvwprintw( dctx->boardWin, rInner->top, rInner->left, buf );
|
mvwprintw( dctx->boardWin, rInner->top, rInner->left, buf );
|
||||||
|
if ( focussed ) {
|
||||||
|
cursesHiliteRect( dctx->boardWin, rInner );
|
||||||
|
}
|
||||||
} /* curses_draw_drawRemText */
|
} /* curses_draw_drawRemText */
|
||||||
|
|
||||||
static int
|
static int
|
||||||
|
|
|
@ -1158,6 +1158,25 @@ curses_util_warnIllegalWord( XW_UtilCtxt* XP_UNUSED(uc),
|
||||||
return XP_FALSE;
|
return XP_FALSE;
|
||||||
} /* curses_util_warnIllegalWord */
|
} /* curses_util_warnIllegalWord */
|
||||||
|
|
||||||
|
static void
|
||||||
|
curses_util_remSelected( XW_UtilCtxt* uc )
|
||||||
|
{
|
||||||
|
CursesAppGlobals* globals = (CursesAppGlobals*)uc->closure;
|
||||||
|
XWStreamCtxt* stream;
|
||||||
|
XP_UCHAR* text;
|
||||||
|
|
||||||
|
stream = mem_stream_make( MPPARM(globals->cGlobals.params->util->mpool)
|
||||||
|
globals->cGlobals.params->vtMgr,
|
||||||
|
globals, CHANNEL_NONE, NULL );
|
||||||
|
board_formatRemainingTiles( globals->cGlobals.game.board, stream );
|
||||||
|
|
||||||
|
text = strFromStream( stream );
|
||||||
|
|
||||||
|
(void)cursesask( globals, text, 1, "Ok" );
|
||||||
|
|
||||||
|
free( text );
|
||||||
|
}
|
||||||
|
|
||||||
#ifndef XWFEATURE_STANDALONE_ONLY
|
#ifndef XWFEATURE_STANDALONE_ONLY
|
||||||
static void
|
static void
|
||||||
cursesSendOnClose( XWStreamCtxt* stream, void* closure )
|
cursesSendOnClose( XWStreamCtxt* stream, void* closure )
|
||||||
|
@ -1192,6 +1211,7 @@ setupCursesUtilCallbacks( CursesAppGlobals* globals, XW_UtilCtxt* util )
|
||||||
util->vtable->m_util_askPassword = curses_util_askPassword;
|
util->vtable->m_util_askPassword = curses_util_askPassword;
|
||||||
util->vtable->m_util_yOffsetChange = curses_util_yOffsetChange;
|
util->vtable->m_util_yOffsetChange = curses_util_yOffsetChange;
|
||||||
util->vtable->m_util_warnIllegalWord = curses_util_warnIllegalWord;
|
util->vtable->m_util_warnIllegalWord = curses_util_warnIllegalWord;
|
||||||
|
util->vtable->m_util_remSelected = curses_util_remSelected;
|
||||||
#ifndef XWFEATURE_STANDALONE_ONLY
|
#ifndef XWFEATURE_STANDALONE_ONLY
|
||||||
util->vtable->m_util_makeStreamFromAddr = curses_util_makeStreamFromAddr;
|
util->vtable->m_util_makeStreamFromAddr = curses_util_makeStreamFromAddr;
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
/* -*-mode: C; fill-column: 78; c-basic-offset: 4; -*- */
|
/* -*-mode: C; fill-column: 78; compile-command: "make MEMDEBUG=TRUE"; -*- */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright 2000 by Eric House (xwords@eehouse.org). All rights reserved.
|
* Copyright 2000 by Eric House (xwords@eehouse.org). All rights reserved.
|
||||||
*
|
*
|
||||||
|
@ -22,61 +23,16 @@
|
||||||
|
|
||||||
#include "gtkask.h"
|
#include "gtkask.h"
|
||||||
|
|
||||||
static void
|
XP_Bool
|
||||||
button_event( GtkWidget* XP_UNUSED(widget), void* closure )
|
gtkask( const gchar *message, GtkButtonsType buttons )
|
||||||
{
|
{
|
||||||
gboolean* whichSet = (gboolean*)closure;
|
GtkWidget* dlg = gtk_message_dialog_new( NULL, /* parent */
|
||||||
*whichSet = 1;
|
GTK_MESSAGE_QUESTION,
|
||||||
|
GTK_DIALOG_MODAL,
|
||||||
gtk_main_quit();
|
buttons, message );
|
||||||
}
|
gint response = gtk_dialog_run( GTK_DIALOG(dlg) );
|
||||||
|
gtk_widget_destroy( dlg );
|
||||||
gint
|
return response == GTK_RESPONSE_OK || response == GTK_RESPONSE_YES;
|
||||||
gtkask( gchar *message, gint numButtons, char* button1, ... )
|
|
||||||
{
|
|
||||||
GtkWidget* dialog;
|
|
||||||
GtkWidget* label;
|
|
||||||
GtkWidget* button;
|
|
||||||
short i;
|
|
||||||
gboolean* results = g_malloc( numButtons * sizeof(results[0]) );
|
|
||||||
char** butList = &button1;
|
|
||||||
|
|
||||||
/* Create the widgets */
|
|
||||||
dialog = gtk_dialog_new();
|
|
||||||
gtk_window_set_modal( GTK_WINDOW( dialog ), TRUE );
|
|
||||||
|
|
||||||
label = gtk_label_new( message );
|
|
||||||
|
|
||||||
for ( i = 0; i < numButtons; ++i ) {
|
|
||||||
button = gtk_button_new_with_label( *butList );
|
|
||||||
|
|
||||||
results[i] = 0;
|
|
||||||
g_signal_connect( GTK_OBJECT( button ), "clicked",
|
|
||||||
G_CALLBACK(button_event), &results[i] );
|
|
||||||
|
|
||||||
gtk_container_add( GTK_CONTAINER( GTK_DIALOG(dialog)->action_area),
|
|
||||||
button );
|
|
||||||
|
|
||||||
++butList;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Add the label, and show everything we've added to the dialog. */
|
|
||||||
gtk_container_add (GTK_CONTAINER (GTK_DIALOG(dialog)->vbox),
|
|
||||||
label);
|
|
||||||
gtk_widget_show_all (dialog);
|
|
||||||
|
|
||||||
/* returns when button handler calls gtk_main_quit */
|
|
||||||
gtk_main();
|
|
||||||
|
|
||||||
gtk_widget_destroy( dialog );
|
|
||||||
|
|
||||||
for ( i = 0; i < numButtons; ++i ) {
|
|
||||||
if ( results[i] ) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
g_free( results );
|
|
||||||
return i;
|
|
||||||
} /* gtkask */
|
} /* gtkask */
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -25,7 +25,9 @@
|
||||||
|
|
||||||
#include "gtkmain.h"
|
#include "gtkmain.h"
|
||||||
|
|
||||||
gint gtkask( gchar *message, gint numButtons, char* button1, ... );
|
/* Returns true for "yes" or "ok" answer, false otherwise.
|
||||||
|
*/
|
||||||
|
XP_Bool gtkask( const gchar *message, GtkButtonsType buttons );
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
#endif /* PLATFORM_GTK */
|
#endif /* PLATFORM_GTK */
|
||||||
|
|
|
@ -63,7 +63,7 @@ gtkInsetRect( XP_Rect* r, short i )
|
||||||
#define GTKMIN_W_HT 12
|
#define GTKMIN_W_HT 12
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gtkFillRect( GtkDrawCtx* dctx, const XP_Rect* rect, GdkColor* color )
|
gtkFillRect( GtkDrawCtx* dctx, const XP_Rect* rect, const GdkColor* color )
|
||||||
{
|
{
|
||||||
gdk_gc_set_foreground( dctx->drawGC, color );
|
gdk_gc_set_foreground( dctx->drawGC, color );
|
||||||
gdk_draw_rectangle( DRAW_WHAT(dctx), dctx->drawGC,
|
gdk_draw_rectangle( DRAW_WHAT(dctx), dctx->drawGC,
|
||||||
|
@ -190,15 +190,17 @@ layout_for_ht( GtkDrawCtx* dctx, XP_U16 ht )
|
||||||
} /* layout_for_ht */
|
} /* layout_for_ht */
|
||||||
|
|
||||||
static void
|
static void
|
||||||
draw_string_at( GtkDrawCtx* dctx, const char* str, XP_U16 fontHt,
|
draw_string_at( GtkDrawCtx* dctx, PangoLayout* layout,
|
||||||
|
const char* str, XP_U16 fontHt,
|
||||||
const XP_Rect* where, XP_GTK_JUST just,
|
const XP_Rect* where, XP_GTK_JUST just,
|
||||||
const GdkColor* frground, const GdkColor* bkgrnd )
|
const GdkColor* frground, const GdkColor* bkgrnd )
|
||||||
{
|
{
|
||||||
PangoLayout* layout;
|
|
||||||
gint xx = where->left;
|
gint xx = where->left;
|
||||||
gint yy = where->top;
|
gint yy = where->top;
|
||||||
|
|
||||||
|
if ( !layout ) {
|
||||||
layout = layout_for_ht( dctx, fontHt );
|
layout = layout_for_ht( dctx, fontHt );
|
||||||
|
}
|
||||||
|
|
||||||
pango_layout_set_text( layout, str, strlen(str) );
|
pango_layout_set_text( layout, str, strlen(str) );
|
||||||
|
|
||||||
|
@ -463,8 +465,8 @@ gtk_draw_drawCell( DrawCtx* p_dctx, const XP_Rect* rect, const XP_UCHAR* letter,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if ( (flags & CELL_ISSTAR) != 0 ) {
|
if ( (flags & CELL_ISSTAR) != 0 ) {
|
||||||
draw_string_at( dctx, "*", rect->height, rect, XP_GTK_JUST_CENTER,
|
draw_string_at( dctx, NULL, "*", rect->height, rect,
|
||||||
&dctx->black, NULL );
|
XP_GTK_JUST_CENTER, &dctx->black, NULL );
|
||||||
}
|
}
|
||||||
} else if ( !!letter ) {
|
} else if ( !!letter ) {
|
||||||
GdkColor* foreground;
|
GdkColor* foreground;
|
||||||
|
@ -478,7 +480,7 @@ gtk_draw_drawCell( DrawCtx* p_dctx, const XP_Rect* rect, const XP_UCHAR* letter,
|
||||||
rectInset.width+1, rectInset.height+1 );
|
rectInset.width+1, rectInset.height+1 );
|
||||||
|
|
||||||
foreground = highlight? &dctx->white : &dctx->playerColors[owner];
|
foreground = highlight? &dctx->white : &dctx->playerColors[owner];
|
||||||
draw_string_at( dctx, letter, rectInset.height-2, &rectInset,
|
draw_string_at( dctx, NULL, letter, rectInset.height-2, &rectInset,
|
||||||
XP_GTK_JUST_CENTER, foreground, cursor );
|
XP_GTK_JUST_CENTER, foreground, cursor );
|
||||||
|
|
||||||
if ( (flags & CELL_ISBLANK) != 0 ) {
|
if ( (flags & CELL_ISBLANK) != 0 ) {
|
||||||
|
@ -561,7 +563,7 @@ gtkDrawTileImpl( DrawCtx* p_dctx, const XP_Rect* rect, const XP_UCHAR* textP,
|
||||||
|
|
||||||
if ( !!textP ) {
|
if ( !!textP ) {
|
||||||
if ( *textP != LETTER_NONE ) { /* blank */
|
if ( *textP != LETTER_NONE ) { /* blank */
|
||||||
draw_string_at( dctx, textP, formatRect.height>>1,
|
draw_string_at( dctx, NULL, textP, formatRect.height>>1,
|
||||||
&formatRect, XP_GTK_JUST_TOPLEFT,
|
&formatRect, XP_GTK_JUST_TOPLEFT,
|
||||||
foreground, NULL );
|
foreground, NULL );
|
||||||
|
|
||||||
|
@ -573,7 +575,7 @@ gtkDrawTileImpl( DrawCtx* p_dctx, const XP_Rect* rect, const XP_UCHAR* textP,
|
||||||
sprintf( numbuf, "%d", val );
|
sprintf( numbuf, "%d", val );
|
||||||
len = strlen( numbuf );
|
len = strlen( numbuf );
|
||||||
|
|
||||||
draw_string_at( dctx, numbuf, formatRect.height>>2,
|
draw_string_at( dctx, NULL, numbuf, formatRect.height>>2,
|
||||||
&formatRect, XP_GTK_JUST_BOTTOMRIGHT,
|
&formatRect, XP_GTK_JUST_BOTTOMRIGHT,
|
||||||
foreground, NULL );
|
foreground, NULL );
|
||||||
|
|
||||||
|
@ -631,7 +633,7 @@ gtk_draw_drawTileBack( DrawCtx* p_dctx, const XP_Rect* rect,
|
||||||
gtkInsetRect( &r, 1 );
|
gtkInsetRect( &r, 1 );
|
||||||
gtkFillRect( dctx, &r, hasCursor? &dctx->cursor : &dctx->tileBack );
|
gtkFillRect( dctx, &r, hasCursor? &dctx->cursor : &dctx->tileBack );
|
||||||
|
|
||||||
draw_string_at( dctx, "?", r.height,
|
draw_string_at( dctx, NULL, "?", r.height,
|
||||||
&r, XP_GTK_JUST_CENTER,
|
&r, XP_GTK_JUST_CENTER,
|
||||||
&dctx->playerColors[dctx->trayOwner], NULL );
|
&dctx->playerColors[dctx->trayOwner], NULL );
|
||||||
|
|
||||||
|
@ -686,7 +688,7 @@ gtk_draw_drawBoardArrow( DrawCtx* p_dctx, const XP_Rect* rectP,
|
||||||
const char* curs = vertical? "|":"-";
|
const char* curs = vertical? "|":"-";
|
||||||
|
|
||||||
/* font needs to be small enough that "|" doesn't overwrite cell below */
|
/* font needs to be small enough that "|" doesn't overwrite cell below */
|
||||||
draw_string_at( dctx, curs, (rectP->height*2)/3,
|
draw_string_at( dctx, NULL, curs, (rectP->height*2)/3,
|
||||||
rectP, XP_GTK_JUST_CENTER,
|
rectP, XP_GTK_JUST_CENTER,
|
||||||
&dctx->black, NULL );
|
&dctx->black, NULL );
|
||||||
drawHintBorders( dctx, rectP, hintAtts );
|
drawHintBorders( dctx, rectP, hintAtts );
|
||||||
|
@ -733,16 +735,17 @@ getLayoutToFitRect( GtkDrawCtx* dctx, const char* str, const XP_Rect* rect )
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gtkDrawDrawRemText( DrawCtx* p_dctx, const XP_Rect* rect, XP_S16 nTilesLeft,
|
gtkDrawDrawRemText( DrawCtx* p_dctx, const XP_Rect* rect, XP_S16 nTilesLeft,
|
||||||
XP_U16* widthP, XP_U16* heightP )
|
XP_U16* widthP, XP_U16* heightP, XP_Bool focussed )
|
||||||
{
|
{
|
||||||
GtkDrawCtx* dctx = (GtkDrawCtx*)p_dctx;
|
GtkDrawCtx* dctx = (GtkDrawCtx*)p_dctx;
|
||||||
char buf[10];
|
char buf[10];
|
||||||
|
PangoLayout* layout;
|
||||||
|
|
||||||
snprintf( buf, sizeof(buf), "rem:%d", nTilesLeft );
|
snprintf( buf, sizeof(buf), "rem:%d", nTilesLeft );
|
||||||
|
layout = getLayoutToFitRect( dctx, buf, rect );
|
||||||
|
|
||||||
if ( !!widthP ) {
|
if ( !!widthP ) {
|
||||||
int width, height;
|
int width, height;
|
||||||
PangoLayout* layout = getLayoutToFitRect( dctx, buf, rect );
|
|
||||||
pango_layout_get_pixel_size( layout, &width, &height );
|
pango_layout_get_pixel_size( layout, &width, &height );
|
||||||
if ( width > rect->width ) {
|
if ( width > rect->width ) {
|
||||||
width = rect->width;
|
width = rect->width;
|
||||||
|
@ -753,24 +756,34 @@ gtkDrawDrawRemText( DrawCtx* p_dctx, const XP_Rect* rect, XP_S16 nTilesLeft,
|
||||||
*widthP = width;
|
*widthP = width;
|
||||||
*heightP = height;
|
*heightP = height;
|
||||||
} else {
|
} else {
|
||||||
draw_string_at( dctx, buf, rect->height,
|
const GdkColor* cursor = NULL;
|
||||||
|
if ( focussed ) {
|
||||||
|
cursor = &dctx->cursor;
|
||||||
|
gtkFillRect( dctx, rect, cursor );
|
||||||
|
}
|
||||||
|
draw_string_at( dctx, layout, buf, rect->height,
|
||||||
rect, XP_GTK_JUST_TOPLEFT,
|
rect, XP_GTK_JUST_TOPLEFT,
|
||||||
&dctx->black, NULL );
|
&dctx->black, cursor );
|
||||||
}
|
}
|
||||||
} /* gtkDrawDrawRemText */
|
} /* gtkDrawDrawRemText */
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gtk_draw_measureRemText( DrawCtx* p_dctx, const XP_Rect* r, XP_S16 nTilesLeft,
|
gtk_draw_measureRemText( DrawCtx* p_dctx, const XP_Rect* rect, XP_S16 nTilesLeft,
|
||||||
XP_U16* width, XP_U16* height )
|
XP_U16* width, XP_U16* height )
|
||||||
{
|
{
|
||||||
gtkDrawDrawRemText( p_dctx, r, nTilesLeft, width, height );
|
if ( nTilesLeft <= 0 ) {
|
||||||
|
*width = *height = 0;
|
||||||
|
} else {
|
||||||
|
gtkDrawDrawRemText( p_dctx, rect, nTilesLeft, width, height, XP_FALSE );
|
||||||
|
}
|
||||||
} /* gtk_draw_measureRemText */
|
} /* gtk_draw_measureRemText */
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gtk_draw_drawRemText( DrawCtx* p_dctx, const XP_Rect* rInner,
|
gtk_draw_drawRemText( DrawCtx* p_dctx, const XP_Rect* rInner,
|
||||||
const XP_Rect* XP_UNUSED(rOuter), XP_S16 nTilesLeft )
|
const XP_Rect* XP_UNUSED(rOuter), XP_S16 nTilesLeft,
|
||||||
|
XP_Bool focussed )
|
||||||
{
|
{
|
||||||
gtkDrawDrawRemText( p_dctx, rInner, nTilesLeft, NULL, NULL );
|
gtkDrawDrawRemText( p_dctx, rInner, nTilesLeft, NULL, NULL, focussed );
|
||||||
} /* gtk_draw_drawRemText */
|
} /* gtk_draw_drawRemText */
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -844,7 +857,7 @@ gtk_draw_score_drawPlayer( DrawCtx* p_dctx, const XP_Rect* rInner,
|
||||||
gtkEraseRect( dctx, rInner );
|
gtkEraseRect( dctx, rInner );
|
||||||
}
|
}
|
||||||
|
|
||||||
draw_string_at( dctx, scoreBuf, rInner->height - 1,
|
draw_string_at( dctx, NULL, scoreBuf, rInner->height - 1,
|
||||||
rInner, XP_GTK_JUST_CENTER,
|
rInner, XP_GTK_JUST_CENTER,
|
||||||
&dctx->playerColors[dsi->playerNum], cursor );
|
&dctx->playerColors[dsi->playerNum], cursor );
|
||||||
|
|
||||||
|
@ -880,10 +893,10 @@ gtk_draw_score_pendingScore( DrawCtx* p_dctx, const XP_Rect* rect,
|
||||||
}
|
}
|
||||||
|
|
||||||
ht = localR.height >> 2;
|
ht = localR.height >> 2;
|
||||||
draw_string_at( dctx, "Pts:", ht,
|
draw_string_at( dctx, NULL, "Pts:", ht,
|
||||||
&localR, XP_GTK_JUST_TOPLEFT,
|
&localR, XP_GTK_JUST_TOPLEFT,
|
||||||
&dctx->black, cursor );
|
&dctx->black, cursor );
|
||||||
draw_string_at( dctx, buf, ht,
|
draw_string_at( dctx, NULL, buf, ht,
|
||||||
&localR, XP_GTK_JUST_BOTTOMRIGHT,
|
&localR, XP_GTK_JUST_BOTTOMRIGHT,
|
||||||
&dctx->black, cursor );
|
&dctx->black, cursor );
|
||||||
|
|
||||||
|
@ -916,7 +929,7 @@ gtk_draw_drawTimer( DrawCtx* p_dctx, const XP_Rect* rInner,
|
||||||
|
|
||||||
/* gdk_gc_set_clip_rectangle( dctx->drawGC, (GdkRectangle*)rInner ); */
|
/* gdk_gc_set_clip_rectangle( dctx->drawGC, (GdkRectangle*)rInner ); */
|
||||||
gtkEraseRect( dctx, rInner );
|
gtkEraseRect( dctx, rInner );
|
||||||
draw_string_at( dctx, buf, rInner->height-1,
|
draw_string_at( dctx, NULL, buf, rInner->height-1,
|
||||||
rInner, XP_GTK_JUST_CENTER,
|
rInner, XP_GTK_JUST_CENTER,
|
||||||
&dctx->black, NULL );
|
&dctx->black, NULL );
|
||||||
} /* gtk_draw_drawTimer */
|
} /* gtk_draw_drawTimer */
|
||||||
|
@ -986,7 +999,7 @@ gtk_draw_drawMiniWindow( DrawCtx* p_dctx, const XP_UCHAR* text,
|
||||||
gtkEraseRect( dctx, &localR );
|
gtkEraseRect( dctx, &localR );
|
||||||
frameRect( dctx, &localR );
|
frameRect( dctx, &localR );
|
||||||
|
|
||||||
draw_string_at( dctx, text, GTKMIN_W_HT,
|
draw_string_at( dctx, NULL, text, GTKMIN_W_HT,
|
||||||
&localR, XP_GTK_JUST_CENTER,
|
&localR, XP_GTK_JUST_CENTER,
|
||||||
&dctx->black, NULL );
|
&dctx->black, NULL );
|
||||||
} /* gtk_draw_drawMiniWindow */
|
} /* gtk_draw_drawMiniWindow */
|
||||||
|
|
|
@ -32,6 +32,8 @@
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <gdk/gdkkeysyms.h>
|
#include <gdk/gdkkeysyms.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
#include <signal.h>
|
||||||
|
|
||||||
#ifndef CLIENT_ONLY
|
#ifndef CLIENT_ONLY
|
||||||
/* # include <prc.h> */
|
/* # include <prc.h> */
|
||||||
#endif
|
#endif
|
||||||
|
@ -605,12 +607,8 @@ final_scores( GtkWidget* XP_UNUSED(widget), GtkAppGlobals* globals )
|
||||||
if ( gameOver ) {
|
if ( gameOver ) {
|
||||||
printFinalScores( globals );
|
printFinalScores( globals );
|
||||||
} else {
|
} else {
|
||||||
XP_Bool confirmed;
|
if ( gtkask( "Are you sure everybody wants to end the game now?",
|
||||||
confirmed =
|
GTK_BUTTONS_YES_NO ) ) {
|
||||||
gtkask( "Are you sure everybody wants to end the game now?",
|
|
||||||
2, "Yes", "No" ) == 0;
|
|
||||||
|
|
||||||
if ( confirmed ) {
|
|
||||||
server_endGame( globals->cGlobals.game.server );
|
server_endGame( globals->cGlobals.game.server );
|
||||||
gameOver = TRUE;
|
gameOver = TRUE;
|
||||||
}
|
}
|
||||||
|
@ -1022,7 +1020,7 @@ gtkUserError( GtkAppGlobals* XP_UNUSED(globals), const char* format, ... )
|
||||||
|
|
||||||
vsprintf( buf, format, ap );
|
vsprintf( buf, format, ap );
|
||||||
|
|
||||||
(void)gtkask( buf, 1, "OK" );
|
(void)gtkask( buf, GTK_BUTTONS_OK );
|
||||||
|
|
||||||
va_end(ap);
|
va_end(ap);
|
||||||
} /* gtkUserError */
|
} /* gtkUserError */
|
||||||
|
@ -1327,12 +1325,30 @@ gtk_util_warnIllegalWord( XW_UtilCtxt* uc, BadWordInfo* bwi, XP_U16 player,
|
||||||
XP_ASSERT( bwi->nWords == 1 );
|
XP_ASSERT( bwi->nWords == 1 );
|
||||||
sprintf( buf, "Word \"%s\" not in the current dictionary. "
|
sprintf( buf, "Word \"%s\" not in the current dictionary. "
|
||||||
"Use it anyway?", bwi->words[0] );
|
"Use it anyway?", bwi->words[0] );
|
||||||
result = 0 == gtkask( buf, 2, "Ok", "Cancel" );
|
result = gtkask( buf, GTK_BUTTONS_YES_NO );
|
||||||
}
|
}
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
} /* gtk_util_warnIllegalWord */
|
} /* gtk_util_warnIllegalWord */
|
||||||
|
|
||||||
|
static void
|
||||||
|
gtk_util_remSelected( XW_UtilCtxt* uc )
|
||||||
|
{
|
||||||
|
GtkAppGlobals* globals = (GtkAppGlobals*)uc->closure;
|
||||||
|
XWStreamCtxt* stream;
|
||||||
|
XP_UCHAR* text;
|
||||||
|
|
||||||
|
stream = mem_stream_make( MEMPOOL
|
||||||
|
globals->cGlobals.params->vtMgr,
|
||||||
|
globals, CHANNEL_NONE, NULL );
|
||||||
|
board_formatRemainingTiles( globals->cGlobals.game.board, stream );
|
||||||
|
text = strFromStream( stream );
|
||||||
|
stream_destroy( stream );
|
||||||
|
|
||||||
|
(void)gtkask( text, GTK_BUTTONS_OK );
|
||||||
|
free( text );
|
||||||
|
}
|
||||||
|
|
||||||
#ifndef XWFEATURE_STANDALONE_ONLY
|
#ifndef XWFEATURE_STANDALONE_ONLY
|
||||||
static XWStreamCtxt*
|
static XWStreamCtxt*
|
||||||
gtk_util_makeStreamFromAddr(XW_UtilCtxt* uc, XP_PlayerAddr channelNo )
|
gtk_util_makeStreamFromAddr(XW_UtilCtxt* uc, XP_PlayerAddr channelNo )
|
||||||
|
@ -1380,34 +1396,23 @@ gtk_util_userQuery( XW_UtilCtxt* XP_UNUSED(uc), UtilQueryID id,
|
||||||
{
|
{
|
||||||
XP_Bool result;
|
XP_Bool result;
|
||||||
char* question;
|
char* question;
|
||||||
char* answers[3];
|
|
||||||
gint numAnswers = 0;
|
|
||||||
XP_U16 okIndex = 1;
|
|
||||||
XP_Bool freeMe = XP_FALSE;
|
XP_Bool freeMe = XP_FALSE;
|
||||||
|
GtkButtonsType buttons = GTK_BUTTONS_YES_NO;
|
||||||
|
|
||||||
switch( id ) {
|
switch( id ) {
|
||||||
|
|
||||||
case QUERY_COMMIT_TURN:
|
case QUERY_COMMIT_TURN:
|
||||||
question = strFromStream( stream );
|
question = strFromStream( stream );
|
||||||
freeMe = XP_TRUE;
|
freeMe = XP_TRUE;
|
||||||
/* len = stream_getSize( stream ); */
|
|
||||||
/* question = malloc( len + 1 ); */
|
|
||||||
/* stream_getBytes( stream, question, len ); */
|
|
||||||
/* question[len] = '\0'; */
|
|
||||||
answers[numAnswers++] = "Cancel";
|
|
||||||
answers[numAnswers++] = "Ok";
|
|
||||||
break;
|
break;
|
||||||
case QUERY_COMMIT_TRADE:
|
case QUERY_COMMIT_TRADE:
|
||||||
question = "Are you sure you want to trade the selected tiles?";
|
question = "Are you sure you want to trade the selected tiles?";
|
||||||
answers[numAnswers++] = "Cancel";
|
|
||||||
answers[numAnswers++] = "Ok";
|
|
||||||
break;
|
break;
|
||||||
case QUERY_ROBOT_MOVE:
|
case QUERY_ROBOT_MOVE:
|
||||||
case QUERY_ROBOT_TRADE:
|
case QUERY_ROBOT_TRADE:
|
||||||
question = strFromStream( stream );
|
question = strFromStream( stream );
|
||||||
freeMe = XP_TRUE;
|
freeMe = XP_TRUE;
|
||||||
answers[numAnswers++] = "Ok";
|
buttons = GTK_BUTTONS_OK;
|
||||||
okIndex = 0;
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
@ -1415,8 +1420,7 @@ gtk_util_userQuery( XW_UtilCtxt* XP_UNUSED(uc), UtilQueryID id,
|
||||||
return XP_FALSE;
|
return XP_FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
result = gtkask( question, numAnswers,
|
result = gtkask( question, buttons );
|
||||||
answers[0], answers[1], answers[2] ) == okIndex;
|
|
||||||
|
|
||||||
if ( freeMe > 0 ) {
|
if ( freeMe > 0 ) {
|
||||||
free( question );
|
free( question );
|
||||||
|
@ -1553,6 +1557,7 @@ setupGtkUtilCallbacks( GtkAppGlobals* globals, XW_UtilCtxt* util )
|
||||||
util->vtable->m_util_setTimer = gtk_util_setTimer;
|
util->vtable->m_util_setTimer = gtk_util_setTimer;
|
||||||
util->vtable->m_util_requestTime = gtk_util_requestTime;
|
util->vtable->m_util_requestTime = gtk_util_requestTime;
|
||||||
util->vtable->m_util_warnIllegalWord = gtk_util_warnIllegalWord;
|
util->vtable->m_util_warnIllegalWord = gtk_util_warnIllegalWord;
|
||||||
|
util->vtable->m_util_remSelected = gtk_util_remSelected;
|
||||||
#ifndef XWFEATURE_STANDALONE_ONLY
|
#ifndef XWFEATURE_STANDALONE_ONLY
|
||||||
util->vtable->m_util_makeStreamFromAddr = gtk_util_makeStreamFromAddr;
|
util->vtable->m_util_makeStreamFromAddr = gtk_util_makeStreamFromAddr;
|
||||||
#endif
|
#endif
|
||||||
|
@ -1778,6 +1783,13 @@ drop_msg_toggle( GtkWidget* toggle, GtkAppGlobals* globals )
|
||||||
} /* drop_msg_toggle */
|
} /* drop_msg_toggle */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
static GtkAppGlobals* g_globals_for_signal;
|
||||||
|
static void
|
||||||
|
handle_sigint( int XP_UNUSED(sig) )
|
||||||
|
{
|
||||||
|
quit( NULL, g_globals_for_signal );
|
||||||
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
gtkmain( LaunchParams* params, int argc, char *argv[] )
|
gtkmain( LaunchParams* params, int argc, char *argv[] )
|
||||||
{
|
{
|
||||||
|
@ -1793,6 +1805,10 @@ gtkmain( LaunchParams* params, int argc, char *argv[] )
|
||||||
GtkWidget* dropCheck;
|
GtkWidget* dropCheck;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
g_globals_for_signal = &globals;
|
||||||
|
struct sigaction act = { .sa_handler = handle_sigint };
|
||||||
|
sigaction( SIGINT, &act, NULL );
|
||||||
|
|
||||||
memset( &globals, 0, sizeof(globals) );
|
memset( &globals, 0, sizeof(globals) );
|
||||||
|
|
||||||
globals.cGlobals.params = params;
|
globals.cGlobals.params = params;
|
||||||
|
@ -1812,16 +1828,6 @@ gtkmain( LaunchParams* params, int argc, char *argv[] )
|
||||||
|
|
||||||
setupGtkUtilCallbacks( &globals, params->util );
|
setupGtkUtilCallbacks( &globals, params->util );
|
||||||
|
|
||||||
/* globals.dictionary = params->dict; */
|
|
||||||
/* globals.trayOverlaps = params->trayOverlaps; */
|
|
||||||
/* globals.askNewGame = params->askNewGame; */
|
|
||||||
/* globals.quitWhenDone = params->quitAfter; */
|
|
||||||
/* globals.sleepOnAnchor = params->sleepOnAnchor; */
|
|
||||||
/* globals.util = params->util; */
|
|
||||||
/* globals.fileName = params->fileName; */
|
|
||||||
|
|
||||||
/* globals.listenPort = params->listenPort; */
|
|
||||||
|
|
||||||
/* Now set up the gtk stuff. This is necessary before we make the
|
/* Now set up the gtk stuff. This is necessary before we make the
|
||||||
draw ctxt */
|
draw ctxt */
|
||||||
gtk_init( &argc, &argv );
|
gtk_init( &argc, &argv );
|
||||||
|
|
Loading…
Reference in a new issue