summaryrefslogtreecommitdiff
path: root/apps/plugins/puzzles/src/loopgen.h
diff options
context:
space:
mode:
authorFranklin Wei <git@fwei.tk>2017-04-29 18:21:56 -0400
committerFranklin Wei <git@fwei.tk>2017-04-29 18:24:42 -0400
commit881746789a489fad85aae8317555f73dbe261556 (patch)
treecec2946362c4698c8db3c10f3242ef546c2c22dd /apps/plugins/puzzles/src/loopgen.h
parent03dd4b92be7dcd5c8ab06da3810887060e06abd5 (diff)
downloadrockbox-881746789a489fad85aae8317555f73dbe261556.tar.gz
rockbox-881746789a489fad85aae8317555f73dbe261556.zip
puzzles: refactor and resync with upstream
This brings puzzles up-to-date with upstream revision 2d333750272c3967cfd5cd3677572cddeaad5932, though certain changes made by me, including cursor-only Untangle and some compilation fixes remain. Upstream code has been moved to its separate subdirectory and future syncs can be done by simply copying over the new sources. Change-Id: Ia6506ca5f78c3627165ea6791d38db414ace0804
Diffstat (limited to 'apps/plugins/puzzles/src/loopgen.h')
-rw-r--r--apps/plugins/puzzles/src/loopgen.h35
1 files changed, 35 insertions, 0 deletions
diff --git a/apps/plugins/puzzles/src/loopgen.h b/apps/plugins/puzzles/src/loopgen.h
new file mode 100644
index 0000000000..079c87c576
--- /dev/null
+++ b/apps/plugins/puzzles/src/loopgen.h
@@ -0,0 +1,35 @@
1/*
2 * loopgen.h: interface file for loop generation functions for grid.[ch].
3 */
4
5#ifndef _LOOPGEN_H
6#define _LOOPGEN_H
7
8#include "puzzles.h"
9#include "grid.h"
10
11enum face_colour { FACE_WHITE, FACE_GREY, FACE_BLACK };
12
13/* face should be of type grid_face* here. */
14#define FACE_COLOUR(face) \
15 ( (face) == NULL ? FACE_BLACK : \
16 board[(face) - g->faces] )
17
18typedef int (*loopgen_bias_fn_t)(void *ctx, char *board, int face);
19
20/* 'board' should be a char array whose length is the same as
21 * g->num_faces: this will be filled in with FACE_WHITE or FACE_BLACK
22 * after loop generation.
23 *
24 * If 'bias' is non-null, it should be a user-provided function which
25 * rates a half-finished board (i.e. may include some FACE_GREYs) for
26 * desirability; this will cause the loop generator to bias in favour
27 * of loops with a high return value from that function. The 'face'
28 * parameter to the bias function indicates which face of the grid has
29 * been modified since the last call; it is guaranteed that only one
30 * will have been (so that bias functions can work incrementally
31 * rather than re-scanning the whole grid on every call). */
32extern void generate_loop(grid *g, char *board, random_state *rs,
33 loopgen_bias_fn_t bias, void *biasctx);
34
35#endif