guix-commits
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

02/02: guix system: Invoking 'guix system init' twice keeps timestamps z


From: Ludovic Courtès
Subject: 02/02: guix system: Invoking 'guix system init' twice keeps timestamps zeroed.
Date: Sun, 11 Nov 2018 17:53:53 -0500 (EST)

civodul pushed a commit to branch master
in repository guix.

commit 6c843907e90c9f6a1af389f9624cac8b6b01ecbb
Author: Ludovic Courtès <address@hidden>
Date:   Sun Nov 11 23:48:53 2018 +0100

    guix system: Invoking 'guix system init' twice keeps timestamps zeroed.
    
    Fixes a bug whereby running 'guix system init config.scm /mnt' twice
    would, on the second run, change timestamps in /mnt/gnu/store from the
    Epoch to now.  This is because the 'register-path' call would bypass the
    'reset-timestamps' phase altogether in that case, as a consequence of
    commit bb3b6ccb05550fbfbeb459c68819a752327d6e1e.
    
    Reported by Christopher Baines.
    
    * guix/scripts/system.scm (install): When TARGET/var/guix exists, delete
    it.  As a side-effect, this ensures that later on, the 'register-path'
    call invokes 'reset-timestamps' on all the copied store items.
---
 guix/scripts/system.scm | 7 +++++++
 1 file changed, 7 insertions(+)

diff --git a/guix/scripts/system.scm b/guix/scripts/system.scm
index d2be0cf..9ba9428 100644
--- a/guix/scripts/system.scm
+++ b/guix/scripts/system.scm
@@ -235,6 +235,13 @@ When INSTALL-BOOTLOADER? is true, install bootloader using 
BOOTCFG."
 the ownership of '~a' may be incorrect!~%")
                target))
 
+  ;; If a previous installation was attempted, make sure we start anew; in
+  ;; particular, we don't want to keep a store database that might not
+  ;; correspond to what we're actually putting in the store.
+  (let ((state (string-append target "/var/guix")))
+    (when (file-exists? state)
+      (delete-file-recursively state)))
+
   (chmod target #o755)
   (let ((os-dir   (derivation->output-path os-drv))
         (format   (lift format %store-monad))



reply via email to

[Prev in Thread] Current Thread [Next in Thread]