deralex/phprainfuck

Brainfuck interpreter and virtual machine

dev-master 2020-01-06 08:15 UTC

This package is not auto-updated.

Last update: 2025-01-14 03:59:47 UTC


README

What the heck is this?

It's a Brainfuck interpreter and (somewhat) virtual machine which makes it possible to both evaluate brainfuck code as "pure" brainfuck code and to evaluate brainfuck code as PHP code.

Installation

Just add it to your composer.json:

"require": {
    ...
    "AlexClooze/phprainfuck": "dev-master"
}

and run composer update.

Usage

There are two ways of using phprainfuck.

It all starts with creating a new instance of phprainfuck:

use AlexClooze\Phprainfuck\Phprainfuck;

$phprain = new Phprainfuck();

After this you've got two options.

Interpreting brainfuck code "as is"

Here's an example on using the evaluate method to just interprete pure brainfuck code:

$code = <<<EOT
+++++ +++[- >++++ ++++< ]>+++ +++++ .<+++ ++[-> +++++ <]>++ ++.++ +++++
..+++ .<+++ +++++ [->-- ----- -<]>- ----- ----- ----. <++++ +++[- >++++
+++<] >++++ ++.<+ +++[- >++++ <]>++ +++++ +.+++ .---- --.-- ----- -.<++
+++++ +[->- ----- --<]> ---.< 
EOT;

print $phprain->evaluate($code);

This will print "Hello World!".

Evaluating brainfuck code as PHP code

Here's an example on creating a new virtual machine and executing brainfuck code as PHP code in it.

Hint: All code executed via the virtual machine is executed in a seperate new PHP process.

$code = <<<EOT
+++++ +++++ [->++ +++++ +++<] >++++ +++++ +++++ ++++. <++++ [->-- --<]>
----- .<+++ +[->+ +++<] >+.<+ +++[- >---- <]>-- -.+++ ++.<+ +++[- >++++
<]>+. ----- ---.+ ++.<+ +++++ ++[-> ----- ---<] >---- ----. ----- -.<++
++++[ ->+++ +++<] >++.< +++++ [->++ +++<] >++++ .++++ +++.. +++.< +++++
+++[- >---- ----< ]>--- ----- ----- --.<+ +++++ +[->+ +++++ +<]>+ +++++
.<+++ +[->+ +++<] >++++ ++++. +++.- ----- .---- ----. <++++ ++++[ ->---
----- <]>-- -.+.+ +++++ +.<++ ++[-> ++++< ]>++. <
EOT;

$vm = $phprain->createVirtualMachine(255);
$vm->run($code);

The argument given by createVirtualMachine is the actual heap size. The above code will evaluate to var_dump("Hello World!"); and will print string(12) "Hello World!".

Running tests

phprainfuck is developed with the help of phpspec. Run phpspec run to run the tests.