X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ian/git?a=blobdiff_plain;f=Recipe;h=3b57ef5e5413f7c5ffd2a8f6fa20b505ad6aaf9f;hb=a0a581c8b5422bf0c5ed3fde6aa25811e4eb89fc;hp=82238619c017a51f0b0670d6acaa37fff08e6c8e;hpb=0c55b7e16f6c1c3bc0c332ebdbfff9686262804b;p=sgt-puzzles.git diff --git a/Recipe b/Recipe index 8223861..3b57ef5 100644 --- a/Recipe +++ b/Recipe @@ -8,37 +8,60 @@ !name puzzles -!makefile gtk Makefile +!makefile gtk Makefile.gtk +!makefile am Makefile.am !makefile vc Makefile.vc +!makefile wce Makefile.wce !makefile cygwin Makefile.cyg !makefile osx Makefile.osx +!makefile gnustep Makefile.gnustep +!makefile nestedvm Makefile.nestedvm +!makefile emcc Makefile.emcc +!makefile clangcl Makefile.clangcl -WINDOWS = windows user32.lib gdi32.lib comctl32.lib -COMMON = midend misc malloc random -NET = net tree234 -NETSLIDE = netslide tree234 - -ALL = list NET NETSLIDE cube fifteen sixteen rect pattern solo - -net : [X] gtk COMMON NET -netslide : [X] gtk COMMON NETSLIDE -cube : [X] gtk COMMON cube -fifteen : [X] gtk COMMON fifteen -sixteen : [X] gtk COMMON sixteen -rect : [X] gtk COMMON rect -pattern : [X] gtk COMMON pattern -solo : [X] gtk COMMON solo - -# The Windows Net shouldn't be called `net.exe' since Windows -# already has a reasonably important utility program by that name! -netgame : [G] WINDOWS COMMON NET -netslide : [G] WINDOWS COMMON NETSLIDE -cube : [G] WINDOWS COMMON cube -fifteen : [G] WINDOWS COMMON fifteen -sixteen : [G] WINDOWS COMMON sixteen -rect : [G] WINDOWS COMMON rect -pattern : [G] WINDOWS COMMON pattern -solo : [G] WINDOWS COMMON solo +!srcdir icons/ + +WINDOWS_COMMON = printing + + user32.lib gdi32.lib comctl32.lib comdlg32.lib winspool.lib +WINDOWS = windows WINDOWS_COMMON +COMMON = midend drawing misc malloc random version +GTK = gtk printing ps +# Objects needed for auxiliary command-line programs. +STANDALONE = nullfe random misc malloc + +ALL = list + +# First half of list.c. +!begin >list.c +/* + * list.c: List of pointers to puzzle structures, for monolithic + * platforms. + * + * This file is automatically generated by mkfiles.pl. Do not edit + * it directly, or the changes will be lost next time mkfiles.pl runs. + * Instead, edit Recipe and/or its *.R subfiles. + */ +#include "puzzles.h" +#define GAMELIST(A) \ +!end + +# Now each .R file adds part of the macro definition of GAMELIST to list.c. +!include *.R + +# Then we finish up list.c as follows: +!begin >list.c + +#define DECL(x) extern const game x; +#define REF(x) &x, +GAMELIST(DECL) +const game *gamelist[] = { GAMELIST(REF) }; +const int gamecount = lenof(gamelist); +!end + +# Unix standalone application for special-purpose obfuscation. +obfusc : [U] obfusc STANDALONE + +puzzles : [G] windows[COMBINED] WINDOWS_COMMON COMMON ALL noicon.res # Mac OS X unified application containing all the puzzles. Puzzles : [MX] osx osx.icns osx-info.plist COMMON ALL @@ -48,7 +71,6 @@ Puzzles : [MX] osx osx.icns osx-info.plist COMMON ALL # all the puzzles. Then I've also got some code in here to build a # distributable .dmg disk image. !begin osx -CFLAGS += -DCOMBINED Puzzles_extra = Puzzles.app/Contents/Resources/Help/index.html Puzzles.app/Contents/Resources/Help/index.html: \ Puzzles.app/Contents/Resources/Help osx-help.but puzzles.but @@ -72,13 +94,65 @@ Puzzles.dmg: Puzzles rm -f raw.dmg devicename !end -# The `nullgame' source file is a largely blank one, which contains -# all the correct function definitions to compile and link, but -# which defines the null game in which nothing is ever drawn and -# there are no valid moves. Its main purpose is to act as a -# template for writing new game definition source files. I include -# it in the Makefile because it will be worse than useless if it -# ever fails to compile, so it's important that it should actually -# be built on a regular basis. -nullgame : [X] gtk COMMON nullgame -nullgame : [G] WINDOWS COMMON nullgame +!begin am +bin_PROGRAMS = $(GAMES) +!end +!begin am_begin +GAMES = +!end + +# make install for Unix. +!begin gtk +install: + for i in $(GAMES); do \ + $(INSTALL_PROGRAM) -m 755 $(BINPREFIX)$$i $(DESTDIR)$(gamesdir)/$(BINPREFIX)$$i \ + || exit 1; \ + done +!end +!begin nestedvm +.PRECIOUS: %.class +%.class: %.mips + java -cp $(NESTEDVM)/build:$(NESTEDVM)/upstream/build/classgen/build \ + org.ibex.nestedvm.Compiler -outformat class -d . \ + PuzzleEngine $< + mv PuzzleEngine.class $@ + +org: + mkdir -p org/ibex/nestedvm/util + cp $(NESTEDVM)/build/org/ibex/nestedvm/Registers.class org/ibex/nestedvm + cp $(NESTEDVM)/build/org/ibex/nestedvm/UsermodeConstants.class org/ibex/nestedvm + cp $(NESTEDVM)/build/org/ibex/nestedvm/Runtime*.class org/ibex/nestedvm + cp $(NESTEDVM)/build/org/ibex/nestedvm/util/Platform*.class org/ibex/nestedvm/util + cp $(NESTEDVM)/build/org/ibex/nestedvm/util/Seekable*.class org/ibex/nestedvm/util + echo "Main-Class: PuzzleApplet" >applet.manifest + +PuzzleApplet.class: PuzzleApplet.java org + javac -source 1.3 -target 1.3 PuzzleApplet.java + +%.jar: %.class PuzzleApplet.class org + mv $< PuzzleEngine.class + jar cfm $@ applet.manifest PuzzleEngine.class PuzzleApplet*.class org + echo '' >$*.html + mv PuzzleEngine.class $< +!end + +# A benchmarking and testing target for the GTK puzzles. +!begin gtk +test: benchmark.html benchmark.txt + +benchmark.html: benchmark.txt benchmark.pl + ./benchmark.pl benchmark.txt > $@ + +benchmark.txt: benchmark.sh $(GAMES) + ./benchmark.sh > $@ + +!end +!begin am +test: benchmark.html benchmark.txt + +benchmark.html: benchmark.txt benchmark.pl + ./benchmark.pl benchmark.txt > $@ + +benchmark.txt: benchmark.sh $(GAMES) + ./benchmark.sh > $@ +!end