aboutsummaryrefslogtreecommitdiff
path: root/guess.c
diff options
context:
space:
mode:
authorBen Harris <bjh21@bjh21.me.uk>2022-12-07 00:18:56 +0000
committerBen Harris <bjh21@bjh21.me.uk>2022-12-07 00:43:45 +0000
commit09f2052fbfbc8a2136b09cf3a868c8cf9c239de0 (patch)
treefbfa1cfa819532ccbbbb7e453ff9e3a889430b90 /guess.c
parent14b434cb88d192a4a5cb2306115dec28cc69e714 (diff)
downloadpuzzles-09f2052fbfbc8a2136b09cf3a868c8cf9c239de0.zip
puzzles-09f2052fbfbc8a2136b09cf3a868c8cf9c239de0.tar.gz
puzzles-09f2052fbfbc8a2136b09cf3a868c8cf9c239de0.tar.bz2
puzzles-09f2052fbfbc8a2136b09cf3a868c8cf9c239de0.tar.xz
guess: Much more efficient keyboard interface
Now rather than mucking around with the cursor keys, you can just type a four-digit number and press Enter. Of course, if you still want to muck around with the cursor keys they work the same as before. Since Backspace was already assigned to clear the peg under the cursor, I haven't co-opted it for the obvious action of clearing the peg to the left of the cursor and moving the cursor left. The left arrow key is a reasonable alternative anyway. For consistency, 'L' now labels the pegs with numbers rather than letters, and is documented.
Diffstat (limited to 'guess.c')
-rw-r--r--guess.c14
1 files changed, 12 insertions, 2 deletions
diff --git a/guess.c b/guess.c
index 793c815..28fa0e0 100644
--- a/guess.c
+++ b/guess.c
@@ -414,7 +414,7 @@ struct game_ui {
int drag_col, drag_x, drag_y; /* x and y are *center* of peg! */
int drag_opeg; /* peg index, if dragged from a peg (from current guess), otherwise -1 */
- bool show_labels; /* label the colours with letters */
+ bool show_labels; /* label the colours with numbers */
pegrow hint;
};
@@ -900,6 +900,16 @@ static char *interpret_move(const game_state *from, game_ui *ui,
set_peg(&from->params, ui, ui->peg_cur, ui->colour_cur+1);
ret = UI_UPDATE;
}
+ } else if (((button >= '1' && button <= '0' + from->params.ncolours) ||
+ (button == '0' && from->params.ncolours == 10)) &&
+ ui->peg_cur < from->params.npegs) {
+ ui->display_cur = true;
+ /* Number keys insert a peg and advance the cursor. */
+ set_peg(&from->params, ui, ui->peg_cur,
+ button == '0' ? 10 : button - '0');
+ if (ui->peg_cur + 1 < from->params.npegs + ui->markable)
+ ui->peg_cur++;
+ ret = UI_UPDATE;
} else if (button == 'D' || button == 'd' || button == '\b') {
ui->display_cur = true;
set_peg(&from->params, ui, ui->peg_cur, 0);
@@ -1196,7 +1206,7 @@ static void draw_peg(drawing *dr, game_drawstate *ds, int cx, int cy,
if (labelled && col) {
char buf[2];
- buf[0] = 'a'-1 + col;
+ buf[0] = '0' + (col % 10);
buf[1] = '\0';
draw_text(dr, cx+PEGRAD, cy+PEGRAD, FONT_VARIABLE, PEGRAD,
ALIGN_HCENTRE|ALIGN_VCENTRE, COL_FRAME, buf);