From 3df5acf332fd7b5c21c09961eaa5353c1bd08c60 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ludovic=20Court=C3=A8s?= Date: Fri, 6 Feb 2015 17:39:10 +0100 Subject: [PATCH] pull: Always install the ~/.config/guix/latest symlink. Before that, if two users on the same machine ran 'guix pull', the second one would have the "Guix already up to date" message and their ~/.config/guix/latest link would be left unchanged---effectively preventing them from updating. * guix/scripts/pull.scm (build-and-install): Install the 'latest' symlink regardless of whether TO-DO? is true or false. --- guix/scripts/pull.scm | 30 +++++++++++++++++------------- 1 file changed, 17 insertions(+), 13 deletions(-) diff --git a/guix/scripts/pull.scm b/guix/scripts/pull.scm index 16805bad3f..e6ed8d23eb 100644 --- a/guix/scripts/pull.scm +++ b/guix/scripts/pull.scm @@ -1,5 +1,5 @@ ;;; GNU Guix --- Functional package management for GNU -;;; Copyright © 2013, 2014 Ludovic Courtès +;;; Copyright © 2013, 2014, 2015 Ludovic Courtès ;;; ;;; This file is part of GNU Guix. ;;; @@ -188,22 +188,26 @@ (define* (build-and-install tarball config-dir (mlet* %store-monad ((source (build-from-source tarball #:verbose? verbose?)) (source-dir -> (derivation->output-path source)) - (to-do? (what-to-build (list source)))) - (if to-do? - (mlet* %store-monad ((built? (built-derivations (list source)))) - (if built? - (mlet* %store-monad - ((latest -> (string-append config-dir "/latest")) - (done (indirect-root-added latest))) + (to-do? (what-to-build (list source))) + (built? (built-derivations (list source)))) + ;; Always update the 'latest' symlink, regardless of whether SOURCE was + ;; already built or not. + (if built? + (mlet* %store-monad + ((latest -> (string-append config-dir "/latest")) + (done (indirect-root-added latest))) + (if (and (file-exists? latest) + (string=? (readlink latest) source-dir)) + (begin + (display (_ "Guix already up to date\n")) + (return #t)) + (begin (switch-symlinks latest source-dir) (format #t (_ "updated ~a successfully deployed under `~a'~%") %guix-package-name latest) - (return #t)) - (leave (_ "failed to update Guix, check the build log~%")))) - (begin - (display (_ "Guix already up to date\n")) - (return #t))))) + (return #t)))) + (leave (_ "failed to update Guix, check the build log~%"))))) (define (guix-pull . args) (define (parse-options)