forked from dbetz/xlisp
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfasl.lsp
executable file
·35 lines (31 loc) · 1.09 KB
/
fasl.lsp
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
(define basic-load load)
(define (load name)
(let ((off (string-search "." name)))
(if off
(let ((ext (substring name off)))
(if (string-ci=? ext ".fsl")
(load-fasl-file name)
(basic-load name)))
(or (load-fasl-file (string-append name ".fsl"))
(basic-load (string-append name ".lsp"))))))
(define (compile-file iname)
(let* ((oname (string-append (get-root-file-name iname) ".fsl"))
(ifile (open-input-file iname))
(ofile (open-output-file oname))
(sts #f))
(when (and ifile ofile)
(let loop ((expr (read ifile)))
(when (not (eof-object? expr))
(let ((compiled-expr (compile expr)))
(fasl-write-procedure compiled-expr ofile))
(loop (read ifile))))
(set! sts #t))
(when ifile (close-port ifile))
(when ofile (close-port ofile))
sts))
(define (get-root-file-name name)
(let ((ext-offset (string-search "." name :from-end? #t)))
(if ext-offset
(values (substring name 0 ext-offset)
(substring name (+ ext-offset 1)))
name)))