Skip to content

Lambda calculus compiler & interpreter written in C

Notifications You must be signed in to change notification settings

lwander/lambdac

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Lambda Calculus Compiler in C

An attempt at writing a lambda calculus compiler in C for educational purposes.


Compilation

$ sudo apt-get install gcc-multilib # for <assert.h>
$ make

While it would be fun to dive immediately into the compilation process for a lambda calculus, I think we need to first examine how a lambda calculus interpreter works to get a feel for the dynamics and semantics of the language.

Semantics

<var> ::= [a-zA-Z0-9]*
<lambda> ::= (\<var>.<expression>)
<application> ::= (<expression> <expression>)
<expression> ::= <var> | <lambda> | <application>

What's written above is the BNF for our lambda calculus. Essentially, it's saying that our language is composed of var, lambda, application, and expression terms.

About

Lambda calculus compiler & interpreter written in C

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published