Started work on the compiler, with a desugar phase

This commit is contained in:
2025-12-26 20:42:03 +03:00
parent e10124498e
commit 4f1ad54596
4 changed files with 109 additions and 23 deletions

27
bin/comp.ml Normal file
View File

@@ -0,0 +1,27 @@
open Parser.Ast;;
let p = Printf.sprintf
let rec dbg_print = function
| LSymbol s -> p "%s" s
| LCons (a, LNil) -> p "%s)" (dbg_print_start a)
| LCons (a, b) -> p "%s %s" (dbg_print_start a) (dbg_print b)
| LNil -> p "()"
| LInt i -> p "%d" i
| LDouble d -> p "%f" d
| LString s -> p "%s" s
and dbg_print_start = function
| LCons (_, _) as l -> p "(%s" (dbg_print l)
| _ as x -> dbg_print x
let def = Parser.parse_str "(define (f x) (+ x 1))
(define (f)
(define (g y) (* y 2))
(g 5))";;
let desugared = List.map Compiler.Sugar.desugar def
let () = List.iter (fun x -> Printf.printf "%s\n" (dbg_print_start x) ) desugared
let () = print_newline ()

View File

@@ -3,3 +3,8 @@
(public_name ollisp-inter)
(libraries str unix interpreter)
(package ollisp))
(executable
(name comp)
(public_name ollisp)
(libraries str unix compiler interpreter))