guix-commits
[Top][All Lists]
Advanced

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

06/09: profiles: Add 'generation-profile'.


From: guix-commits
Subject: 06/09: profiles: Add 'generation-profile'.
Date: Wed, 10 Apr 2019 11:17:51 -0400 (EDT)

civodul pushed a commit to branch master
in repository guix.

commit c872b952c527cb42766654d12059d5ea5224ca6c
Author: Ludovic Courtès <address@hidden>
Date:   Sat Apr 6 23:05:27 2019 +0200

    profiles: Add 'generation-profile'.
    
    * guix/profiles.scm (%profile-generation-rx): New variable.
    (generation-profile): New procedure.
---
 guix/profiles.scm | 15 +++++++++++++++
 1 file changed, 15 insertions(+)

diff --git a/guix/profiles.scm b/guix/profiles.scm
index 6564526..dfc9ba1 100644
--- a/guix/profiles.scm
+++ b/guix/profiles.scm
@@ -118,6 +118,7 @@
             profile-search-paths
 
             generation-number
+            generation-profile
             generation-numbers
             profile-generations
             relative-generation-spec->number
@@ -1552,6 +1553,20 @@ already effective."
              (compose string->number (cut match:substring <> 1)))
       0))
 
+(define %profile-generation-rx
+  ;; Regexp that matches profile generation.
+  (make-regexp "(.*)-([0-9]+)-link$"))
+
+(define (generation-profile file)
+  "If FILE is a profile generation GC root such as \"guix-profile-42-link\",
+return its corresponding profile---e.g., \"guix-profile\".  Otherwise return
+#f."
+  (match (regexp-exec %profile-generation-rx file)
+    (#f #f)
+    (m  (let ((profile (match:substring m 1)))
+          (and (file-exists? (string-append profile "/manifest"))
+               profile)))))
+
 (define (generation-numbers profile)
   "Return the sorted list of generation numbers of PROFILE, or '(0) if no
 former profiles were found."



reply via email to

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