forked from justinethier/cyclone
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgenerate-c.scm
49 lines (43 loc) · 1.09 KB
/
generate-c.scm
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
;;;; Cyclone Scheme
;;;; https://github.com/justinethier/cyclone
;;;;
;;;; Copyright (c) 2014-2016, Justin Ethier
;;;; All rights reserved.
;;;;
;;;; This module automatically generates the following files:
;;;;
;;;; - dispatch.c => Used by apply to call native C functions.
;;;;
(import (scheme base)
(scheme file)
(scheme write))
(with-output-to-file
"dispatch.c"
(lambda ()
(display "
#include \"cyclone/types.h\"
#include \"cyclone/runtime.h\"
void do_dispatch(void *data, int argc, function_type func, object clo, object *b) {
switch(argc) {" )
(define bs "")
(let loop ((i 0))
(display "case " )
(display i )
(display ":func(" )
(display "data,")
(display i )
(display ",clo" )
(display bs )
(display ");" )
(set! bs (string-append bs ",*(b+" (number->string i) ")"))
(if (< i 149)
(loop (+ i 1))))
(display "
default:
{
char buf[1024];
snprintf(buf, 1023, \"Unhandled number of function arguments: %d\\n\", argc);
Cyc_rt_raise_msg(data, buf);
}
}
}" )))