From 980880be1f2801b2a69fcc67abc0f5827fd106f2 Mon Sep 17 00:00:00 2001 From: Simon Tatham Date: Sat, 2 Apr 2011 16:19:12 +0000 Subject: Add a function to every game backend which indicates whether a game state is in a solved position, and a midend function wrapping it. (Or, at least, a situation in which further play is pointless. The point is, given that game state, would it be a good idea for a front end that does that sort of thing to proactively provide the option to start a fresh game?) [originally from svn r9140] --- twiddle.c | 6 ++++++ 1 file changed, 6 insertions(+) (limited to 'twiddle.c') diff --git a/twiddle.c b/twiddle.c index 36b19e1..6acf4cf 100644 --- a/twiddle.c +++ b/twiddle.c @@ -1070,6 +1070,11 @@ static float game_flash_length(game_state *oldstate, game_state *newstate, return 0.0F; } +static int game_is_solved(game_state *state) +{ + return state->completed; +} + static void game_redraw(drawing *dr, game_drawstate *ds, game_state *oldstate, game_state *state, int dir, game_ui *ui, float animtime, float flashtime) @@ -1287,6 +1292,7 @@ const struct game thegame = { game_redraw, game_anim_length, game_flash_length, + game_is_solved, FALSE, FALSE, game_print_size, game_print, TRUE, /* wants_statusbar */ FALSE, game_timing_state, -- cgit v1.1