mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2024-11-19 05:07:11 -05:00
glib-or-gtk-build-system: Look up the interpreter in 'inputs'.
* guix/build/glib-or-gtk-build-system.scm (wrap-all-programs): Pass the shell interpreter from 'inputs' to 'wrap-program' using 'search-input-file'. Partially-Fixes: <https://issues.guix.gnu.org/47869> Signed-off-by: Ludovic Courtès <ludo@gnu.org>
This commit is contained in:
parent
5378edeab4
commit
1dbc3b2b0c
1 changed files with 13 additions and 7 deletions
|
@ -2,6 +2,7 @@
|
|||
;;; Copyright © 2014 Federico Beffa <beffa@fbengineering.ch>
|
||||
;;; Copyright © 2014, 2015 Ludovic Courtès <ludo@gnu.org>
|
||||
;;; Copyright © 2018 Mark H Weaver <mhw@netris.org>
|
||||
;;; Copyright © 2021 Maxime Devos <maximedevos@telenet.be>
|
||||
;;;
|
||||
;;; This file is part of GNU Guix.
|
||||
;;;
|
||||
|
@ -136,6 +137,11 @@ (define* (wrap-all-programs #:key inputs outputs
|
|||
GLIB-OR-GTK-WRAP-EXCLUDED-OUTPUTS. This is useful when an output is known not
|
||||
to contain any GLib or GTK+ binaries, and where wrapping would gratuitously
|
||||
add a dependency of that output on GLib and GTK+."
|
||||
;; Do not require bash to be present in the package inputs
|
||||
;; even when there is nothing to wrap.
|
||||
;; Also, calculate (sh) only once to prevent some I/O.
|
||||
(define %sh (delay (search-input-file inputs "bin/bash")))
|
||||
(define (sh) (force %sh))
|
||||
(define handle-output
|
||||
(match-lambda
|
||||
((output . directory)
|
||||
|
@ -165,36 +171,36 @@ (define handle-output
|
|||
#f)))
|
||||
(cond
|
||||
((and data-env-var gtk-mod-env-var gio-mod-env-var)
|
||||
(for-each (cut wrap-program <>
|
||||
(for-each (cut wrap-program <> #:sh (sh)
|
||||
data-env-var
|
||||
gtk-mod-env-var
|
||||
gio-mod-env-var)
|
||||
bin-list))
|
||||
((and data-env-var gtk-mod-env-var (not gio-mod-env-var))
|
||||
(for-each (cut wrap-program <>
|
||||
(for-each (cut wrap-program <> #:sh (sh)
|
||||
data-env-var
|
||||
gtk-mod-env-var)
|
||||
bin-list))
|
||||
((and data-env-var (not gtk-mod-env-var) gio-mod-env-var)
|
||||
(for-each (cut wrap-program <>
|
||||
(for-each (cut wrap-program <> #:sh (sh)
|
||||
data-env-var
|
||||
gio-mod-env-var)
|
||||
bin-list))
|
||||
((and (not data-env-var) gtk-mod-env-var gio-mod-env-var)
|
||||
(for-each (cut wrap-program <>
|
||||
(for-each (cut wrap-program <> #:sh (sh)
|
||||
gio-mod-env-var
|
||||
gtk-mod-env-var)
|
||||
bin-list))
|
||||
((and data-env-var (not gtk-mod-env-var) (not gio-mod-env-var))
|
||||
(for-each (cut wrap-program <>
|
||||
(for-each (cut wrap-program <> #:sh (sh)
|
||||
data-env-var)
|
||||
bin-list))
|
||||
((and (not data-env-var) gtk-mod-env-var (not gio-mod-env-var))
|
||||
(for-each (cut wrap-program <>
|
||||
(for-each (cut wrap-program <> #:sh (sh)
|
||||
gtk-mod-env-var)
|
||||
bin-list))
|
||||
((and (not data-env-var) (not gtk-mod-env-var) gio-mod-env-var)
|
||||
(for-each (cut wrap-program <>
|
||||
(for-each (cut wrap-program <> #:sh (sh)
|
||||
gio-mod-env-var)
|
||||
bin-list))))))))
|
||||
|
||||
|
|
Loading…
Reference in a new issue