profiles: Allow a profile to be added as an entry of another profile.

* guix/build/profiles.scm (build-etc/profile): When 'OUTPUT/etc/profile'
already exists, delete it first.
(build-profile): Likewise for 'OUTPUT/manifest'.
* tests/profiles.scm ("profile in profile"): New test.
This commit is contained in:
Ludovic Courtès 2019-01-20 01:33:25 +01:00
parent 2d17a904ac
commit 38b77f3464
No known key found for this signature in database
GPG key ID: 090B11993D9AEBB5
2 changed files with 50 additions and 5 deletions

View file

@ -1,5 +1,5 @@
;;; GNU Guix --- Functional package management for GNU ;;; GNU Guix --- Functional package management for GNU
;;; Copyright © 2015, 2017, 2018 Ludovic Courtès <ludo@gnu.org> ;;; Copyright © 2015, 2017, 2018, 2019 Ludovic Courtès <ludo@gnu.org>
;;; ;;;
;;; This file is part of GNU Guix. ;;; This file is part of GNU Guix.
;;; ;;;
@ -67,8 +67,14 @@ (define (write-environment-variable-definition port)
(define (build-etc/profile output search-paths) (define (build-etc/profile output search-paths)
"Build the 'OUTPUT/etc/profile' shell file containing environment variable "Build the 'OUTPUT/etc/profile' shell file containing environment variable
definitions for all the SEARCH-PATHS." definitions for all the SEARCH-PATHS."
(mkdir-p (string-append output "/etc")) (define file
(call-with-output-file (string-append output "/etc/profile") (string-append output "/etc/profile"))
(mkdir-p (dirname file))
(when (file-exists? file)
(delete-file file))
(call-with-output-file file
(lambda (port) (lambda (port)
;; The use of $GUIX_PROFILE described below is not great. Another ;; The use of $GUIX_PROFILE described below is not great. Another
;; option would have been to use "$1" and have users run: ;; option would have been to use "$1" and have users run:
@ -144,13 +150,22 @@ (define* (build-profile output inputs
create symlinks. Write MANIFEST, an sexp, to OUTPUT/manifest. Create create symlinks. Write MANIFEST, an sexp, to OUTPUT/manifest. Create
OUTPUT/etc/profile with Bash definitions for -all the variables listed in OUTPUT/etc/profile with Bash definitions for -all the variables listed in
SEARCH-PATHS." SEARCH-PATHS."
(define manifest-file
(string-append output "/manifest"))
;; Make the symlinks. ;; Make the symlinks.
(union-build output inputs (union-build output inputs
#:symlink symlink #:symlink symlink
#:log-port (%make-void-port "w")) #:log-port (%make-void-port "w"))
;; If one of the INPUTS provides a '/manifest' file, delete it. That can
;; happen if MANIFEST contains something such as a Guix instance, which is
;; ultimately built as a profile.
(when (file-exists? manifest-file)
(delete-file manifest-file))
;; Store meta-data. ;; Store meta-data.
(call-with-output-file (string-append output "/manifest") (call-with-output-file manifest-file
(lambda (p) (lambda (p)
(pretty-print manifest p))) (pretty-print manifest p)))

View file

@ -1,5 +1,5 @@
;;; GNU Guix --- Functional package management for GNU ;;; GNU Guix --- Functional package management for GNU
;;; Copyright © 2013, 2014, 2015, 2016, 2017, 2018 Ludovic Courtès <ludo@gnu.org> ;;; Copyright © 2013, 2014, 2015, 2016, 2017, 2018, 2019 Ludovic Courtès <ludo@gnu.org>
;;; Copyright © 2014 Alex Kost <alezost@gmail.com> ;;; Copyright © 2014 Alex Kost <alezost@gmail.com>
;;; ;;;
;;; This file is part of GNU Guix. ;;; This file is part of GNU Guix.
@ -591,6 +591,36 @@ (define (entry->sexp entry)
(built-derivations (list drv)) (built-derivations (list drv))
(return (readlink (readlink (string-append profile "/dangling"))))))) (return (readlink (readlink (string-append profile "/dangling")))))))
(test-equalm "profile in profile"
'("foo" "0")
;; Make sure we can build a profile that has another profile has one of its
;; entries. The new profile's /manifest and /etc/profile must override the
;; other's.
(mlet* %store-monad
((prof0 (profile-derivation
(manifest
(list (package->manifest-entry %bootstrap-guile)))
#:hooks '()
#:locales? #f))
(prof1 (profile-derivation
(manifest (list (manifest-entry
(name "foo")
(version "0")
(item prof0))))
#:hooks '()
#:locales? #f)))
(mbegin %store-monad
(built-derivations (list prof1))
(let ((out (derivation->output-path prof1)))
(return (and (file-exists?
(string-append out "/bin/guile"))
(let ((manifest (profile-manifest out)))
(match (manifest-entries manifest)
((entry)
(list (manifest-entry-name entry)
(manifest-entry-version entry)))))))))))
(test-end "profiles") (test-end "profiles")
;;; Local Variables: ;;; Local Variables: