Logo

dev-resources.site

for different kinds of informations.

Crafting a Compiler in Rust: Introduction

Published at
12/8/2022
Categories
rust
compilers
tutorial
computerscience
Author
simmypeet
Author
9 person written this
simmypeet
open
Crafting a Compiler in Rust: Introduction

Has anyone wondered? How does the code that we've written turn into a program or application? The simple explanation is that there's a program designed specifically to translate high-level code into machine code that computers can understand and execute. This program is called a compiler.

Hi, In this dev-blog series, I'm writing and documenting the process of creating a compiler for my programming language, Pernix. This series will go through to the point where the compiler is self-hosted, meaning it's possible to develop a compiler for my programming language using my programming language and compiler. This series will not be a line-by-line tutorial but will show what each component in the compiler does and how they interact.

About my Programming Language and Compiler

The programming language is called Pernix. It is a Latin word; that means agile, quick, and swift. The language is statically-typed and compiled and has a syntax similar to C. I'll implement the compiler in Rust programming language with the help of LLVM.

Compiler Basics

Before writing a compiler, let's understand some basics of it. Generally speaking, the compiler is separated into the front-end and back-end. The front-end part involves converting the source code into an intermediate representation and checking all sorts of errors in the program. The back-end then performs the translation from the intermediate representation produced by the front-end into machine code.

Typically, each operating system and CPU have its own instruction sets, meaning that the compiler has to handle the differences between them.
Fortunately, LLVM will do the most heavy-lifting jobs in the back-end part. Therefore, I'll focus more on developing the front-end part.

Compiler Front-End Overview

Again, the compiler front end can also be broken down into several parts:
Lexical Analysis, Syntactic Analysis, and Semantic Analysis.

  • Lexical Analysis involves breaking the source code into manageable tokens/words.
  • Syntactic Analysis performs the grammar check of the language and turns a token stream from the previous phase into the abstract syntax tree (AST).
  • Semantic Analysis performs additional checks that the Syntactic Analysis phase can't, such as type-checking and symbols look-up. As the previous can only validate the grammatical structure of the program.

Brief Diagram of Compiler Front-End

I'll go into more detail about each phase in their separate blog post of them.

compilers Article's
30 articles in total
Favicon
How to create simple tool for compile the Linux Kernel
Favicon
Unraveling Undefined Behavior: Performance Optimizations in Modern Compilers
Favicon
Video — Deep dive: Compiling deep learning models, from XLA to PyTorch 2
Favicon
The current state of Lithia after 2 years
Favicon
Verificando e Gerando Expressões
Favicon
Expressões encadeadas e agrupamento
Favicon
Improving Compiler Performance with Profile Guided Optimization
Favicon
Understanding Interpreters and Compilers in Programming
Favicon
Create Your Own Programming Language 9: Iteration
Favicon
Crafting Interpreters
Favicon
Create Your Own Programming Language 8: Conditionals
Favicon
Create Your Own Programming Language 7: More Types
Favicon
Create Your Own Programming Language 6: Functions
Favicon
Create Your Own Programming Language 4: Variables and Types
Favicon
Create Your Own Programming Language 3: Call Expressions
Favicon
How To Create Your Own Programming Language
Favicon
Create Your Own Programming Language 1: Numbers
Favicon
An alternative to "Distinguishing an Interpreter from a Compiler"
Favicon
On What Lexers Do
Favicon
Compilers Could Be Way More Fun
Favicon
Incremental compilation for Crystal - Part 3
Favicon
Incremental compilation for Crystal - Part 1
Favicon
Incremental compilation for Crystal - Part 2
Favicon
Crafting a Compiler in Rust: Lexical Analysis
Favicon
Crafting a Compiler in Rust: Introduction
Favicon
What is an ELF file?
Favicon
Static vs dynamic linking
Favicon
Speeding up ReScript compilation using interface files
Favicon
🕶 What it takes to build a Static Analysis tool
Favicon
A Compiler optimization area

Featured ones: