July 26th, 2024

Bril: An Intermediate Language for Teaching Compilers

Adrian Sampson developed Bril, an educational intermediate language for teaching compilers, emphasizing simplicity and extensibility, allowing students to learn algorithms without complex industrial APIs.

Read original articleLink Icon
Bril: An Intermediate Language for Teaching Compilers

Adrian Sampson from Cornell University developed Bril, an intermediate language designed specifically for teaching compilers. The language aims to provide a hands-on learning experience, allowing students to implement algorithms without the complexity of industrial compiler APIs. Bril is characterized by its simplicity, regular syntax, and ease of use, making it accessible for students with varying levels of familiarity with compilers. It is structured as a JSON document, which facilitates quick integration with various programming languages and tools, promoting collaboration among students.

Bril prioritizes educational goals over traditional compiler performance metrics, such as code size and execution speed. It features a unique design that includes a core opcode for printing, which simplifies example creation, and employs a more A-normal form than typical intermediate languages. This design choice, while verbose, aids in teaching by standardizing how constants are handled.

The language is extensible, allowing students to contribute tools and features, although this has led to some management challenges within the ecosystem. Bril also includes a non-SSA form, which helps students understand the implications of mutable variables before transitioning to SSA concepts. Despite some design flaws, particularly regarding its SSA implementation, Bril has evolved through student contributions, enhancing its functionality and usability in educational settings.

Related

Show HN: Lady Deirdre 2 – Rust Framework for Compilers and LSP Servers

Show HN: Lady Deirdre 2 – Rust Framework for Compilers and LSP Servers

Lady Deirdre, a proprietary compiler front-end by Ilya Lakhin, supports incremental programming language compilers, error resilience, Web-Assembly compatibility, and more. Available for open-source projects with non-commercial licenses and GitHub contributions.

Writing an IR from Scratch and survive to write a post

Writing an IR from Scratch and survive to write a post

Eduardo Blázquez developed an Intermediate Representation (IR) for the Kunai Static Analyzer during his PhD, aiming to enhance Dalvik bytecode analysis. The project, shared on GitHub and published in SoftwareX, transitioned to Shuriken. Blázquez drew inspiration from Triton and LLVM, exploring various IR structures like ASTs and CFGs. MjolnIR, Kunai's IR, utilized a Medium Level IL design with control-flow graphs representing methods. Blázquez's approach involved studying compiler design resources.

Ur-Scheme: A GPL self-hosting compiler from a subset of R5RS Scheme

Ur-Scheme: A GPL self-hosting compiler from a subset of R5RS Scheme

Ur-Scheme is a compact GPL compiler translating R5RS Scheme to Linux x86 assembly. Despite limitations, it offers speed, safety, and unique extensions. Inspired by Ghuloum, it simplifies compiler construction.

'Writing a C Compiler' is a book

'Writing a C Compiler' is a book

The "Writing a C Compiler" series transitions into a book by No Starch Press, focusing on building a C compiler with practical guidance, pseudocode examples, and essential compiler concepts for a broad audience.

Show HN: Programming with Bird Emojis

Show HN: Programming with Bird Emojis

The programming language Birb uses bird emojis to represent lambda calculus terms. Syntax involves bird emojis, and semantics reduce birds in associative order. Birb is Turing complete, with a transpiler converting to SKI combinators and Jot.

Link Icon 1 comments
By @nioj - 6 months
Ongoing discussion with more comments: https://news.ycombinator.com/item?id=41084318