mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-12 06:06:53 -05:00
self: Ensure the daemon refers to the right 'guix' command.
Previously it would refer to
/var/guix/profiles/per-user/root/current-guix/bin/guix, which would fail
when that profile does not exist. This is notably the case when using
'channel-instance->package' as done in commit
7e6d8d366a
.
* gnu/packages/package-management.scm (guix-daemon)[arguments]: In
'install phase, honor environment variable 'GUIX'.
* guix/self.scm (whole-package)[wrap]: New procedure.
Use it.
This commit is contained in:
parent
a87d66f371
commit
765a5bf167
2 changed files with 13 additions and 3 deletions
|
@ -356,7 +356,7 @@ (define-public guix-daemon
|
||||||
(let ((out (assoc-ref outputs "out")))
|
(let ((out (assoc-ref outputs "out")))
|
||||||
(substitute* (find-files (string-append out "/libexec"))
|
(substitute* (find-files (string-append out "/libexec"))
|
||||||
(("exec \".*/bin/guix\"")
|
(("exec \".*/bin/guix\"")
|
||||||
"exec /var/guix/profiles/per-user/root/current-guix/bin/guix"))
|
"exec \"${GUIX:-/var/guix/profiles/per-user/root/current-guix/bin/guix}\""))
|
||||||
#t)))
|
#t)))
|
||||||
(delete 'wrap-program)))))))
|
(delete 'wrap-program)))))))
|
||||||
|
|
||||||
|
|
|
@ -460,17 +460,27 @@ (define* (whole-package name modules dependencies
|
||||||
the modules (under share/guile/site and lib/guile), and DEPENDENCIES, a list
|
the modules (under share/guile/site and lib/guile), and DEPENDENCIES, a list
|
||||||
of packages depended on. COMMAND is the 'guix' program to use; INFO is the
|
of packages depended on. COMMAND is the 'guix' program to use; INFO is the
|
||||||
Info manual."
|
Info manual."
|
||||||
|
(define (wrap daemon)
|
||||||
|
(program-file "guix-daemon"
|
||||||
|
#~(begin
|
||||||
|
(setenv "GUIX" #$command)
|
||||||
|
(apply execl #$(file-append daemon "/bin/guix-daemon")
|
||||||
|
"guix-daemon" (cdr (command-line))))))
|
||||||
|
|
||||||
(computed-file name
|
(computed-file name
|
||||||
(with-imported-modules '((guix build utils))
|
(with-imported-modules '((guix build utils))
|
||||||
#~(begin
|
#~(begin
|
||||||
(use-modules (guix build utils))
|
(use-modules (guix build utils))
|
||||||
|
|
||||||
|
(define daemon
|
||||||
|
#$(and daemon (wrap daemon)))
|
||||||
|
|
||||||
(mkdir-p (string-append #$output "/bin"))
|
(mkdir-p (string-append #$output "/bin"))
|
||||||
(symlink #$command
|
(symlink #$command
|
||||||
(string-append #$output "/bin/guix"))
|
(string-append #$output "/bin/guix"))
|
||||||
|
|
||||||
(when #$daemon
|
(when daemon
|
||||||
(symlink (string-append #$daemon "/bin/guix-daemon")
|
(symlink daemon
|
||||||
(string-append #$output "/bin/guix-daemon")))
|
(string-append #$output "/bin/guix-daemon")))
|
||||||
|
|
||||||
(let ((share (string-append #$output "/share"))
|
(let ((share (string-append #$output "/share"))
|
||||||
|
|
Loading…
Reference in a new issue