2011-08-29 20:36:01 -07:00
|
|
|
/* -*-mode: C; fill-column: 78; c-basic-offset: 4; -*- */
|
2003-11-01 05:35:29 +00:00
|
|
|
/*
|
2010-04-08 04:14:34 +00:00
|
|
|
* Copyright 1997 - 2010 by Eric House (xwords@eehouse.org). All rights
|
|
|
|
* reserved.
|
2003-11-01 05:35:29 +00:00
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _UTIL_H_
|
|
|
|
#define _UTIL_H_
|
|
|
|
|
|
|
|
#include "comtypes.h"
|
|
|
|
|
|
|
|
#include "dawg.h"
|
|
|
|
#include "model.h"
|
|
|
|
#include "board.h"
|
|
|
|
#include "mempool.h"
|
|
|
|
#include "vtabmgr.h"
|
2005-03-09 15:14:10 +00:00
|
|
|
#include "comms.h"
|
2003-11-01 05:35:29 +00:00
|
|
|
|
2005-09-03 06:56:33 +00:00
|
|
|
#include "xwrelay.h"
|
|
|
|
|
2003-11-01 05:35:29 +00:00
|
|
|
#define LETTER_NONE '\0'
|
|
|
|
|
|
|
|
typedef enum {
|
2007-11-18 23:43:27 +00:00
|
|
|
ERR_NONE, /* 0 is special case */
|
2003-11-01 05:35:29 +00:00
|
|
|
ERR_TILES_NOT_IN_LINE, /* scoring a move where tiles aren't in line */
|
|
|
|
ERR_NO_EMPTIES_IN_TURN,
|
|
|
|
ERR_TWO_TILES_FIRST_MOVE,
|
|
|
|
ERR_TILES_MUST_CONTACT,
|
|
|
|
/* ERR_NO_HINT_MID_TURN, */
|
|
|
|
ERR_TOO_FEW_TILES_LEFT_TO_TRADE,
|
|
|
|
ERR_NOT_YOUR_TURN,
|
|
|
|
ERR_NO_PEEK_ROBOT_TILES,
|
|
|
|
#ifndef XWFEATURE_STANDALONE_ONLY
|
|
|
|
ERR_SERVER_DICT_WINS,
|
|
|
|
ERR_NO_PEEK_REMOTE_TILES,
|
2008-05-31 03:26:16 +00:00
|
|
|
ERR_REG_UNEXPECTED_USER, /* server asked to register too many remote
|
|
|
|
users */
|
2008-01-04 14:47:52 +00:00
|
|
|
ERR_REG_SERVER_SANS_REMOTE,
|
2008-01-07 01:11:29 +00:00
|
|
|
STR_NEED_BT_HOST_ADDR,
|
2003-11-01 05:35:29 +00:00
|
|
|
#endif
|
2011-03-07 06:28:43 -08:00
|
|
|
ERR_NO_EMPTY_TRADE,
|
2005-01-04 04:07:38 +00:00
|
|
|
/* ERR_CANT_ENGINE_MID_MOVE, */
|
2003-11-01 05:35:29 +00:00
|
|
|
/* ERR_NOT_YOUR_TURN_TO_TRADE, */
|
|
|
|
/* ERR_NOT_YOUR_TURN_TO_MOVE, */
|
2005-07-06 01:36:52 +00:00
|
|
|
ERR_CANT_UNDO_TILEASSIGN,
|
2008-07-24 12:37:05 +00:00
|
|
|
ERR_CANT_HINT_WHILE_DISABLED,
|
2005-07-06 01:36:52 +00:00
|
|
|
|
2005-09-03 06:56:33 +00:00
|
|
|
ERR_RELAY_BASE,
|
|
|
|
ERR_RELAY_END = ERR_RELAY_BASE + XWRELAY_ERROR_LASTERR
|
2003-11-01 05:35:29 +00:00
|
|
|
} UtilErrID;
|
|
|
|
|
|
|
|
typedef enum {
|
2008-05-31 03:26:16 +00:00
|
|
|
QUERY_COMMIT_TURN, /* 0 means cancel; 1 means commit */
|
2003-11-01 05:35:29 +00:00
|
|
|
QUERY_COMMIT_TRADE,
|
|
|
|
QUERY_ROBOT_MOVE,
|
2005-01-20 02:37:13 +00:00
|
|
|
QUERY_ROBOT_TRADE,
|
|
|
|
|
|
|
|
QUERY_LAST_COMMON
|
2003-11-01 05:35:29 +00:00
|
|
|
} UtilQueryID;
|
|
|
|
|
2003-11-16 17:11:33 +00:00
|
|
|
typedef enum {
|
|
|
|
PICK_FOR_BLANK
|
|
|
|
, PICK_FOR_CHEAT
|
|
|
|
} PICK_WHY;
|
|
|
|
|
2004-05-14 08:57:38 +00:00
|
|
|
#define PICKER_PICKALL -1
|
|
|
|
#define PICKER_BACKUP -2
|
|
|
|
|
2003-11-16 17:11:33 +00:00
|
|
|
typedef struct PickInfo {
|
2009-04-07 04:23:56 +00:00
|
|
|
const XP_UCHAR** curTiles;
|
2003-11-30 18:54:08 +00:00
|
|
|
XP_U16 nCurTiles;
|
2004-11-02 06:27:47 +00:00
|
|
|
XP_U16 nTotal; /* count to fetch for turn, <= MAX_TRAY_TILES */
|
2003-11-16 17:11:33 +00:00
|
|
|
XP_U16 thisPick; /* <= nTotal */
|
2003-11-30 18:54:08 +00:00
|
|
|
PICK_WHY why;
|
2003-11-16 17:11:33 +00:00
|
|
|
} PickInfo;
|
|
|
|
|
2003-11-01 05:35:29 +00:00
|
|
|
typedef struct BadWordInfo {
|
|
|
|
XP_U16 nWords;
|
2010-02-24 04:34:22 +00:00
|
|
|
const XP_UCHAR* words[MAX_TRAY_TILES+1]; /* can form in both directions */
|
2003-11-01 05:35:29 +00:00
|
|
|
} BadWordInfo;
|
|
|
|
|
2008-04-12 15:36:31 +00:00
|
|
|
/* XWTimerProc returns true if redraw was necessitated by what the proc did */
|
|
|
|
typedef XP_Bool (*XWTimerProc)( void* closure, XWTimerReason why );
|
2005-06-23 04:16:53 +00:00
|
|
|
|
2003-11-01 05:35:29 +00:00
|
|
|
/* Platform-specific utility functions that need to be
|
|
|
|
*/
|
|
|
|
typedef struct UtilVtable {
|
|
|
|
|
|
|
|
VTableMgr* (*m_util_getVTManager)(XW_UtilCtxt* uc);
|
|
|
|
|
2005-01-04 04:07:38 +00:00
|
|
|
#ifndef XWFEATURE_STANDALONE_ONLY
|
2003-11-01 05:35:29 +00:00
|
|
|
XWStreamCtxt* (*m_util_makeStreamFromAddr )(XW_UtilCtxt* uc,
|
2007-12-05 06:28:51 +00:00
|
|
|
XP_PlayerAddr channelNo );
|
2005-01-04 04:07:38 +00:00
|
|
|
#endif
|
2003-11-01 05:35:29 +00:00
|
|
|
|
2008-05-06 12:49:37 +00:00
|
|
|
XWBonusType (*m_util_getSquareBonus)( XW_UtilCtxt* uc,
|
|
|
|
const ModelCtxt* model,
|
2003-11-01 05:35:29 +00:00
|
|
|
XP_U16 col, XP_U16 row );
|
|
|
|
void (*m_util_userError)( XW_UtilCtxt* uc, UtilErrID id );
|
|
|
|
|
2004-02-17 04:00:12 +00:00
|
|
|
XP_Bool (*m_util_userQuery)( XW_UtilCtxt* uc, UtilQueryID id,
|
|
|
|
XWStreamCtxt* stream );
|
2003-11-01 05:35:29 +00:00
|
|
|
|
2003-11-16 17:11:33 +00:00
|
|
|
/* return of < 0 means computer should pick */
|
2005-01-09 21:33:48 +00:00
|
|
|
XP_S16 (*m_util_userPickTile)( XW_UtilCtxt* uc, const PickInfo* pi,
|
2003-11-16 17:11:33 +00:00
|
|
|
XP_U16 playerNum,
|
2009-04-07 04:23:56 +00:00
|
|
|
const XP_UCHAR** texts, XP_U16 nTiles );
|
2003-11-16 17:11:33 +00:00
|
|
|
|
2003-11-01 05:35:29 +00:00
|
|
|
XP_Bool (*m_util_askPassword)( XW_UtilCtxt* uc, const XP_UCHAR* name,
|
|
|
|
XP_UCHAR* buf, XP_U16* len );
|
|
|
|
|
|
|
|
void (*m_util_trayHiddenChange)(XW_UtilCtxt* uc,
|
2006-05-19 13:44:05 +00:00
|
|
|
XW_TrayVisState newState,
|
|
|
|
XP_U16 nVisibleRows );
|
2010-04-08 04:14:14 +00:00
|
|
|
void (*m_util_yOffsetChange)(XW_UtilCtxt* uc, XP_U16 maxOffset,
|
|
|
|
XP_U16 oldOffset, XP_U16 newOffset );
|
2008-02-27 05:43:27 +00:00
|
|
|
#ifdef XWFEATURE_TURNCHANGENOTIFY
|
2008-02-26 13:46:33 +00:00
|
|
|
void (*m_util_turnChanged)(XW_UtilCtxt* uc);
|
2008-02-27 05:43:27 +00:00
|
|
|
#endif
|
2003-11-01 05:35:29 +00:00
|
|
|
void (*m_util_notifyGameOver)( XW_UtilCtxt* uc );
|
|
|
|
|
|
|
|
XP_Bool (*m_util_hiliteCell)( XW_UtilCtxt* uc, XP_U16 col, XP_U16 row );
|
|
|
|
|
|
|
|
XP_Bool (*m_util_engineProgressCallback)( XW_UtilCtxt* uc );
|
|
|
|
|
2005-06-23 04:16:53 +00:00
|
|
|
void (*m_util_setTimer)( XW_UtilCtxt* uc, XWTimerReason why, XP_U16 when,
|
2007-05-26 14:14:01 +00:00
|
|
|
XWTimerProc proc, void* closure );
|
2009-09-21 12:49:08 +00:00
|
|
|
void (*m_util_clearTimer)( XW_UtilCtxt* uc, XWTimerReason why );
|
2003-11-01 05:35:29 +00:00
|
|
|
|
|
|
|
void (*m_util_requestTime)( XW_UtilCtxt* uc );
|
|
|
|
|
2008-04-08 03:55:53 +00:00
|
|
|
XP_Bool (*m_util_altKeyDown)( XW_UtilCtxt* uc );
|
|
|
|
|
2003-11-01 05:35:29 +00:00
|
|
|
XP_U32 (*m_util_getCurSeconds)( XW_UtilCtxt* uc );
|
|
|
|
|
|
|
|
DictionaryCtxt* (*m_util_makeEmptyDict)( XW_UtilCtxt* uc );
|
|
|
|
|
2007-02-03 17:54:20 +00:00
|
|
|
const XP_UCHAR* (*m_util_getUserString)( XW_UtilCtxt* uc,
|
|
|
|
XP_U16 stringCode );
|
2003-11-01 05:35:29 +00:00
|
|
|
|
|
|
|
XP_Bool (*m_util_warnIllegalWord)( XW_UtilCtxt* uc, BadWordInfo* bwi,
|
|
|
|
XP_U16 turn, XP_Bool turnLost );
|
2008-10-24 08:56:20 +00:00
|
|
|
|
|
|
|
void (*m_util_remSelected)(XW_UtilCtxt* uc);
|
|
|
|
|
2011-08-29 20:36:01 -07:00
|
|
|
#ifndef XWFEATURE_MINIWIN
|
|
|
|
void (*m_util_bonusSquareHeld)( XW_UtilCtxt* uc, XWBonusType bonus );
|
2011-09-02 18:36:03 -07:00
|
|
|
void (*m_util_playerScoreHeld)( XW_UtilCtxt* uc, XP_U16 player );
|
2011-08-29 20:36:01 -07:00
|
|
|
#endif
|
|
|
|
|
2009-01-03 23:54:25 +00:00
|
|
|
#ifndef XWFEATURE_STANDALONE_ONLY
|
2005-04-03 16:57:01 +00:00
|
|
|
void (*m_util_addrChange)( XW_UtilCtxt* uc, const CommsAddrRec* oldAddr,
|
2006-09-08 07:14:24 +00:00
|
|
|
const CommsAddrRec* newAddr );
|
2010-09-10 01:30:40 -07:00
|
|
|
void (*m_util_setIsServer)(XW_UtilCtxt* uc, XP_Bool isServer );
|
2003-11-01 05:35:29 +00:00
|
|
|
#endif
|
|
|
|
|
2004-06-25 06:39:24 +00:00
|
|
|
#ifdef XWFEATURE_SEARCHLIMIT
|
|
|
|
XP_Bool (*m_util_getTraySearchLimits)(XW_UtilCtxt* uc,
|
|
|
|
XP_U16* min, XP_U16* max );
|
|
|
|
#endif
|
|
|
|
|
2010-10-03 18:11:51 -07:00
|
|
|
#ifdef XWFEATURE_CHAT
|
|
|
|
void (*m_util_showChat)( XW_UtilCtxt* uc, const XP_UCHAR* const msg );
|
|
|
|
#endif
|
|
|
|
|
2003-11-01 05:35:29 +00:00
|
|
|
#ifdef SHOW_PROGRESS
|
2004-10-07 13:51:03 +00:00
|
|
|
void (*m_util_engineStarting)( XW_UtilCtxt* uc, XP_U16 nBlanks );
|
2003-11-01 05:35:29 +00:00
|
|
|
void (*m_util_engineStopping)( XW_UtilCtxt* uc );
|
|
|
|
#endif
|
2006-11-07 05:46:44 +00:00
|
|
|
|
2003-11-01 05:35:29 +00:00
|
|
|
} UtilVtable;
|
|
|
|
|
|
|
|
|
|
|
|
struct XW_UtilCtxt {
|
|
|
|
UtilVtable* vtable;
|
|
|
|
|
|
|
|
struct CurGameInfo* gameInfo;
|
|
|
|
|
|
|
|
void* closure;
|
|
|
|
MPSLOT
|
|
|
|
};
|
|
|
|
|
|
|
|
#define util_getVTManager(uc) \
|
|
|
|
(uc)->vtable->m_util_getVTManager((uc))
|
|
|
|
|
|
|
|
#define util_makeStreamFromAddr(uc,a) \
|
|
|
|
(uc)->vtable->m_util_makeStreamFromAddr((uc),(a))
|
|
|
|
|
|
|
|
#define util_getSquareBonus(uc,m,c,r) \
|
|
|
|
(uc)->vtable->m_util_getSquareBonus((uc),(m),(c),(r))
|
|
|
|
|
|
|
|
#define util_userError(uc,err) \
|
|
|
|
(uc)->vtable->m_util_userError((uc),(err))
|
|
|
|
|
|
|
|
#define util_userQuery(uc,qcode,str) \
|
|
|
|
(uc)->vtable->m_util_userQuery((uc),(qcode),(str))
|
|
|
|
|
2003-11-16 17:11:33 +00:00
|
|
|
#define util_userPickTile( uc, w, n, tx, nt ) \
|
|
|
|
(uc)->vtable->m_util_userPickTile( (uc), (w), (n), (tx), (nt) )
|
2003-11-01 05:35:29 +00:00
|
|
|
#define util_askPassword( uc, n, b, lp ) \
|
|
|
|
(uc)->vtable->m_util_askPassword( (uc), (n), (b), (lp) )
|
|
|
|
|
2006-05-19 13:44:05 +00:00
|
|
|
#define util_trayHiddenChange( uc, b, n ) \
|
|
|
|
(uc)->vtable->m_util_trayHiddenChange((uc), (b), (n))
|
2003-11-01 05:35:29 +00:00
|
|
|
|
2010-04-08 04:14:14 +00:00
|
|
|
#define util_yOffsetChange( uc, m, o, n ) \
|
|
|
|
(uc)->vtable->m_util_yOffsetChange((uc), (m), (o), (n) )
|
2003-11-01 05:35:29 +00:00
|
|
|
|
2008-02-27 05:43:27 +00:00
|
|
|
#ifdef XWFEATURE_TURNCHANGENOTIFY
|
|
|
|
# define util_turnChanged( uc ) \
|
2008-02-26 13:46:33 +00:00
|
|
|
(uc)->vtable->m_util_turnChanged((uc) )
|
2008-02-27 05:43:27 +00:00
|
|
|
#else
|
|
|
|
# define util_turnChanged( uc )
|
|
|
|
#endif
|
2008-02-26 13:46:33 +00:00
|
|
|
|
2003-11-01 05:35:29 +00:00
|
|
|
#define util_notifyGameOver( uc ) \
|
|
|
|
(uc)->vtable->m_util_notifyGameOver((uc))
|
|
|
|
|
|
|
|
#define util_hiliteCell( uc, c, r ) \
|
|
|
|
(uc)->vtable->m_util_hiliteCell((uc), (c), (r))
|
|
|
|
|
|
|
|
#define util_engineProgressCallback( uc ) \
|
|
|
|
(uc)->vtable->m_util_engineProgressCallback((uc))
|
|
|
|
|
2005-06-23 04:16:53 +00:00
|
|
|
#define util_setTimer( uc, why, when, proc, clos ) \
|
|
|
|
(uc)->vtable->m_util_setTimer((uc),(why),(when),(proc),(clos))
|
2009-09-21 12:49:08 +00:00
|
|
|
#define util_clearTimer( uc, why ) \
|
|
|
|
(uc)->vtable->m_util_clearTimer((uc),(why))
|
2003-11-01 05:35:29 +00:00
|
|
|
|
|
|
|
#define util_requestTime( uc ) \
|
|
|
|
(uc)->vtable->m_util_requestTime((uc))
|
|
|
|
|
2008-04-08 03:55:53 +00:00
|
|
|
#define util_altKeyDown( uc ) \
|
|
|
|
(uc)->vtable->m_util_altKeyDown((uc))
|
|
|
|
|
2003-11-01 05:35:29 +00:00
|
|
|
#define util_getCurSeconds(uc) \
|
|
|
|
(uc)->vtable->m_util_getCurSeconds((uc))
|
|
|
|
|
|
|
|
#define util_makeEmptyDict( uc ) \
|
|
|
|
(uc)->vtable->m_util_makeEmptyDict((uc))
|
|
|
|
|
|
|
|
#define util_getUserString( uc, c ) \
|
|
|
|
(uc)->vtable->m_util_getUserString((uc),(c))
|
|
|
|
|
|
|
|
#define util_warnIllegalWord( uc, w, p, b ) \
|
|
|
|
(uc)->vtable->m_util_warnIllegalWord((uc),(w),(p),(b))
|
|
|
|
|
2008-10-24 08:56:20 +00:00
|
|
|
#define util_remSelected( uc ) \
|
|
|
|
(uc)->vtable->m_util_remSelected((uc))
|
|
|
|
|
2011-08-29 20:36:01 -07:00
|
|
|
#ifndef XWFEATURE_MINIWIN
|
|
|
|
# define util_bonusSquareHeld( uc, b ) \
|
|
|
|
(uc)->vtable->m_util_bonusSquareHeld( (uc), (b) )
|
2011-09-02 18:36:03 -07:00
|
|
|
# define util_playerScoreHeld( uc, player ) \
|
|
|
|
(uc)->vtable->m_util_playerScoreHeld( (uc), (player) )
|
2011-08-29 20:36:01 -07:00
|
|
|
#endif
|
|
|
|
|
2009-01-03 23:54:25 +00:00
|
|
|
#ifndef XWFEATURE_STANDALONE_ONLY
|
|
|
|
# define util_addrChange( uc, addro, addrn ) \
|
2006-09-08 07:14:24 +00:00
|
|
|
(uc)->vtable->m_util_addrChange((uc), (addro), (addrn))
|
2010-09-10 01:30:40 -07:00
|
|
|
# define util_setIsServer( uc, is ) \
|
|
|
|
(uc)->vtable->m_util_setIsServer((uc), (is))
|
2009-01-05 02:07:30 +00:00
|
|
|
# else
|
|
|
|
# define util_addrChange( uc, addro, addrn )
|
2003-11-01 05:35:29 +00:00
|
|
|
#endif
|
|
|
|
|
2004-06-25 06:39:24 +00:00
|
|
|
#ifdef XWFEATURE_SEARCHLIMIT
|
|
|
|
#define util_getTraySearchLimits(uc,min,max) \
|
|
|
|
(uc)->vtable->m_util_getTraySearchLimits((uc), (min), (max))
|
|
|
|
#endif
|
|
|
|
|
2010-10-03 18:11:51 -07:00
|
|
|
#ifdef XWFEATURE_CHAT
|
|
|
|
# define util_showChat( uc, m ) (uc)->vtable->m_util_showChat((uc),(m))
|
|
|
|
#endif
|
2004-06-25 06:39:24 +00:00
|
|
|
|
2003-11-01 05:35:29 +00:00
|
|
|
# ifdef SHOW_PROGRESS
|
2004-10-07 13:51:03 +00:00
|
|
|
# define util_engineStarting( uc, nb ) \
|
|
|
|
(uc)->vtable->m_util_engineStarting((uc),(nb))
|
2003-11-01 05:35:29 +00:00
|
|
|
# define util_engineStopping( uc ) \
|
|
|
|
(uc)->vtable->m_util_engineStopping((uc))
|
|
|
|
# else
|
2004-10-30 16:59:07 +00:00
|
|
|
# define util_engineStarting( uc, nb )
|
2003-11-01 05:35:29 +00:00
|
|
|
# define util_engineStopping( uc )
|
|
|
|
# endif
|
|
|
|
|
|
|
|
#endif
|