Files
puzzles/list.c
Simon Tatham 97e93dbfff Peg Solitaire implementation, complete with a random board
generator. The generator is lacking in almost any kind of finesse,
but it produces puzzles which at least _I_ find plausibly puzzling.

[originally from svn r6052]
2005-07-04 19:42:55 +00:00

53 lines
1.2 KiB
C

/*
* list.c: List of puzzles.
*/
#include "puzzles.h"
/*
* The available games can be most easily enumerated by searching
* for the line in each game source file saying "#define thegame
* <gamename>". Hence, the following piece of shell/Perl should
* regenerate this list automatically:
perl -ne '/^#define thegame (\S+)/ and $1 ne "nullgame" and print "extern const game $1;\n"' *.c
echo -e '\nconst game *gamelist[] = {'
perl -ne '/^#define thegame (\S+)/ and $1 ne "nullgame" and print " &$1,\n"' *.c
echo -e '};\n\nconst int gamecount = lenof(gamelist);'
*/
extern const game cube;
extern const game fifteen;
extern const game flip;
extern const game guess;
extern const game mines;
extern const game net;
extern const game netslide;
extern const game pattern;
extern const game pegs;
extern const game rect;
extern const game samegame;
extern const game sixteen;
extern const game solo;
extern const game twiddle;
const game *gamelist[] = {
&cube,
&fifteen,
&flip,
&guess,
&mines,
&net,
&netslide,
&pattern,
&pegs,
&rect,
&samegame,
&sixteen,
&solo,
&twiddle,
};
const int gamecount = lenof(gamelist);