- Ikarus now recognizes IKARUS_FASL_DIRECTORY (and the corresponding
fasl-directory parameter) that works as follows: - if IKARUS_FASL_DIRECTORY is set to "", no fasl files are produced. - if IKARUS_FASL_DIRECTORY is set to something other than "", the string is used as a directory in which fasl files are placed. - if IKARUS_FASL_DIRECTORY is unset, the directory $HOME/.ikarus/precompiled is used for fasl output. - library file names are cannonicalized using file-real-path. - the fasl file (if produced) is the result of (string-append (fasl-directory) (file-real-path filename) ext) where ext is either ".ikarus-32bit-fasl" or ".ikarus-64bit-fasl". - The old behavior (placing the fasl files in the same place as the library files) can be achieved by setting IKARUS_FASL_DIRECTORY='/'.
This commit is contained in:
parent
a050e28633
commit
f759815a8c
|
@ -15,9 +15,9 @@
|
||||||
|
|
||||||
|
|
||||||
(library (ikarus load)
|
(library (ikarus load)
|
||||||
(export load load-r6rs-script)
|
(export load load-r6rs-script fasl-directory)
|
||||||
(import
|
(import
|
||||||
(except (ikarus) load load-r6rs-script)
|
(except (ikarus) fasl-directory load load-r6rs-script)
|
||||||
(only (ikarus.compiler) compile-core-expr)
|
(only (ikarus.compiler) compile-core-expr)
|
||||||
(only (psyntax library-manager)
|
(only (psyntax library-manager)
|
||||||
serialize-all current-precompiled-library-loader)
|
serialize-all current-precompiled-library-loader)
|
||||||
|
@ -31,13 +31,28 @@
|
||||||
[(<= (fixnum-width) 32) ".ikarus-32bit-fasl"]
|
[(<= (fixnum-width) 32) ".ikarus-32bit-fasl"]
|
||||||
[else ".ikarus-64bit-fasl"]))
|
[else ".ikarus-64bit-fasl"]))
|
||||||
|
|
||||||
|
(define fasl-directory
|
||||||
|
(make-parameter
|
||||||
|
(cond
|
||||||
|
[(getenv "IKARUS_FASL_DIRECTORY")]
|
||||||
|
[(getenv "HOME") =>
|
||||||
|
(lambda (s)
|
||||||
|
(string-append s "/.ikarus/precompiled"))]
|
||||||
|
[else ""])
|
||||||
|
(lambda (s)
|
||||||
|
(if (string? s)
|
||||||
|
s
|
||||||
|
(die 'fasl-directory "not a string" s)))))
|
||||||
|
|
||||||
(define (fasl-path filename)
|
(define (fasl-path filename)
|
||||||
(string-append filename fasl-extension))
|
(let ([d (fasl-directory)])
|
||||||
|
(and (not (string=? d ""))
|
||||||
|
(string-append d (file-real-path filename) fasl-extension))))
|
||||||
|
|
||||||
(define (load-serialized-library filename sk)
|
(define (load-serialized-library filename sk)
|
||||||
(let ([ikfasl (fasl-path filename)])
|
(let ([ikfasl (fasl-path filename)])
|
||||||
(cond
|
(cond
|
||||||
[(not (file-exists? ikfasl)) #f]
|
[(or (not ikfasl) (not (file-exists? ikfasl))) #f]
|
||||||
[(< (file-mtime ikfasl) (file-mtime filename))
|
[(< (file-mtime ikfasl) (file-mtime filename))
|
||||||
(fprintf (current-error-port)
|
(fprintf (current-error-port)
|
||||||
"WARNING: not using fasl file ~s because it is older \
|
"WARNING: not using fasl file ~s because it is older \
|
||||||
|
@ -62,10 +77,15 @@
|
||||||
|
|
||||||
(define (do-serialize-library filename contents)
|
(define (do-serialize-library filename contents)
|
||||||
(let ([ikfasl (fasl-path filename)])
|
(let ([ikfasl (fasl-path filename)])
|
||||||
|
(cond
|
||||||
|
[(not ikfasl) (void)]
|
||||||
|
[else
|
||||||
(fprintf (current-error-port) "Serializing ~s ...\n" ikfasl)
|
(fprintf (current-error-port) "Serializing ~s ...\n" ikfasl)
|
||||||
|
(let-values ([(dir name) (split-file-name ikfasl)])
|
||||||
|
(make-directory* dir))
|
||||||
(let ([p (open-file-output-port ikfasl (file-options no-fail))])
|
(let ([p (open-file-output-port ikfasl (file-options no-fail))])
|
||||||
(fasl-write (make-serialized-library contents) p)
|
(fasl-write (make-serialized-library contents) p)
|
||||||
(close-output-port p))))
|
(close-output-port p))])))
|
||||||
|
|
||||||
(define load-handler
|
(define load-handler
|
||||||
(lambda (x)
|
(lambda (x)
|
||||||
|
|
|
@ -368,7 +368,12 @@
|
||||||
(die who "not a string" x))
|
(die who "not a string" x))
|
||||||
(let ([v (foreign-call "ikrt_realpath" (string->utf8 x))])
|
(let ([v (foreign-call "ikrt_realpath" (string->utf8 x))])
|
||||||
(cond
|
(cond
|
||||||
[(bytevector? v) (utf8->string v)]
|
[(bytevector? v)
|
||||||
|
(let ([s (utf8->string v)])
|
||||||
|
(when (or (string=? s "")
|
||||||
|
(not (char=? (string-ref s 0) #\/)))
|
||||||
|
(error who "unexpected value returned from OS" s x))
|
||||||
|
s)]
|
||||||
[else (raise/strerror who v x)])))
|
[else (raise/strerror who v x)])))
|
||||||
|
|
||||||
(define (getenv key)
|
(define (getenv key)
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
1793
|
1794
|
||||||
|
|
|
@ -620,6 +620,7 @@
|
||||||
[error@fxsub1 ]
|
[error@fxsub1 ]
|
||||||
[fasl-write i]
|
[fasl-write i]
|
||||||
[fasl-read i]
|
[fasl-read i]
|
||||||
|
[fasl-directory i]
|
||||||
[lambda i r ba se ne]
|
[lambda i r ba se ne]
|
||||||
[and i r ba se ne]
|
[and i r ba se ne]
|
||||||
[begin i r ba se ne]
|
[begin i r ba se ne]
|
||||||
|
|
Loading…
Reference in New Issue