An optimizing brainfuck interpreter in js
Go to file
Juhani Krekelä e75a0a085d Update documentation 2018-05-25 23:21:29 +03:00
.gitignore First commit 2018-05-21 23:55:48 +03:00
README.md Update documentation 2018-05-25 23:21:29 +03:00
UNLICENSE First commit 2018-05-21 23:55:48 +03:00
brainfuck.md Add documentation 2018-05-22 19:39:48 +03:00
gir.html Add correct charset info 2018-05-24 23:35:50 +03:00
gir.js Add transformMultiplyLoops optimization pass and switch to using Maps 2018-05-25 18:24:27 +03:00
ir.md Update documentation 2018-05-25 23:21:29 +03:00
optimizations.md Update documentation 2018-05-25 23:21:29 +03:00

README.md

Gir is an optimizing brainfuck interpreter in Javascript.

Name

𒌋𒀜 gir (Sumerian) - n. kiln

License

Everything in the repo is under Unlicense / CC0.

Status

Gir can parse, prettyprint, and run programs in brainfuck. Gir supports following optimizations:

  • Turn runs of +- or <> into one command
  • Turn [-] or [+] into one command
  • Add offsets to commands that modify tape, to reduce moving tape head
  • Turn multiply loops into one command

TODO

gir.js

  • Implement :;#
  • Make VM and transformMultiplyLoops use a Proxied object that gives out 0 for nonexistent elements for tape and allows using [] interface
  • Keep a cache of compiled programs in run()
  • Support for other types of EOF?

gir.html

  • Implement a UI

Documentation

  • Document the VM
  • Document the user-facing API
  • Document the overall architecture

General

  • Get this on NPM?