activation: Make the /bin/sh symlink at activation time.

* gnu/build/install.scm (directives): Remove "/bin/sh".
* gnu/build/activation.scm (activate-/bin/sh): New procedure.
* gnu/system.scm (operating-system-activation-script): Use it.
This commit is contained in:
Ludovic Courtès 2014-09-11 22:18:52 +02:00
parent ecd06ca9fa
commit ee248b6a70
3 changed files with 11 additions and 1 deletions

View file

@ -26,6 +26,7 @@ (define-module (gnu build activation)
#:export (activate-users+groups
activate-etc
activate-setuid-programs
activate-/bin/sh
activate-current-system))
;;; Commentary:
@ -214,6 +215,11 @@ (define (make-setuid-program prog)
(for-each make-setuid-program programs))
(define (activate-/bin/sh shell)
"Change /bin/sh to point to SHELL."
(symlink shell "/bin/sh.new")
(rename-file "/bin/sh.new" "/bin/sh"))
(define %current-system
;; The system that is current (a symlink.) This is not necessarily the same
;; as the system we booted (aka. /run/booted-system) because we can re-build

View file

@ -113,7 +113,6 @@ (define (directives store)
("/var/guix/gcroots/current-system" -> "/run/current-system")
(directory "/bin")
("/bin/sh" -> "/run/current-system/profile/bin/bash")
(directory "/tmp" 0 0 #o1777) ; sticky bit
(directory "/root" 0 0) ; an exception

View file

@ -417,6 +417,11 @@ (define group-specs
(use-modules (gnu build activation))
;; Make sure /bin/sh is valid and current.
(activate-/bin/sh
(string-append #$(canonical-package bash)
"/bin/sh"))
;; Populate /etc.
(activate-etc #$etc)