Author:
- Name: Bas de Bakker
Location: NL - Kingdom of the Netherlands (Netherlands)
To build:
make all
To use:
./bas1.sh
Judges’ remarks:
The output is supposed to be a 3D maze, but it is somewhat more than that. If you’ve seen any of the Maurits Escher’s works, you’ll know what we’re talking about.
When trying to run the program with command line arguments, be generous.
Author’s remarks:
BEMAZING
“You’re in a twisty little maze of beams, all different.”
Bemazing
is “amazing” taken one step (letter) further. Bemazing
creates a 3D maze of beams. Try to go from the entrance (the
unfinished beam in one corner) to the exit (the unfinished beam in the
opposite corner) or vice versa.
For maximum portability, Bemazing
is not tied to any window system, but
creates postscript output. The picture it makes will fit on either A4 or letter
size paper.
In addition, because postscript is rather verbose, Bemazing
creates
the postscript in gzip(1)
format, in order to save precious bits on your
hard disk for the latest version of GNU
Emacs (after all, you wouldn’t
want to use an editor without a psychoanalyze-pinhead function, now
would you). Again for maximum portability, Bemazing
will take special
care that the binary output will not contain any newline or return
characters that may get weird treatment on systems that do not use the
One True Line Separator.
NOTES
Be sure to view the source with something that can display characters
\240-\377
. Use LESSCHARSET=latin1
, M-x
standard-display-european
in
GNU Emacs etc. The source does not use characters in the range
\200-\237
(we are not an unnamed word processor that tends to create
HTML containing these control characters).
Because this is not the obfuscated postscript contest, the postscript
does not contain any for
, if
or other control structures. All the
logic is in the C code. There are only a few straightforward def
s,
because otherwise the output would become much larger.
Try running Bemazing
with command line arguments and see what
happens. (But note that the program only guarantees that there
actually is a route from entrance to exit if you run it without
command line arguments.)
Inventory for 1998/bas1
Primary files
- bas1.c - entry source code
- Makefile - entry Makefile
- bas1.orig.c - original source code
- bas1.sh - script to run entry
Secondary files
- 1998_bas1.tar.bz2 - download entry tarball
- README.md - markdown source for this web page
- .entry.json - entry summary and manifest in JSON
- .gitignore - list of files that should not be committed under git
- .path - directory path from top level directory
- index.html - this web page