Skip to content

Instantly share code, notes, and snippets.

@kspalaiologos
Forked from maxcountryman/bf.c
Created November 15, 2017 17:14
Show Gist options
  • Save kspalaiologos/58e6c88a7bfceb6cd8afc991f4f9bbda to your computer and use it in GitHub Desktop.
Save kspalaiologos/58e6c88a7bfceb6cd8afc991f4f9bbda to your computer and use it in GitHub Desktop.
A simple brainfuck interpreter in C
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
// initialize the tape with 30,000 zeroes
unsigned char tape[30000] = {0};
// set the pointer to point at the left-most cell of the tape
unsigned char* ptr = tape;
void interpret(char* input) {
char current_char;
size_t i;
size_t loop;
for (i = 0; input[i] != 0; i++) {
current_char = input[i];
if (current_char == '>') {
++ptr;
} else if (current_char == '<') {
--ptr;
} else if (current_char == '+') {
++*ptr;
} else if (current_char == '-') {
--*ptr;
} else if (current_char == '.' ) {
putchar(*ptr);
} else if (current_char == ',') {
*ptr = getchar();
} else if (current_char == '[') {
continue;
} else if (current_char == ']' && *ptr) {
loop = 1;
while (loop > 0) {
current_char = input[--i];
if (current_char == '[') {
loop--;
} else if (current_char == ']') {
loop++;
}
}
}
}
}
int main() {
interpret(",[.[-],]"); // outputs input
return 0;
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment