Teacher: Letterio Galletta
Contact: name.surname(at)imtlucca.it
Office hours: contact me by e-mail
Page of theory part of the course held by Prof. Roberta Gori: http://pages.di.unipi.it/gori/Linguaggi-Compilatori2020/
The course will present tools and techniques used in the implementation of programming languages. In particular, the course will guide students in the implementation of a compiler for a small subset of language C, called MicroC, and of an interpreter of a small functional language, called FUN. During the lectures students will work on programming assignments covering different aspects of language implementation. The programming language adopted for the exercises and the project is OCaml. At the end of the course students who completed all the assignments will have developed an simple interpreter and a compiler.
After completing the course, students will have
- Known the basics of the functional programming language OCaml;
- Implemented parsers using state-of-the-art parsers generators;
- Designed and implemented semantic analyses for a functional and an imperative languages;
- Used the LLVM toolchain for generating and optimize code;
- Had some fun along the way! 😄
- Introduction to functional programming and to OCaml language;
- Lexing and parsing using
ocamllex
andmenhir
; - Semantic analysis implementation: type checking, scope management, control-flow analysis;
- Introduction to LLVM infrastructure and LLVM intermediate language;
- Code generation.
This table specifies the lecture schedule with topics and materials.
See these instructions to set up your programming environment.
The final project of the course consists in implementing a compiler for MicroC. See here for the instructions.
Programming assignments will use the following pieces of sotfware:
- OCaml - try to install the latest version. All the code shown during the course is tested with the version 4.10.1.
- Opam - OCaml package manager.
- Menhir - a LR(1) parser generator for the OCaml programming language.
- Clang - a compiler for C programs.
- LLVM - The LLVM compiler infrastructure. All the code shown during the course is tested with the version 10.0.
- rlwrap - a small utility to improve the editing capability of the OCaml REPL.
- OCaml user manual
- OCaml Discourse community
- OCamlverse
- The book Functional Programming in OCaml
- The book Real World OCaml
- The book OCaml Scientific Computing
- OCaml MOOC
- An interactive tutorial on using
git
- LLVM Language Reference Manual
- LLVM OCaml Binding Documentation
- Kaleidoscope: Implementing a Language with LLVM in Objective Caml
- The Programming Languages Zoo - A potpourri of programming languages
- Compiler Explorer
- Resources for Amateur Compiler Writers
Here you find a list of further references that complete and deepen the various topics covered during the course. A rich collection of articles related to the course can be found in Prof. Matt Might's blog.