mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-26 12:39:36 -05:00
self: 'compiled-files' builds the given list of files.
* guix/self.scm (compiled-files): Add 'module-files' parameter. [build]: 'process-directory' now honors MODULE-FILES instead of building any '.scm' file it sees. (scheme-node): Adjust accordingly.
This commit is contained in:
parent
e3a87d770f
commit
8031b3fa3c
1 changed files with 14 additions and 13 deletions
|
@ -171,7 +171,8 @@ (define* (scheme-node name modules #:optional (dependencies '())
|
|||
(source (imported-files (string-append name "-source")
|
||||
(append module-files extra-files))))
|
||||
(node name modules source dependencies
|
||||
(compiled-modules name source modules
|
||||
(compiled-modules name source
|
||||
(map car module-files)
|
||||
(map node-source dependencies)
|
||||
(map node-compiled dependencies)
|
||||
#:extensions extensions
|
||||
|
@ -505,7 +506,7 @@ (define build
|
|||
#:substitutable? #f
|
||||
#:env-vars (("COLUMNS" . "200")))))
|
||||
|
||||
(define* (compiled-modules name module-tree modules
|
||||
(define* (compiled-modules name module-tree module-files
|
||||
#:optional
|
||||
(dependencies '())
|
||||
(dependencies-compiled '())
|
||||
|
@ -513,6 +514,9 @@ (define* (compiled-modules name module-tree modules
|
|||
(extensions '()) ;full-blown Guile packages
|
||||
parallel?
|
||||
guile-for-build)
|
||||
"Build all the MODULE-FILES from MODULE-TREE. MODULE-FILES must be a list
|
||||
like '(\"guix/foo.scm\" \"gnu/bar.scm\") and MODULE-TREE is the directory
|
||||
containing MODULE-FILES and possibly other files as well."
|
||||
;; This is a non-monadic, enhanced version of 'compiled-file' from (guix
|
||||
;; gexp).
|
||||
(define build
|
||||
|
@ -543,16 +547,13 @@ (define (report-compilation file total completed)
|
|||
(* 100. (/ completed total)) total)
|
||||
(force-output))
|
||||
|
||||
(define (process-directory directory output)
|
||||
(let ((files (find-files directory "\\.scm$"))
|
||||
(prefix (+ 1 (string-length directory))))
|
||||
;; Hide compilation warnings.
|
||||
(parameterize ((current-warning-port (%make-void-port "w")))
|
||||
(compile-files directory #$output
|
||||
(map (cut string-drop <> prefix) files)
|
||||
#:workers (parallel-job-count)
|
||||
#:report-load report-load
|
||||
#:report-compilation report-compilation))))
|
||||
(define (process-directory directory files output)
|
||||
;; Hide compilation warnings.
|
||||
(parameterize ((current-warning-port (%make-void-port "w")))
|
||||
(compile-files directory #$output files
|
||||
#:workers (parallel-job-count)
|
||||
#:report-load report-load
|
||||
#:report-compilation report-compilation)))
|
||||
|
||||
(setvbuf (current-output-port) _IONBF)
|
||||
(setvbuf (current-error-port) _IONBF)
|
||||
|
@ -580,7 +581,7 @@ (define (process-directory directory output)
|
|||
|
||||
(mkdir #$output)
|
||||
(chdir #+module-tree)
|
||||
(process-directory "." #$output)
|
||||
(process-directory "." '#+module-files #$output)
|
||||
(newline))))
|
||||
|
||||
(computed-file name build
|
||||
|
|
Loading…
Reference in a new issue