Use temp directory

This commit is contained in:
Lassi Kortela 2021-09-20 14:02:09 +03:00
parent 05298fb1f0
commit 93c7ef8046
1 changed files with 27 additions and 17 deletions

View File

@ -7,6 +7,7 @@
(scheme write) (scheme write)
(only (chicken blob) blob->string) (only (chicken blob) blob->string)
(only (chicken file) create-temporary-directory) (only (chicken file) create-temporary-directory)
(chicken process-context)
(chicken process) (chicken process)
(only (srfi 4) u8vector->blob) (only (srfi 4) u8vector->blob)
(spiffy) (spiffy)
@ -68,6 +69,12 @@
(make-tar-header-for-regular-file filename bytes) (make-tar-header-for-regular-file filename bytes)
bytes (make-tar-padding bytes))) bytes (make-tar-padding bytes)))
(define (with-current-directory dir proc)
(let ((old-dir (current-directory)))
(dynamic-wind (lambda () (change-directory dir))
proc
(lambda () (change-directory old-dir)))))
(define (handle-the-scheme-implementation impl) (define (handle-the-scheme-implementation impl)
(let ((cmdline #f) (let ((cmdline #f)
(environ #f) (environ #f)
@ -115,13 +122,16 @@
(error "No main.scm file in archive")) (error "No main.scm file in archive"))
(let ((tempdir (create-temporary-directory))) (let ((tempdir (create-temporary-directory)))
(write tempdir)(newline) (write tempdir)(newline)
(with-current-directory
tempdir
(lambda ()
(for-each (lambda (entry) (for-each (lambda (entry)
(let ((name (car entry)) (let ((name (car entry))
(bytes (cdr entry))) (bytes (cdr entry)))
(call-with-port (call-with-port
(open-binary-output-file name) (open-binary-output-file name)
(lambda (out) (write-bytevector bytes out))))) (lambda (out) (write-bytevector bytes out)))))
files)) files)
(let ((command (append (implementation-command-line impl) (let ((command (append (implementation-command-line impl)
(list "main.scm") (list "main.scm")
cmdline))) cmdline)))
@ -131,7 +141,7 @@
(write-bytevector stdin to-sub) (write-bytevector stdin to-sub)
(close-output-port to-sub) (close-output-port to-sub)
(set! stdout (read-all-bytes from-sub)) (set! stdout (read-all-bytes from-sub))
(set! stderr (read-all-bytes from-sub-err)))) (set! stderr (read-all-bytes from-sub-err)))))))
(send-response (send-response
status: 'ok status: 'ok
headers: `((content-type ,tar-content-type)) headers: `((content-type ,tar-content-type))