mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-15 15:41:24 +01:00
use actual rather than max possible board dimensions to apportion
space, fixing crashes when max upped to 32. Will still fail as actual size approaches that number.
This commit is contained in:
parent
86d5778ec3
commit
379e5f1d96
1 changed files with 6 additions and 4 deletions
|
@ -1569,15 +1569,16 @@ positionSizeStuff( CursesAppGlobals* globals, int width, int height )
|
||||||
XP_U16 cellWidth, cellHt, scoreLeft, scoreWidth;
|
XP_U16 cellWidth, cellHt, scoreLeft, scoreWidth;
|
||||||
BoardCtxt* board = globals->cGlobals.game.board;
|
BoardCtxt* board = globals->cGlobals.game.board;
|
||||||
int remWidth = width;
|
int remWidth = width;
|
||||||
|
int nRows = globals->cGlobals.params->gi.boardSize;
|
||||||
|
|
||||||
cellWidth = CURSES_CELL_WIDTH;
|
cellWidth = CURSES_CELL_WIDTH;
|
||||||
cellHt = CURSES_CELL_HT;
|
cellHt = CURSES_CELL_HT;
|
||||||
board_setPos( board, BOARD_OFFSET, BOARD_OFFSET,
|
board_setPos( board, BOARD_OFFSET, BOARD_OFFSET,
|
||||||
cellWidth * MAX_COLS, cellHt * MAX_ROWS,
|
cellWidth * nRows, cellHt * nRows,
|
||||||
cellWidth, XP_FALSE );
|
cellWidth, XP_FALSE );
|
||||||
/* board_setScale( board, cellWidth, cellHt ); */
|
/* board_setScale( board, cellWidth, cellHt ); */
|
||||||
scoreLeft = (cellWidth * MAX_COLS);// + BOARD_SCORE_PADDING;
|
scoreLeft = (cellWidth * nRows);// + BOARD_SCORE_PADDING;
|
||||||
remWidth -= cellWidth * MAX_COLS;
|
remWidth -= cellWidth * nRows;
|
||||||
|
|
||||||
/* If the scoreboard will right of the board, put it there. Otherwise try
|
/* If the scoreboard will right of the board, put it there. Otherwise try
|
||||||
to fit it below the boards. */
|
to fit it below the boards. */
|
||||||
|
@ -1591,8 +1592,9 @@ positionSizeStuff( CursesAppGlobals* globals, int width, int height )
|
||||||
trayTop = 8;
|
trayTop = 8;
|
||||||
} else {
|
} else {
|
||||||
trayLeft = BOARD_OFFSET;
|
trayLeft = BOARD_OFFSET;
|
||||||
trayTop = BOARD_OFFSET + (cellHt * MAX_ROWS);
|
trayTop = BOARD_OFFSET + (cellHt * nRows);
|
||||||
if ( trayTop + trayHt > height ) {
|
if ( trayTop + trayHt > height ) {
|
||||||
|
XP_ASSERT( height > trayTop );
|
||||||
trayHt = height - trayTop;
|
trayHt = height - trayTop;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue