summaryrefslogtreecommitdiff
path: root/src/modules/generator/generator.scm
diff options
context:
space:
mode:
authorbd <bdunahu@operationnull.com>2024-12-28 12:44:07 -0700
committerbd <bdunahu@operationnull.com>2024-12-28 12:47:56 -0700
commitbabe9f9d0e84daec1015d7593a9d6c6d480662b8 (patch)
tree1314d8803b4fa564e06c58444e3524e688c4f204 /src/modules/generator/generator.scm
parent11ecac1d0686d5ed75b73eee0c860d7d67f6d6f0 (diff)
Assembly generation for trivial programs
Diffstat (limited to 'src/modules/generator/generator.scm')
-rw-r--r--src/modules/generator/generator.scm31
1 files changed, 31 insertions, 0 deletions
diff --git a/src/modules/generator/generator.scm b/src/modules/generator/generator.scm
new file mode 100644
index 0000000..4c08e32
--- /dev/null
+++ b/src/modules/generator/generator.scm
@@ -0,0 +1,31 @@
+(define-module (modules generator generator)
+ #:use-module (modules ast syntax-tree)
+ #:use-module (modules ast assembly-tree)
+ #:export (generate))
+
+(define (generate node)
+ (cond
+ ((program? node) (g-program node))
+ ((function? node) (g-function node))
+ ((stmt? node) (g-stmt node))
+ ((expr? node) (g-expr node))
+ ((id? node) (g-id node))
+ (else (error "Unknown AST element"))))
+
+(define (g-program p)
+ (make-program (generate (program-function p))))
+
+(define (g-function f)
+ (make-subroutine (generate (function-id f))
+ (generate (function-stmt f))))
+
+(define (g-stmt s)
+ (generate (stmt-expr s)))
+
+(define (g-expr e)
+ ;; for now, we assume only 'return'!
+ (list (make-instruction "mov1" "%eax" "$2")
+ (make-instruction "ret" #f #f)))
+
+(define (g-id i)
+ (id-symbol i))