WLP4 Compiler
WLP4 is a subset of the C++ language made by the University of Waterloo. During CS 241 (Sequential Programs), I worked on building a compiler for WLP4 thorughout the semester.
A compiler/translator has two stages; Analysis and Synthesis. Analysis checks the input lexically,
syntactically, and semantically to ensure proper language grammar and creates a parse tree. The
generated parse tree is used in Synthesis to produce the output. In our WLP4 Compiler, the compiler
takes a .wlp4
file and produces a .asm
file which is in Assembly code.
Structure of the compiler:
- Scanner - The first part of the analysis stage. Reads the input file and checks the input lexically for any invalid characters or strings (i.e using unkown characters 🌱). Produces a vector of tokens; each strings in the input are turned into tokens for parsing
- Parser - Checks the vector of tokens for syntax errors (i.e missing semicolons or parentheses) and produces a parse tree which is useful in checking for context.
- Context Sensitive Analysis - Checks the parse tree for any semantic errors (i.e assigning the wrong type). Context Sensitive Analysis produces a pruned parse tree where some nodes are removed since it is not needed for code generation, and also a symbol table. The symbol table contains the variable and function names in the input.
- Code Generation - Takes a parse tree and symbol table and produces the generated assembly code.
Code Generation is the only part of the Synthesis stage.
How WLP4 differs from C++?
- First of all, the 'main' function of WLP4 is 'wain' and it can only take two parameters; either two ints, or an int and an array of ints
- Another significant difference is that all variables can only be declared once at the very top of a procedure. There are only two types of variables; int or int*
- UWaterloo CS241 - WLP4
What the Compiler produces?
The compiler generates an assembly code which takes the parameters of 'wain' in register $1 and $2 and enters the returned value of the procedure in register $3
Usage
make
./compiler < ./sample/test.wlp4