mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-15 07:27:48 -05:00
build-system/gnu: Use invoke instead of system*.
* guix/build/gnu-build-system.scm (unpack, configure, build, check, install) (strip, compress-documentation): Use invoke and remove vestigial plumbing.
This commit is contained in:
parent
6d084076b4
commit
9a87649c86
1 changed files with 83 additions and 84 deletions
|
@ -1,5 +1,6 @@
|
||||||
;;; GNU Guix --- Functional package management for GNU
|
;;; GNU Guix --- Functional package management for GNU
|
||||||
;;; Copyright © 2012, 2013, 2014, 2015, 2016, 2017, 2018 Ludovic Courtès <ludo@gnu.org>
|
;;; Copyright © 2012, 2013, 2014, 2015, 2016, 2017, 2018 Ludovic Courtès <ludo@gnu.org>
|
||||||
|
;;; Copyright © 2018 Mark H Weaver <mhw@netris.org>
|
||||||
;;;
|
;;;
|
||||||
;;; This file is part of GNU Guix.
|
;;; This file is part of GNU Guix.
|
||||||
;;;
|
;;;
|
||||||
|
@ -152,12 +153,13 @@ (define* (unpack #:key source #:allow-other-keys)
|
||||||
;; Preserve timestamps (set to the Epoch) on the copied tree so that
|
;; Preserve timestamps (set to the Epoch) on the copied tree so that
|
||||||
;; things work deterministically.
|
;; things work deterministically.
|
||||||
(copy-recursively source "."
|
(copy-recursively source "."
|
||||||
#:keep-mtime? #t)
|
#:keep-mtime? #t))
|
||||||
#t)
|
(begin
|
||||||
(and (if (string-suffix? ".zip" source)
|
(if (string-suffix? ".zip" source)
|
||||||
(zero? (system* "unzip" source))
|
(invoke "unzip" source)
|
||||||
(zero? (system* "tar" "xvf" source)))
|
(invoke "tar" "xvf" source))
|
||||||
(chdir (first-subdirectory ".")))))
|
(chdir (first-subdirectory "."))))
|
||||||
|
#t)
|
||||||
|
|
||||||
(define %bootstrap-scripts
|
(define %bootstrap-scripts
|
||||||
;; Typical names of Autotools "bootstrap" scripts.
|
;; Typical names of Autotools "bootstrap" scripts.
|
||||||
|
@ -316,33 +318,32 @@ (define (package-name)
|
||||||
;; Call `configure' with a relative path. Otherwise, GCC's build system
|
;; Call `configure' with a relative path. Otherwise, GCC's build system
|
||||||
;; (for instance) records absolute source file names, which typically
|
;; (for instance) records absolute source file names, which typically
|
||||||
;; contain the hash part of the `.drv' file, leading to a reference leak.
|
;; contain the hash part of the `.drv' file, leading to a reference leak.
|
||||||
(zero? (apply system* bash
|
(apply invoke bash
|
||||||
(string-append srcdir "/configure")
|
(string-append srcdir "/configure")
|
||||||
flags))))
|
flags)))
|
||||||
|
|
||||||
(define* (build #:key (make-flags '()) (parallel-build? #t)
|
(define* (build #:key (make-flags '()) (parallel-build? #t)
|
||||||
#:allow-other-keys)
|
#:allow-other-keys)
|
||||||
(zero? (apply system* "make"
|
(apply invoke "make"
|
||||||
`(,@(if parallel-build?
|
`(,@(if parallel-build?
|
||||||
`("-j" ,(number->string (parallel-job-count)))
|
`("-j" ,(number->string (parallel-job-count)))
|
||||||
'())
|
'())
|
||||||
,@make-flags))))
|
,@make-flags)))
|
||||||
|
|
||||||
(define* (check #:key target (make-flags '()) (tests? (not target))
|
(define* (check #:key target (make-flags '()) (tests? (not target))
|
||||||
(test-target "check") (parallel-tests? #t)
|
(test-target "check") (parallel-tests? #t)
|
||||||
#:allow-other-keys)
|
#:allow-other-keys)
|
||||||
(if tests?
|
(if tests?
|
||||||
(zero? (apply system* "make" test-target
|
(apply invoke "make" test-target
|
||||||
`(,@(if parallel-tests?
|
`(,@(if parallel-tests?
|
||||||
`("-j" ,(number->string (parallel-job-count)))
|
`("-j" ,(number->string (parallel-job-count)))
|
||||||
'())
|
'())
|
||||||
,@make-flags)))
|
,@make-flags))
|
||||||
(begin
|
(format #t "test suite not run~%"))
|
||||||
(format #t "test suite not run~%")
|
#t)
|
||||||
#t)))
|
|
||||||
|
|
||||||
(define* (install #:key (make-flags '()) #:allow-other-keys)
|
(define* (install #:key (make-flags '()) #:allow-other-keys)
|
||||||
(zero? (apply system* "make" "install" make-flags)))
|
(apply invoke "make" "install" make-flags))
|
||||||
|
|
||||||
(define* (patch-shebangs #:key inputs outputs (patch-shebangs? #t)
|
(define* (patch-shebangs #:key inputs outputs (patch-shebangs? #t)
|
||||||
#:allow-other-keys)
|
#:allow-other-keys)
|
||||||
|
@ -408,10 +409,8 @@ (define (make-debug-file file)
|
||||||
(let ((debug (debug-file file)))
|
(let ((debug (debug-file file)))
|
||||||
(mkdir-p (dirname debug))
|
(mkdir-p (dirname debug))
|
||||||
(copy-file file debug)
|
(copy-file file debug)
|
||||||
(and (zero? (system* strip-command "--only-keep-debug" debug))
|
(invoke strip-command "--only-keep-debug" debug)
|
||||||
(begin
|
(chmod debug #o400)))
|
||||||
(chmod debug #o400)
|
|
||||||
#t))))
|
|
||||||
|
|
||||||
(define (add-debug-link file)
|
(define (add-debug-link file)
|
||||||
;; Add a debug link in FILE (info "(binutils) strip").
|
;; Add a debug link in FILE (info "(binutils) strip").
|
||||||
|
@ -421,10 +420,10 @@ (define (add-debug-link file)
|
||||||
;; `bfd_fill_in_gnu_debuglink_section' function.) No reference to
|
;; `bfd_fill_in_gnu_debuglink_section' function.) No reference to
|
||||||
;; DEBUG-OUTPUT is kept because bfd keeps only the basename of the debug
|
;; DEBUG-OUTPUT is kept because bfd keeps only the basename of the debug
|
||||||
;; file.
|
;; file.
|
||||||
(zero? (system* objcopy-command "--enable-deterministic-archives"
|
(invoke objcopy-command "--enable-deterministic-archives"
|
||||||
(string-append "--add-gnu-debuglink="
|
(string-append "--add-gnu-debuglink="
|
||||||
(debug-file file))
|
(debug-file file))
|
||||||
file)))
|
file))
|
||||||
|
|
||||||
(define (strip-dir dir)
|
(define (strip-dir dir)
|
||||||
(format #t "stripping binaries in ~s with ~s and flags ~s~%"
|
(format #t "stripping binaries in ~s with ~s and flags ~s~%"
|
||||||
|
@ -434,17 +433,18 @@ (define (strip-dir dir)
|
||||||
debug-output objcopy-command))
|
debug-output objcopy-command))
|
||||||
|
|
||||||
(for-each (lambda (file)
|
(for-each (lambda (file)
|
||||||
(and (or (elf-file? file) (ar-file? file))
|
(when (or (elf-file? file) (ar-file? file))
|
||||||
(or (not debug-output)
|
(when debug-output
|
||||||
(make-debug-file file))
|
(make-debug-file file))
|
||||||
|
|
||||||
;; Ensure the file is writable.
|
;; Ensure the file is writable.
|
||||||
(begin (make-file-writable file) #t)
|
(make-file-writable file)
|
||||||
|
|
||||||
(zero? (apply system* strip-command
|
(apply invoke strip-command
|
||||||
(append strip-flags (list file))))
|
(append strip-flags (list file)))
|
||||||
(or (not debug-output)
|
|
||||||
(add-debug-link file))))
|
(when debug-output
|
||||||
|
(add-debug-link file))))
|
||||||
(find-files dir
|
(find-files dir
|
||||||
(lambda (file stat)
|
(lambda (file stat)
|
||||||
;; Ignore symlinks such as:
|
;; Ignore symlinks such as:
|
||||||
|
@ -452,15 +452,16 @@ (define (strip-dir dir)
|
||||||
(eq? 'regular (stat:type stat)))
|
(eq? 'regular (stat:type stat)))
|
||||||
#:stat lstat)))
|
#:stat lstat)))
|
||||||
|
|
||||||
(or (not strip-binaries?)
|
(when strip-binaries?
|
||||||
(every strip-dir
|
(for-each
|
||||||
(append-map (match-lambda
|
strip-dir
|
||||||
((_ . dir)
|
(append-map (match-lambda
|
||||||
(filter-map (lambda (d)
|
((_ . dir)
|
||||||
(let ((sub (string-append dir "/" d)))
|
(filter-map (lambda (d)
|
||||||
(and (directory-exists? sub) sub)))
|
(let ((sub (string-append dir "/" d)))
|
||||||
strip-directories)))
|
(and (directory-exists? sub) sub)))
|
||||||
outputs))))
|
strip-directories)))
|
||||||
|
outputs))))
|
||||||
|
|
||||||
(define* (validate-runpath #:key
|
(define* (validate-runpath #:key
|
||||||
(validate-runpath? #t)
|
(validate-runpath? #t)
|
||||||
|
@ -586,47 +587,45 @@ (define (points-to-symlink? symlink)
|
||||||
(apply throw args))))))
|
(apply throw args))))))
|
||||||
|
|
||||||
(define (maybe-compress-directory directory regexp)
|
(define (maybe-compress-directory directory regexp)
|
||||||
(or (not (directory-exists? directory))
|
(when (directory-exists? directory)
|
||||||
(match (find-files directory regexp)
|
(match (find-files directory regexp)
|
||||||
(() ;nothing to compress
|
(() ;nothing to compress
|
||||||
#t)
|
#t)
|
||||||
((files ...) ;one or more files
|
((files ...) ;one or more files
|
||||||
(format #t
|
(format #t
|
||||||
"compressing documentation in '~a' with ~s and flags ~s~%"
|
"compressing documentation in '~a' with ~s and flags ~s~%"
|
||||||
directory documentation-compressor
|
directory documentation-compressor
|
||||||
documentation-compressor-flags)
|
documentation-compressor-flags)
|
||||||
(call-with-values
|
(call-with-values
|
||||||
(lambda ()
|
(lambda ()
|
||||||
(partition symbolic-link? files))
|
(partition symbolic-link? files))
|
||||||
(lambda (symlinks regular-files)
|
(lambda (symlinks regular-files)
|
||||||
;; Compress the non-symlink files, and adjust symlinks to refer
|
;; Compress the non-symlink files, and adjust symlinks to refer
|
||||||
;; to the compressed files. Leave files that have hard links
|
;; to the compressed files. Leave files that have hard links
|
||||||
;; unchanged ('gzip' would refuse to compress them anyway.)
|
;; unchanged ('gzip' would refuse to compress them anyway.)
|
||||||
;; Also, do not retarget symbolic links pointing to other
|
;; Also, do not retarget symbolic links pointing to other
|
||||||
;; symbolic links, since these are not compressed.
|
;; symbolic links, since these are not compressed.
|
||||||
(and (every retarget-symlink
|
(for-each retarget-symlink
|
||||||
(filter (lambda (symlink)
|
(filter (lambda (symlink)
|
||||||
(and (not (points-to-symlink? symlink))
|
(and (not (points-to-symlink? symlink))
|
||||||
(string-match regexp symlink)))
|
(string-match regexp symlink)))
|
||||||
symlinks))
|
symlinks))
|
||||||
(zero?
|
(apply invoke documentation-compressor
|
||||||
(apply system* documentation-compressor
|
(append documentation-compressor-flags
|
||||||
(append documentation-compressor-flags
|
(remove has-links? regular-files)))))))))
|
||||||
(remove has-links? regular-files)))))))))))
|
|
||||||
|
|
||||||
(define (maybe-compress output)
|
(define (maybe-compress output)
|
||||||
(and (maybe-compress-directory (string-append output "/share/man")
|
(maybe-compress-directory (string-append output "/share/man")
|
||||||
"\\.[0-9]+$")
|
"\\.[0-9]+$")
|
||||||
(maybe-compress-directory (string-append output "/share/info")
|
(maybe-compress-directory (string-append output "/share/info")
|
||||||
"\\.info(-[0-9]+)?$")))
|
"\\.info(-[0-9]+)?$"))
|
||||||
|
|
||||||
(if compress-documentation?
|
(if compress-documentation?
|
||||||
(match outputs
|
(match outputs
|
||||||
(((names . directories) ...)
|
(((names . directories) ...)
|
||||||
(every maybe-compress directories)))
|
(for-each maybe-compress directories)))
|
||||||
(begin
|
(format #t "not compressing documentation~%"))
|
||||||
(format #t "not compressing documentation~%")
|
#t)
|
||||||
#t)))
|
|
||||||
|
|
||||||
(define* (delete-info-dir-file #:key outputs #:allow-other-keys)
|
(define* (delete-info-dir-file #:key outputs #:allow-other-keys)
|
||||||
"Delete any 'share/info/dir' file from OUTPUTS."
|
"Delete any 'share/info/dir' file from OUTPUTS."
|
||||||
|
|
Loading…
Reference in a new issue