Skip to main content

A brainfuck REPL.

Project description

A brainfuck REPL.

Installation

Pypi (recommended):

sudo pip3 install brainfoose

Manual installation using git master:

git clone https://github.com/abactel/brainfoose

cd brainfoose

pip install -r requirements.txt

sudo setup.py install

Usage

Usage:

brainfoose [--run_command=<programs>]

brainfoose [--tape_size=<tape_size>]

brainfoose [--verify_program=<tape_size>]

brainfoose (-h | --help)

brainfoose --version

Options:
-h, --help

Show this message

--version

Show version information

--run

Run a command without starting a REPL

--tape_size=<tape_size>

Set size of tape [default: 3000]

The syntax of the language is as follows:

Token

Meaning

?

Print a help screen

>

Increment the data pointer by 1.

<

Decrement the data pointer by 1.

+

Increment the value at the data pointer by 1.

-

Decrement the value at the data pointer by 1.

.

Output the byte at the data pointer. The byte is formatted to the character it represents.

,

Store a value at the data pointer’s position. The character is as a decimal byte representing the character. The character is accepted form a standard input prompt.

[

If the value at the data pointer is 0, move to matching ].

]

If the value at the data pointer is not 0, move to matching [.

$

Display tape up to last non-zero cell.

&

Reset tape.

%

Load program from file, syntax: %[filename].

The wikipedia page on brainfuck includes the following tutorial:

[ This program prints "Hello World!" and a newline to the screen, its
  length is 106 active command characters. [It is not the shortest.]

  This loop is an "initial comment loop", a simple way of adding a comment
  to a BF program such that you don't have to worry about any command
  characters. Any ".", ",", "+", "-", "<" and ">" characters are simply
  ignored, the "[" and "]" characters just have to be balanced. This
  loop and the commands it contains are ignored because the current cell
  defaults to a value of 0; the 0 value causes this loop to be skipped.
]
++++++++               Set Cell #0 to 8
[
    >++++               Add 4 to Cell #1; this will always set Cell #1 to 4
    [                   as the cell will be cleared by the loop
        >++             Add 2 to Cell #2
        >+++            Add 3 to Cell #3
        >+++            Add 3 to Cell #4
        >+              Add 1 to Cell #5
        <<<<-           Decrement the loop counter in Cell #1
    ]                   Loop till Cell #1 is zero; number of iterations is 4
    >+                  Add 1 to Cell #2
    >+                  Add 1 to Cell #3
    >-                  Subtract 1 from Cell #4
    >>+                 Add 1 to Cell #6
    [<]                 Move back to the first zero cell you find; this will
                        be Cell #1 which was cleared by the previous loop
    <-                  Decrement the loop Counter in Cell #0
]                       Loop till Cell #0 is zero; number of iterations is 8

The result of this is:
Cell No :   0   1   2   3   4s

Further reading

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

brainfoose-2.0.1.tar.gz (5.5 kB view details)

Uploaded Source

Built Distribution

brainfoose-2.0.1-py2.py3-none-any.whl (7.4 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file brainfoose-2.0.1.tar.gz.

File metadata

  • Download URL: brainfoose-2.0.1.tar.gz
  • Upload date:
  • Size: 5.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for brainfoose-2.0.1.tar.gz
Algorithm Hash digest
SHA256 6335e0f23cb020f08d61c5e740cbeeca11891e9aaa1d88e4e31dfa3ef93dac4a
MD5 66f9b92ef9fe098c2a879cb630119dd3
BLAKE2b-256 a6f0f32fac6c36c9e0f4111079767cedcf62bd21800b7808ee64d2fe2d723a33

See more details on using hashes here.

File details

Details for the file brainfoose-2.0.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for brainfoose-2.0.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 593b30ba064aea1f807f0a165e5554d80a7ecc96f0d8cfbf700e5714e5c58105
MD5 99bb7c96a17182db3e328eabcb214297
BLAKE2b-256 62745588e8970d22c959332a434bc081529e64385d453b6da374234b0a8e2033

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page