mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-16 15:41:16 +01:00
move arrow to where removed tile was, and set its direction based on
whether removed tile and the next tile are in the same column or row.
This commit is contained in:
parent
c2956f4064
commit
bfc68656cb
3 changed files with 44 additions and 25 deletions
|
@ -88,9 +88,7 @@ static void dictChanged( void* p_board, XP_S16 playerNum,
|
||||||
|
|
||||||
static void boardTurnChanged( void* board );
|
static void boardTurnChanged( void* board );
|
||||||
static void boardGameOver( void* board );
|
static void boardGameOver( void* board );
|
||||||
static void setArrow( BoardCtxt* board, XP_U16 row, XP_U16 col );
|
static void setArrow( BoardCtxt* board, XP_U16 row, XP_U16 col, XP_Bool* vp );
|
||||||
static void setArrowFor( BoardCtxt* board, XP_U16 player, XP_U16 col,
|
|
||||||
XP_U16 row );
|
|
||||||
static XP_Bool setArrowVisible( BoardCtxt* board, XP_Bool visible );
|
static XP_Bool setArrowVisible( BoardCtxt* board, XP_Bool visible );
|
||||||
|
|
||||||
#ifdef XWFEATURE_MINIWIN
|
#ifdef XWFEATURE_MINIWIN
|
||||||
|
@ -108,7 +106,7 @@ static XP_Bool setTrayVisState( BoardCtxt* board, XW_TrayVisState newState );
|
||||||
static XP_Bool advanceArrow( BoardCtxt* board );
|
static XP_Bool advanceArrow( BoardCtxt* board );
|
||||||
static XP_Bool exitTradeMode( BoardCtxt* board );
|
static XP_Bool exitTradeMode( BoardCtxt* board );
|
||||||
|
|
||||||
static XP_Bool getArrow( BoardCtxt* board, XP_U16* col, XP_U16* row );
|
static XP_Bool getArrow( const BoardCtxt* board, XP_U16* col, XP_U16* row );
|
||||||
static XP_Bool setArrowVisibleFor( BoardCtxt* board, XP_U16 player,
|
static XP_Bool setArrowVisibleFor( BoardCtxt* board, XP_U16 player,
|
||||||
XP_Bool visible );
|
XP_Bool visible );
|
||||||
static XP_Bool board_moveArrow( BoardCtxt* board, XP_Key cursorKey );
|
static XP_Bool board_moveArrow( BoardCtxt* board, XP_Key cursorKey );
|
||||||
|
@ -1696,10 +1694,6 @@ board_replaceNTiles( BoardCtxt* board, XP_U16 nTiles )
|
||||||
result = XP_TRUE;
|
result = XP_TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( result ) {
|
|
||||||
(void)setArrowVisible( board, XP_FALSE );
|
|
||||||
}
|
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2531,7 +2525,7 @@ tryReplaceTile( BoardCtxt* board, XP_U16 pencol, XP_U16 penrow )
|
||||||
|
|
||||||
model_moveBoardToTray( board->model, board->selPlayer,
|
model_moveBoardToTray( board->model, board->selPlayer,
|
||||||
modcol, modrow, -1 );
|
modcol, modrow, -1 );
|
||||||
setArrow( board, pencol, penrow );
|
setArrow( board, pencol, penrow, NULL );
|
||||||
result = XP_TRUE;
|
result = XP_TRUE;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -3122,7 +3116,7 @@ board_moveArrow( BoardCtxt* board, XP_Key cursorKey )
|
||||||
changed = figureNextLoc( board, cursorKey, XP_TRUE, XP_FALSE,
|
changed = figureNextLoc( board, cursorKey, XP_TRUE, XP_FALSE,
|
||||||
&col, &row, NULL );
|
&col, &row, NULL );
|
||||||
if ( changed ) {
|
if ( changed ) {
|
||||||
(void)setArrow( board, col, row );
|
(void)setArrow( board, col, row, NULL );
|
||||||
}
|
}
|
||||||
return changed;
|
return changed;
|
||||||
} /* board_moveArrow */
|
} /* board_moveArrow */
|
||||||
|
@ -3210,14 +3204,16 @@ static XP_Bool
|
||||||
replaceLastTile( BoardCtxt* board )
|
replaceLastTile( BoardCtxt* board )
|
||||||
{
|
{
|
||||||
XP_Bool result = XP_FALSE;
|
XP_Bool result = XP_FALSE;
|
||||||
XP_U16 tilesInMove = model_getCurrentMoveCount( board->model,
|
XP_S16 turn = board->selPlayer;
|
||||||
board->selPlayer );
|
XP_U16 tilesInMove = model_getCurrentMoveCount( board->model, turn );
|
||||||
|
|
||||||
if ( tilesInMove > 0 ) {
|
if ( tilesInMove > 0 ) {
|
||||||
XP_U16 col, row;
|
XP_U16 col, row;
|
||||||
Tile tile;
|
Tile tile;
|
||||||
XP_Bool isBlank;
|
XP_Bool isBlank;
|
||||||
XP_S16 index;
|
XP_S16 index;
|
||||||
|
XP_Bool isVertical;
|
||||||
|
XP_Bool directionKnown =
|
||||||
|
model_getCurrentMoveIsVertical( board->model, turn, &isVertical );
|
||||||
|
|
||||||
index = -1;
|
index = -1;
|
||||||
model_getCurrentMoveTile( board->model, board->selPlayer, &index,
|
model_getCurrentMoveTile( board->model, board->selPlayer, &index,
|
||||||
|
@ -3225,8 +3221,7 @@ replaceLastTile( BoardCtxt* board )
|
||||||
model_moveBoardToTray( board->model, board->selPlayer, col, row, -1 );
|
model_moveBoardToTray( board->model, board->selPlayer, col, row, -1 );
|
||||||
|
|
||||||
flipIf( board, col, row, &col, &row );
|
flipIf( board, col, row, &col, &row );
|
||||||
setArrow( board, col, row );
|
setArrow( board, col, row, directionKnown? &isVertical : NULL );
|
||||||
|
|
||||||
result = XP_TRUE;
|
result = XP_TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3320,35 +3315,33 @@ moveKeyTileToBoard( BoardCtxt* board, XP_Key cursorKey, XP_Bool* gotArrow )
|
||||||
#endif /* #ifdef KEY_SUPPORT */
|
#endif /* #ifdef KEY_SUPPORT */
|
||||||
|
|
||||||
static void
|
static void
|
||||||
setArrowFor( BoardCtxt* board, XP_U16 player, XP_U16 col, XP_U16 row )
|
setArrow( BoardCtxt* board, XP_U16 col, XP_U16 row, XP_Bool* vertp )
|
||||||
{
|
{
|
||||||
|
XP_U16 player = board->selPlayer;
|
||||||
BoardArrow* arrow = &board->pti[player].boardArrow;
|
BoardArrow* arrow = &board->pti[player].boardArrow;
|
||||||
invalCell( board, arrow->col, arrow->row );
|
invalCell( board, arrow->col, arrow->row );
|
||||||
invalCell( board, col, row );
|
invalCell( board, col, row );
|
||||||
|
|
||||||
arrow->col = (XP_U8)col;
|
arrow->col = (XP_U8)col;
|
||||||
arrow->row = (XP_U8)row;
|
arrow->row = (XP_U8)row;
|
||||||
|
if ( !!vertp ) {
|
||||||
|
arrow->vert = *vertp;
|
||||||
|
}
|
||||||
|
|
||||||
scrollIntoView( board, col, row );
|
scrollIntoView( board, col, row );
|
||||||
} /* setArrowFor */
|
|
||||||
|
|
||||||
static void
|
|
||||||
setArrow( BoardCtxt* board, XP_U16 col, XP_U16 row )
|
|
||||||
{
|
|
||||||
setArrowFor( board, board->selPlayer, col, row );
|
|
||||||
} /* setArrow */
|
} /* setArrow */
|
||||||
|
|
||||||
static XP_Bool
|
static XP_Bool
|
||||||
getArrowFor( BoardCtxt* board, XP_U16 player, XP_U16* col, XP_U16* row )
|
getArrowFor( const BoardCtxt* board, XP_U16 player, XP_U16* col, XP_U16* row )
|
||||||
{
|
{
|
||||||
BoardArrow* arrow = &board->pti[player].boardArrow;
|
const BoardArrow* arrow = &board->pti[player].boardArrow;
|
||||||
*col = arrow->col;
|
*col = arrow->col;
|
||||||
*row = arrow->row;
|
*row = arrow->row;
|
||||||
return arrow->visible;
|
return arrow->visible;
|
||||||
} /* getArrowFor */
|
} /* getArrowFor */
|
||||||
|
|
||||||
static XP_Bool
|
static XP_Bool
|
||||||
getArrow( BoardCtxt* board, XP_U16* col, XP_U16* row )
|
getArrow( const BoardCtxt* board, XP_U16* col, XP_U16* row )
|
||||||
{
|
{
|
||||||
return getArrowFor( board, board->selPlayer, col, row );
|
return getArrowFor( board, board->selPlayer, col, row );
|
||||||
} /* getArrow */
|
} /* getArrow */
|
||||||
|
|
|
@ -1162,6 +1162,29 @@ model_getCurrentMoveCount( const ModelCtxt* model, XP_S16 turn )
|
||||||
return player->nPending;
|
return player->nPending;
|
||||||
} /* model_getCurrentMoveCount */
|
} /* model_getCurrentMoveCount */
|
||||||
|
|
||||||
|
XP_Bool
|
||||||
|
model_getCurrentMoveIsVertical( const ModelCtxt* model, XP_S16 turn,
|
||||||
|
XP_Bool* isVertical )
|
||||||
|
{
|
||||||
|
XP_ASSERT( turn >= 0 );
|
||||||
|
const PlayerCtxt* player = &model->players[turn];
|
||||||
|
XP_U16 nPending = player->nPending;
|
||||||
|
XP_Bool known = 2 <= nPending;
|
||||||
|
if ( known ) {
|
||||||
|
--nPending;
|
||||||
|
if ( player->pendingTiles[nPending].col
|
||||||
|
== player->pendingTiles[nPending-1].col ) {
|
||||||
|
*isVertical = XP_TRUE;
|
||||||
|
} else if ( player->pendingTiles[nPending].row
|
||||||
|
== player->pendingTiles[nPending-1].row ) {
|
||||||
|
*isVertical = XP_FALSE;
|
||||||
|
} else {
|
||||||
|
known = XP_FALSE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return known;
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
model_getCurrentMoveTile( ModelCtxt* model, XP_S16 turn, XP_S16* index,
|
model_getCurrentMoveTile( ModelCtxt* model, XP_S16 turn, XP_S16* index,
|
||||||
Tile* tile, XP_U16* col, XP_U16* row,
|
Tile* tile, XP_U16* col, XP_U16* row,
|
||||||
|
|
|
@ -179,6 +179,9 @@ void model_addToCurrentMove( ModelCtxt* model, XP_S16 turn,
|
||||||
Tile tile, XP_Bool isBlank );
|
Tile tile, XP_Bool isBlank );
|
||||||
XP_U16 model_getCurrentMoveCount( const ModelCtxt* model, XP_S16 turn );
|
XP_U16 model_getCurrentMoveCount( const ModelCtxt* model, XP_S16 turn );
|
||||||
|
|
||||||
|
XP_Bool model_getCurrentMoveIsVertical( const ModelCtxt* model, XP_S16 turn,
|
||||||
|
XP_Bool* isHorizontal );
|
||||||
|
|
||||||
void model_getCurrentMoveTile( ModelCtxt* model, XP_S16 turn, XP_S16* index,
|
void model_getCurrentMoveTile( ModelCtxt* model, XP_S16 turn, XP_S16* index,
|
||||||
Tile* tile, XP_U16* col, XP_U16* row,
|
Tile* tile, XP_U16* col, XP_U16* row,
|
||||||
XP_Bool* isBlank );
|
XP_Bool* isBlank );
|
||||||
|
|
Loading…
Reference in a new issue