Skip to content

Little brainfuck interpreter with some typo checks. Written in C

License

Notifications You must be signed in to change notification settings

oguzbakir/brainfuck-interpreter

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

22 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Brainfuck-Interpreter

Prerequisites

  • gcc
  • brain

How to use

First of all compile core:

gcc core.c -o core

Then give input file name as argument:

./core cool_brainfuck_filename

The Language

A Brainfuck program has an implicit byte pointer, called "the pointer", which is free to move around within an array initially all set to zero. The pointer itself is initialized to point to the beginning of this array.

The Brainfuck programming language consists of eight commands, each of which is represented as a single character.

">" Increment the pointer.
"<" Decrement the pointer.
"+" Increment the byte at the pointer.
"-" Decrement the byte at the pointer.
"." Output the byte at the pointer.
"," Input a byte and store it in the byte at the pointer.
"[" Jump forward past the matching ] if the byte at the pointer is zero.
"]" Jump backward to the matching [ unless the byte at the pointer is zero.

The semantics of the Brainfuck commands can also be succinctly expressed in terms of C, as follows (assuming that p has been previously defined as a char*):

">" becomes ++p;
"<" becomes --p;
"+" becomes ++*p;
"-" becomes --*p;
"." becomes putchar(*p);
"," becomes *p = getchar();
"[" becomes while (*p) {
"]" becomes }

Source

About

Little brainfuck interpreter with some typo checks. Written in C

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published