mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-25 20:19:18 -05:00
guix system: Restore load path after running the activation script.
Fixes <http://bugs.gnu.org/22753>. Reported by Mark H Weaver <mhw@netris.org>. * guix/scripts/system.scm (save-load-path-excursion): New variable. (upgrade-shepherd-services): Add comment about the issue. (switch-to-system): Use 'save-load-path-excursion' around 'primitive-load' call.
This commit is contained in:
parent
06b76acceb
commit
cfd503205e
1 changed files with 22 additions and 1 deletions
|
@ -211,6 +211,19 @@ (define-syntax-rule (save-environment-excursion body ...)
|
|||
(lambda ()
|
||||
(environ env)))))
|
||||
|
||||
(define-syntax-rule (save-load-path-excursion body ...)
|
||||
"Save the current values of '%load-path' and '%load-compiled-path', run
|
||||
BODY..., and restore them."
|
||||
(let ((path %load-path)
|
||||
(cpath %load-compiled-path))
|
||||
(dynamic-wind
|
||||
(const #t)
|
||||
(lambda ()
|
||||
body ...)
|
||||
(lambda ()
|
||||
(set! %load-path path)
|
||||
(set! %load-compiled-path cpath)))))
|
||||
|
||||
(define-syntax-rule (warn-on-system-error body ...)
|
||||
(catch 'system-error
|
||||
(lambda ()
|
||||
|
@ -273,6 +286,9 @@ (define to-unload
|
|||
(info (_ "loading new services:~{ ~a~}...~%") to-load-names)
|
||||
(mlet %store-monad ((files (mapm %store-monad shepherd-service-file
|
||||
to-load)))
|
||||
;; Here we assume that FILES are exactly those that were computed
|
||||
;; as part of the derivation that built OS, which is normally the
|
||||
;; case.
|
||||
(load-services (map derivation->output-path files))
|
||||
|
||||
(for-each start-service
|
||||
|
@ -299,7 +315,12 @@ (define* (switch-to-system os
|
|||
;; Tell 'activate-current-system' what the new system is.
|
||||
(setenv "GUIX_NEW_SYSTEM" system)
|
||||
|
||||
(primitive-load (derivation->output-path script)))
|
||||
;; The activation script may modify '%load-path' & co., so protect
|
||||
;; against that. This is necessary to ensure that
|
||||
;; 'upgrade-shepherd-services' gets to see the right modules when it
|
||||
;; computes derivations with (gexp->derivation #:modules …).
|
||||
(save-load-path-excursion
|
||||
(primitive-load (derivation->output-path script))))
|
||||
|
||||
;; Finally, try to update system services.
|
||||
(upgrade-shepherd-services os))))
|
||||
|
|
Loading…
Reference in a new issue