Use temp directory
This commit is contained in:
parent
05298fb1f0
commit
93c7ef8046
|
@ -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,23 +122,26 @@
|
||||||
(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)
|
||||||
(for-each (lambda (entry)
|
(with-current-directory
|
||||||
(let ((name (car entry))
|
tempdir
|
||||||
(bytes (cdr entry)))
|
(lambda ()
|
||||||
(call-with-port
|
(for-each (lambda (entry)
|
||||||
(open-binary-output-file name)
|
(let ((name (car entry))
|
||||||
(lambda (out) (write-bytevector bytes out)))))
|
(bytes (cdr entry)))
|
||||||
files))
|
(call-with-port
|
||||||
(let ((command (append (implementation-command-line impl)
|
(open-binary-output-file name)
|
||||||
(list "main.scm")
|
(lambda (out) (write-bytevector bytes out)))))
|
||||||
cmdline)))
|
files)
|
||||||
(write command)(newline)
|
(let ((command (append (implementation-command-line impl)
|
||||||
(let-values (((from-sub to-sub sub-pid from-sub-err)
|
(list "main.scm")
|
||||||
(process* (car command) (cdr command) environ)))
|
cmdline)))
|
||||||
(write-bytevector stdin to-sub)
|
(write command)(newline)
|
||||||
(close-output-port to-sub)
|
(let-values (((from-sub to-sub sub-pid from-sub-err)
|
||||||
(set! stdout (read-all-bytes from-sub))
|
(process* (car command) (cdr command) environ)))
|
||||||
(set! stderr (read-all-bytes from-sub-err))))
|
(write-bytevector stdin to-sub)
|
||||||
|
(close-output-port to-sub)
|
||||||
|
(set! stdout (read-all-bytes from-sub))
|
||||||
|
(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))
|
||||||
|
|
Loading…
Reference in New Issue