Skip to content

This project that was inspired by ALX brainf*ck problem. The aim is to create a simple interpreter for the brainf*ck esoteric programming language

Notifications You must be signed in to change notification settings

MungaSoftwiz/bf_esolang_interpreter

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

15 Commits
 
 
 
 
 
 

Repository files navigation

Brainfuck Interpreter

Introduction

This Brainfuck interpreter project is inspired by a task I encountered during my time at ALX, which sparked the interest in esoteric programming languages. Brainfuck, a minimalist, Turing complete language, has always been a fascinating challenge for programmers.

What is Brainfuck?

Brainfuck is an esoteric programming language created by Urban Müller in 1993. It is characterized by its minimalistic and cryptic syntax, consisting of only eight commands: >, <, +, -, ., ,, [, and ]. Despite its simplicity, Brainfuck is Turing complete, meaning it can perform any computation that any other programming language can, given enough time and memory.

In Brainfuck, you work with a one-dimensional array of memory cells, a data pointer that points to the current memory cell, and input and output streams that are often connected to the keyboard and a monitor using ASCII character encoding. The language operates through a set of commands, each represented by a single character.

Getting Started

Prerequisites

To run this Brainfuck interpreter, you will need a C compiler such as GCC. If you don't have one installed, you can download it from https://gcc.gnu.org/.

Building the Interpreter

Follow these steps to build the Brainfuck interpreter:

  1. Clone this repository to your local machine:

git clone https://github.com/MungaSoftwiz/bf_esolang_interpreter.git

  1. Navigate to the project directory:

cd bf_esolang_interpreter/interpreter

  1. Compile the source code:

gcc -Wall -Werror -Wextra -pedantic -std=gnu89 *.c -o bfrun

Running Brainfuck Programs

You can run the brainfuck programs using the interpreter as follows:

./bfrun <your_program.bf>

Usage

To use the interpreter, execute it from the command line with the following options:

./bfrun [output_option] `

[output_option] (Optional): Use the -n flag to specify that the output should be treated as integers rather than characters.

Examples

Execute a Brainfuck program in character mode:

./bfrun hello_world.bf

Execute a Brainfuck program in integer mode:

./bfrun -n fibonacci.bf

About

This project that was inspired by ALX brainf*ck problem. The aim is to create a simple interpreter for the brainf*ck esoteric programming language

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published