This is Cat's Eye Technologies' distribution of tools for Cliff L. Biffle's Beatnik programming language. This includes an interpreter for Beatnik, some example Beatnik programs, a compiler from a wimpmode dialect called Wottasquare, and various small utilities which can (for example) search a dictionary file for all words with a given Scrabble score.
All tools are written in Python and located in the
You may wish to
cd to this directory to run them, or put this directory
on your executable search path.
beatnik.py (filename.beatnik|--eval 'Beatnik program source')
Interprets the Beatnik program in the given source file, or, if the
flag is given, the Beatnik program in the command line.
It considers the program to be written in Beatnik at face value. That is to say, it interprets the Beatnik specification as containing no errors, even though the author claims there is an error in it and won't divulge where. Don't expect this interpreter to work on the example programs supplied with the specification.
This interpreter seems to have the same behaviour as Catatonic Porpoise's Beatnik interpreter. This repository could stand to contain some test cases, though.
beatnik.py also takes a
--debug flag, which dumps some internal state
to standard error as the program is run.
beatnik.py also takes a
--tokenize flag, which prevents the program
from being run, and instead dumps a representation of the program in
Wottasquare to standard output. (It is essentially a Beatnik-to-Wottasquare
The following idiom can be used to find out what Scrabble score, and thus what Beatnik instruction, a particular word has.
$ beatnik.py --tokenize --eval 'Twenty' [12:DUP/Twenty]
wottasquare.py [--dictionary filename] filename.wottasquare
Reads the Wottasquare program from the given file and compiles it to an equivalent Beatnik program on standard output.
The Wottasquare language has the same semantics as the Beatnik language,
but each token has the form
n is the Scrabble score,
given in decimal, and
comment is optional, purely descriptive, and ignored
by translation tools such as this one.
Thus, the Wottasquare token
 could be translated to any word which has
a Scrabble score of 5, such as
slug, for use in Beatnik.
wottasquare.py looks in
words to use when translating Wottasquare to Beatnik. A different dictionary
file can be specified with the
--dictionary command-line argument. Note
that the dictionary file is parsed like a Beatnik source file would be;
punctuation is ignored (and treated as word seperator), etc.
There are two flags which trigger special behaviour:
wottasquare.py --find 'number-or-word'
Shows the Scrabble score of the given word (or treats the given argument as a Scrabble score, if it is numeric,) then dumps, to standard output, 20 words chosen from the dictionary file which have the same Scrabble score as the given word. Examples:
$ wottasquare.py --find chase 10 cubits badger gourmet pointers militant acumen engorges rehab fulled bibles bonny wantons motored blasters colossus warder howl colonial mainline frailer $ wottasquare.py --find 5 5 nip rode sitar lisle stilt uteri slug stain stool earls terns cot liter stout lob lab trots lotus altos boo
--find-all works similarly, but dumps all words from the dictionary
with the given Scrabble score to standard output.
Takes a string on the command line and writes, to standard output, a Wottasquare program which, when run, prints that string. It does not produce the most efficient such program.
This tool was used to generate
eg/hello-world.wottasquare, which was then
translated to Beatnik by
wottasquare.py, which was then manually formatted
and punctuated, with some (maybe 3%) words "adjusted" to make it flow better.
The contents of this repository are in the public domain. See the file UNLICENSE in this directory for more information.
git clone https://git.catseye.tc/Beatnik/
- Merge pull request #1 from angel-carvajal-coder/patch-1 Chris Pressey (commit: GitHub) 3 months ago
- Python 3 support angel-carvajal-coder (commit: GitHub) 6 months ago
- Added tag 0.1 for changeset d091af8634b9 Chris Pressey 6 years ago
- Add the 0-255 restrict, and fix the jump-back commands (I hope.) Chris Pressey 6 years ago
- Make wottasquare.py's dictionary file configurable. Chris Pressey 6 years ago
- beatnik.py's --tokenize now compiles Beatnik to Wottasquare. Chris Pressey 6 years ago
- Describe the tools available in the script/ directory. Chris Pressey 6 years ago
- Initial import of files for our Beatnik distribution. Chris Pressey 6 years ago