mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-12 06:06:53 -05:00
distro: Change $DISTRO_{PATCH,BOOTSTRAP}_DIRECTORY to search paths.
* distro.scm (not-colon): New variable. (%patch-directory): Rename to... (%patch-path): ... this. Turn into a list. Expect $DISTRO_PATCH_PATH to be a colon-separated search path. (%bootstrap-binaries-directory): Rename to... (%bootstrap-binaries-path): ... this. Likewise. (search-patch, search-bootstrap-binary): Adjust accordingly. * pre-inst-env.in: Change to use `DISTRO_PATCH_PATH' and `DISTRO_BOOTSTRAP_PATH'.
This commit is contained in:
parent
cc9abfd0f4
commit
a9f60c421b
2 changed files with 20 additions and 12 deletions
26
distro.scm
26
distro.scm
|
@ -37,23 +37,31 @@ (define-module (distro)
|
||||||
|
|
||||||
(define _ (cut gettext <> "guix"))
|
(define _ (cut gettext <> "guix"))
|
||||||
|
|
||||||
(define %patch-directory
|
(define not-colon
|
||||||
(make-parameter
|
;; The char set that contains all the characters but `:'.
|
||||||
(or (getenv "DISTRO_PATCH_DIRECTORY")
|
(char-set-complement (char-set #\:)))
|
||||||
(compile-time-value (getenv "DISTRO_INSTALLED_PATCH_DIRECTORY")))))
|
|
||||||
|
|
||||||
(define %bootstrap-binaries-directory
|
(define %patch-path
|
||||||
(make-parameter
|
(make-parameter
|
||||||
(or (getenv "DISTRO_BOOTSTRAP_DIRECTORY")
|
(or (and=> (getenv "DISTRO_PATCH_PATH")
|
||||||
(compile-time-value (getenv "DISTRO_INSTALLED_BOOTSTRAP_DIRECTORY")))))
|
(cut string-tokenize <> not-colon))
|
||||||
|
(compile-time-value
|
||||||
|
(list (getenv "DISTRO_INSTALLED_PATCH_DIRECTORY"))))))
|
||||||
|
|
||||||
|
(define %bootstrap-binaries-path
|
||||||
|
(make-parameter
|
||||||
|
(or (and=> (getenv "DISTRO_BOOTSTRAP_PATH")
|
||||||
|
(cut string-tokenize <> not-colon))
|
||||||
|
(compile-time-value
|
||||||
|
(list (getenv "DISTRO_INSTALLED_BOOTSTRAP_DIRECTORY"))))))
|
||||||
|
|
||||||
(define (search-patch file-name)
|
(define (search-patch file-name)
|
||||||
"Search the patch FILE-NAME."
|
"Search the patch FILE-NAME."
|
||||||
(search-path (list (%patch-directory)) file-name))
|
(search-path (%patch-path) file-name))
|
||||||
|
|
||||||
(define (search-bootstrap-binary file-name system)
|
(define (search-bootstrap-binary file-name system)
|
||||||
"Search the bootstrap binary FILE-NAME for SYSTEM."
|
"Search the bootstrap binary FILE-NAME for SYSTEM."
|
||||||
(search-path (list (%bootstrap-binaries-directory))
|
(search-path (%bootstrap-binaries-path)
|
||||||
(string-append system "/" file-name)))
|
(string-append system "/" file-name)))
|
||||||
|
|
||||||
(define %distro-module-directory
|
(define %distro-module-directory
|
||||||
|
|
|
@ -23,12 +23,12 @@
|
||||||
# Run COMMAND in a pre-installation environment. Typical use is
|
# Run COMMAND in a pre-installation environment. Typical use is
|
||||||
# "./pre-inst-env guix-build hello".
|
# "./pre-inst-env guix-build hello".
|
||||||
|
|
||||||
DISTRO_PATCH_DIRECTORY="@abs_top_srcdir@/distro/packages/patches"
|
DISTRO_PATCH_PATH="@abs_top_srcdir@/distro/packages/patches"
|
||||||
DISTRO_BOOTSTRAP_DIRECTORY="@abs_top_srcdir@/distro/packages/bootstrap"
|
DISTRO_BOOTSTRAP_PATH="@abs_top_srcdir@/distro/packages/bootstrap"
|
||||||
GUILE_LOAD_COMPILED_PATH="@abs_top_builddir@${GUILE_LOAD_COMPILED_PATH:+:}$GUILE_LOAD_COMPILED_PATH"
|
GUILE_LOAD_COMPILED_PATH="@abs_top_builddir@${GUILE_LOAD_COMPILED_PATH:+:}$GUILE_LOAD_COMPILED_PATH"
|
||||||
GUILE_LOAD_PATH="@abs_top_srcdir@${GUILE_LOAD_PATH:+:}:$GUILE_LOAD_PATH"
|
GUILE_LOAD_PATH="@abs_top_srcdir@${GUILE_LOAD_PATH:+:}:$GUILE_LOAD_PATH"
|
||||||
|
|
||||||
export DISTRO_PATCH_DIRECTORY DISTRO_BOOTSTRAP_DIRECTORY
|
export DISTRO_PATCH_PATH DISTRO_BOOTSTRAP_PATH
|
||||||
export GUILE_LOAD_COMPILED_PATH GUILE_LOAD_PATH
|
export GUILE_LOAD_COMPILED_PATH GUILE_LOAD_PATH
|
||||||
|
|
||||||
# Define $PATH so that `guix-build' and friends are easily found.
|
# Define $PATH so that `guix-build' and friends are easily found.
|
||||||
|
|
Loading…
Reference in a new issue