~mdw
/
sgt
/
puzzles
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Reinstate WinHelp topic now we have a manual chapter.
[sgt/puzzles]
/
netslide.c
diff --git
a/netslide.c
b/netslide.c
index
22517f4
..
5aa58b6
100644
(file)
--- a/
netslide.c
+++ b/
netslide.c
@@
-582,7
+582,7
@@
static char *new_game_desc(game_params *params, random_state *rs,
if (col == prevrowcol) {
if (dir == 2-prevdir)
continue; /* undoes last move */
if (col == prevrowcol) {
if (dir == 2-prevdir)
continue; /* undoes last move */
- else if ((nrepeats+1)*2 > h)
+ else if (
dir == prevdir &&
(nrepeats+1)*2 > h)
continue; /* makes fewer moves */
}
slide_col_int(w, h, tiles, 1 - dir, col);
continue; /* makes fewer moves */
}
slide_col_int(w, h, tiles, 1 - dir, col);
@@
-593,7
+593,7
@@
static char *new_game_desc(game_params *params, random_state *rs,
if (row == prevrowcol) {
if (dir == 4-prevdir)
continue; /* undoes last move */
if (row == prevrowcol) {
if (dir == 4-prevdir)
continue; /* undoes last move */
- else if ((nrepeats+1)*2 > w)
+ else if (
dir == prevdir &&
(nrepeats+1)*2 > w)
continue; /* makes fewer moves */
}
slide_row_int(w, h, tiles, 2 - dir, row);
continue; /* makes fewer moves */
}
slide_row_int(w, h, tiles, 2 - dir, row);
@@
-893,8
+893,8
@@
static void free_game(game_state *state)
sfree(state);
}
sfree(state);
}
-static game_state *solve_game(game_state *state, game_
aux_info *aux
,
- char **error)
+static game_state *solve_game(game_state *state, game_
state *currstate
,
+
game_aux_info *aux,
char **error)
{
game_state *ret;
{
game_state *ret;