diff options
| author | Ben Harris <bjh21@bjh21.me.uk> | 2023-01-31 21:05:47 +0000 |
|---|---|---|
| committer | Ben Harris <bjh21@bjh21.me.uk> | 2023-01-31 23:25:05 +0000 |
| commit | 789e11f8f802889904c7eb137d354877f647c88d (patch) | |
| tree | 67b9e13a88fa00a0b78912a7a4a9d4816ff0b3dd /loopy.c | |
| parent | ccd579e72ee8ea2de46786a6b296f37a0ecf5867 (diff) | |
| download | puzzles-789e11f8f802889904c7eb137d354877f647c88d.zip puzzles-789e11f8f802889904c7eb137d354877f647c88d.tar.gz puzzles-789e11f8f802889904c7eb137d354877f647c88d.tar.bz2 puzzles-789e11f8f802889904c7eb137d354877f647c88d.tar.xz | |
Remove various unused game functions
If can_configure is false, then the game's configure() and
custom_params() functions will never be called. If can_solve is false,
solve() will never be called. If can_format_as_text_ever is false,
can_format_as_text_now() and text_format() will never be called. If
can_print is false, print_size() and print() will never be called. If
is_timed is false, timing_state() will never be called.
In each case, almost all puzzles provided a function nonetheless. I
think this is because in Puzzles' early history there was no "game"
structure, so the functions had to be present for linking to work. But
now that everything indirects through the "game" structure, unused
functions can be left unimplemented and the corresponding pointers set
to NULL.
So now where the flags mentioned above are false, the corresponding
functions are omitted and the function pointers in the "game" structures
are NULL.
Diffstat (limited to 'loopy.c')
| -rw-r--r-- | loopy.c | 7 |
1 files changed, 1 insertions, 6 deletions
@@ -980,11 +980,6 @@ static void game_free_drawstate(drawing *dr, game_drawstate *ds) sfree(ds); } -static bool game_timing_state(const game_state *state, game_ui *ui) -{ - return true; -} - static float game_anim_length(const game_state *oldstate, const game_state *newstate, int dir, game_ui *ui) { @@ -3694,7 +3689,7 @@ const struct game thegame = { game_status, true, false, game_print_size, game_print, false /* wants_statusbar */, - false, game_timing_state, + false, NULL, /* timing_state */ 0, /* mouse_priorities */ }; |