chiark / gitweb /
Move the benchmarking logic out into a script.
authorSimon Tatham <anakin@pobox.com>
Mon, 18 May 2015 15:17:49 +0000 (16:17 +0100)
committerSimon Tatham <anakin@pobox.com>
Mon, 18 May 2015 15:17:49 +0000 (16:17 +0100)
It's a pain having it in a rule in Makefile.gtk, which isn't even the
recommended makefile these days - it can't be re-run conveniently, and
there's no way to parametrise it. Now it can be run no matter which
makefile you're using, and it lets you narrow down to a subset of
games (though not presets). Other options could easily be added.

Recipe
benchmark.pl
benchmark.sh [new file with mode: 0755]

diff --git a/Recipe b/Recipe
index a2d30908b2873d7ecf432771f5b779120e3eff4e..4515ab9b5eca57a82f50f184e379106a5520b0e2 100644 (file)
--- a/Recipe
+++ b/Recipe
@@ -142,11 +142,7 @@ test: benchmark.html benchmark.txt
 benchmark.html: benchmark.txt benchmark.pl
        ./benchmark.pl benchmark.txt > $@
 
-benchmark.txt: $(GAMES)
-       for i in $(GAMES); do \
-               for params in $$(env -i ./$(BINPREFIX)$$i --list-presets | cut -f1 -d' '); do \
-                       env -i ./$(BINPREFIX)$$i --test-solve --time-generation --generate 100 $$params \
-                       || exit 1; \
-               done; \
-       done > $@
+benchmark.txt: benchmark.sh $(GAMES)
+       ./benchmark.sh > $@
+
 !end
index 131faafb25f91052db46ecf6b3fa1c8f1cae9b42..26a5a988215af5a8228846b0d74152b36c64e082 100755 (executable)
@@ -1,5 +1,7 @@
 #!/usr/bin/perl
 
+# Process the raw output from benchmark.sh into Javascript-ified HTML.
+
 use strict;
 use warnings;
 
diff --git a/benchmark.sh b/benchmark.sh
new file mode 100755 (executable)
index 0000000..b3af277
--- /dev/null
@@ -0,0 +1,27 @@
+#!/bin/sh
+
+# Run every puzzle in benchmarking mode, and generate a file of raw
+# data that benchmark.pl will format into a web page.
+
+# If any arguments are provided, use those as the list of games to
+# benchmark. Otherwise, read the full list from gamedesc.txt.
+if test $# = 0; then
+    set -- $(cut -f1 -d: < gamedesc.txt)
+fi
+
+failures=false
+
+for game in "$@"; do
+    # Use 'env -i' to suppress any environment variables that might
+    # change the preset list for a puzzle (e.g. user-defined extras)
+    presets=$(env -i ./$game --list-presets | cut -f1 -d' ')
+    for preset in $presets; do
+       if ! env -i ./$game --test-solve --time-generation \
+                            --generate 100 $preset;
+        then
+            echo "${game} ${preset} failed to generate" >&2
+        fi
+    done
+done
+
+if $failures; then exit 1; fi