gexp: 'compiled-modules' prints a line for each module.
* guix/gexp.scm (compiled-modules)[build]: Add 'processed' parameter to 'process-entry' and 'process-directory'. Print a message before each 'compile-file' call.
This commit is contained in:
parent
e640c9e6f3
commit
d32922759b
@ -1051,6 +1051,8 @@ last one is created from the given <scheme-file> object."
|
|||||||
"Return a derivation that builds a tree containing the `.go' files
|
"Return a derivation that builds a tree containing the `.go' files
|
||||||
corresponding to MODULES. All the MODULES are built in a context where
|
corresponding to MODULES. All the MODULES are built in a context where
|
||||||
they can refer to each other."
|
they can refer to each other."
|
||||||
|
(define total (length modules))
|
||||||
|
|
||||||
(mlet %store-monad ((modules (imported-modules modules
|
(mlet %store-monad ((modules (imported-modules modules
|
||||||
#:system system
|
#:system system
|
||||||
#:guile guile
|
#:guile guile
|
||||||
@ -1062,32 +1064,42 @@ they can refer to each other."
|
|||||||
(primitive-load (ungexp %utils-module)) ;for 'mkdir-p'
|
(primitive-load (ungexp %utils-module)) ;for 'mkdir-p'
|
||||||
|
|
||||||
(use-modules (ice-9 ftw)
|
(use-modules (ice-9 ftw)
|
||||||
|
(ice-9 format)
|
||||||
|
(srfi srfi-1)
|
||||||
(srfi srfi-26)
|
(srfi srfi-26)
|
||||||
(system base compile))
|
(system base compile))
|
||||||
|
|
||||||
(define (regular? file)
|
(define (regular? file)
|
||||||
(not (member file '("." ".."))))
|
(not (member file '("." ".."))))
|
||||||
|
|
||||||
(define (process-entry entry output)
|
(define (process-entry entry output processed)
|
||||||
(if (file-is-directory? entry)
|
(if (file-is-directory? entry)
|
||||||
(let ((output (string-append output "/" (basename entry))))
|
(let ((output (string-append output "/" (basename entry))))
|
||||||
(mkdir-p output)
|
(mkdir-p output)
|
||||||
(process-directory entry output))
|
(process-directory entry output processed))
|
||||||
(let* ((base (basename entry ".scm"))
|
(let* ((base (basename entry ".scm"))
|
||||||
(output (string-append output "/" base ".go")))
|
(output (string-append output "/" base ".go")))
|
||||||
|
(format #t "[~2@a/~2@a] Compiling '~a'...~%"
|
||||||
|
(+ 1 processed) (ungexp total) entry)
|
||||||
(compile-file entry
|
(compile-file entry
|
||||||
#:output-file output
|
#:output-file output
|
||||||
#:opts %auto-compilation-options))))
|
#:opts %auto-compilation-options)
|
||||||
|
(+ 1 processed))))
|
||||||
|
|
||||||
(define (process-directory directory output)
|
(define (process-directory directory output processed)
|
||||||
(let ((entries (map (cut string-append directory "/" <>)
|
(let ((entries (map (cut string-append directory "/" <>)
|
||||||
(scandir directory regular?))))
|
(scandir directory regular?))))
|
||||||
(for-each (cut process-entry <> output) entries)))
|
(fold (cut process-entry <> output <>)
|
||||||
|
processed
|
||||||
|
entries)))
|
||||||
|
|
||||||
|
(setvbuf (current-output-port)
|
||||||
|
(cond-expand (guile-2.2 'line) (else _IOLBF)))
|
||||||
|
|
||||||
(set! %load-path (cons (ungexp modules) %load-path))
|
(set! %load-path (cons (ungexp modules) %load-path))
|
||||||
(mkdir (ungexp output))
|
(mkdir (ungexp output))
|
||||||
(chdir (ungexp modules))
|
(chdir (ungexp modules))
|
||||||
(process-directory "." (ungexp output)))))
|
(process-directory "." (ungexp output) 0))))
|
||||||
|
|
||||||
;; TODO: Pass MODULES as an environment variable.
|
;; TODO: Pass MODULES as an environment variable.
|
||||||
(gexp->derivation name build
|
(gexp->derivation name build
|
||||||
|
Loading…
Reference in New Issue
Block a user