This repository contains the code for a compiler implementation for a simple, C-like language that relies on the C tools Flex and Bison.
A comprehensive tutorial series is also available.
The project was unfortunately abandoned for over five years due to the maintainer's time constraints.
Due to the 2020 Steemit dispute, when the project was revitalized the tutorial series resumed on Hive instead.
Important
A major overhaul of the repository is currently underway (see open issue #5). Although the project had reached the code generation stage, improvements to the code base have necessitated a temporary return to the post-syntax analysis stage.
- GCC (GNU Compiler Collection)
- Make
- Flex (derivative of Lex)
- Bison (derivative of Yacc)
- QtSpim (MIPS32 Simulator)
For Arch-based distributions:
sudo pacman -Syu
sudo pacman -S --needed base-devel
Note
base-devel includes gcc, make, flex, bison, and other core development tools. Alternatively, you can install each separately.
For Debian-based distributions
sudo apt update
sudo apt install build-essential flex bison
Note
build-essential includes gcc, make, and other core build tools. Alternatively, you can install each separately.
For Fedora-based distributions
sudo dnf makecache
sudo dnf group install development-tools
sudo dnf install flex flex-devel bison bison-devel
Note
development-tools group includes gcc, make, and other core build tools. Alternatively, you can install each separately.
It is highly recommended that you use a Linux distribution instead, through any method you prefer.
Options include:
- Windows Subsystem for Linux (WSL), preferably version 2
- Docker or Podman containers
- Virtual Machines
I am not very familiar with Macintosh systems.
However, it seems that you first need to install Apple's command-line developer tools, which will provide you with make, clang and gcc (via clang), as well as other development tools.
Next, install a package manager such as Homebrew (brew), through which you can then install flex and bison.
xcode-select --install
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
brew install flex bison
Regarding MIPS32 simulation, note that there is a Flatpak package for QtSpim that appears to work just fine on Arch Linux.
If you are on Microsoft Windows, macOS, or a Debian-based Linux distribution, you should be good to go with one of the recent releases of QtSpim on SourceForge.
Clone the repository and change into the directory:
git clone https://github.com/drifter1/compiler.git
cd compiler
To build the compiler simply type make in this directory.
By default, the executable will be located in the subdirectory bin and called compiler.
Examples are included in the examples subdirectory. You can compile example1.c in the Simple-C language via:
./bin/compiler examples/simple_c_examples/example1.c
This will print out parsing debugging information in the terminal console and also create a symtab_dump_out file.
terminal output:
Inserted i for the first time with linenumber 1!
Inserted val for the first time with linenumber 2!
Found i again at line 3!
Found i again at line 3!
Found i again at line 3!
Found val again at line 4!
Found val again at line 4!
Found i again at line 4!
Found i again at line 4!
Inserted print for the first time with linenumber 6!
Found val again at line 6!
symtab_dump.out
------------ ------ ------------
Name         Type   Line Numbers
------------ ------ -------------
i            undef     1    3    3    3    4    4 
val          undef     2    4    4    6 
print        undef     6 
To clean the build files and binary executable, you just have to type make clean.
Note
The above command does not remove debugging files such as symtab_dump_out, which are created when you use the compiler itself. These files need to be removed manually.
The complete list of articles can be found here.
- Machine Code generation in MIPS Assembly (remaining cases)
- Optimizations in the compiler's source code

