This JavaScript app parses and interprets a simple but Turing Complete programming language consisting of 8 symbols using a Recursive Descent Parser technique. The language's machine model consists of the program and instruction pointer, as well as a one-dimensional array of at least 30,000 byte cells initialized to zero; a movable data pointer (initialized to point to the leftmost byte of the array); and two streams of bytes for input and output (most often connected to a keyboard and a monitor respectively, and using the ASCII character encoding). The language commands each consist of a single character (see Language Reference below).

Interpreter

Display prompt for input

Converter

Character Instruction Performed
> Increment the data pointer by one (to point to the next cell to the right)
< Decrement the data pointer by one (to point to the next cell to the left)
+ Increment the byte at the data pointer by one
- Decrement the byte at the data pointer by one
. Output the byte at the data pointer
, Accept one byte of input, storing its value in the byte at the data pointer
[ If the byte at the data pointer is zero, then instead of moving the instruction pointer forward to the next command, jump it forward to the command after the matching ] command
] If the byte at the data pointer is nonzero, then instead of moving the instruction pointer forward to the next command, jump it back to the command after the matching [ command
Bonus Instruction! (Not part of original language but added to help debugging)
# Log the machine model's current state in the JS console