mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-12 06:06:53 -05:00
home: Add 'home-generation-base'.
* gnu/home.scm (%profile-generation-rx): New variable. (home-generation-base): New procedure.
This commit is contained in:
parent
ff94f9dfde
commit
5df8f7802e
1 changed files with 24 additions and 2 deletions
26
gnu/home.scm
26
gnu/home.scm
|
@ -1,5 +1,6 @@
|
||||||
;;; GNU Guix --- Functional package management for GNU
|
;;; GNU Guix --- Functional package management for GNU
|
||||||
;;; Copyright © 2021 Andrew Tropin <andrew@trop.in>
|
;;; Copyright © 2021 Andrew Tropin <andrew@trop.in>
|
||||||
|
;;; Copyright © 2022 Ludovic Courtès <ludo@gnu.org>
|
||||||
;;;
|
;;;
|
||||||
;;; This file is part of GNU Guix.
|
;;; This file is part of GNU Guix.
|
||||||
;;;
|
;;;
|
||||||
|
@ -27,7 +28,8 @@ (define-module (gnu home)
|
||||||
#:use-module (guix diagnostics)
|
#:use-module (guix diagnostics)
|
||||||
#:use-module (guix gexp)
|
#:use-module (guix gexp)
|
||||||
#:use-module (guix store)
|
#:use-module (guix store)
|
||||||
|
#:use-module (ice-9 match)
|
||||||
|
#:use-module (ice-9 regex)
|
||||||
#:export (home-environment
|
#:export (home-environment
|
||||||
home-environment?
|
home-environment?
|
||||||
this-home-environment
|
this-home-environment
|
||||||
|
@ -38,7 +40,9 @@ (define-module (gnu home)
|
||||||
home-environment-services
|
home-environment-services
|
||||||
home-environment-location
|
home-environment-location
|
||||||
|
|
||||||
home-environment-with-provenance))
|
home-environment-with-provenance
|
||||||
|
|
||||||
|
home-generation-base))
|
||||||
|
|
||||||
;;; Comment:
|
;;; Comment:
|
||||||
;;;
|
;;;
|
||||||
|
@ -114,3 +118,21 @@ (define-gexp-compiler (home-environment-compiler (he <home-environment>)
|
||||||
(run-with-store store (home-environment-derivation he)
|
(run-with-store store (home-environment-derivation he)
|
||||||
#:system system
|
#:system system
|
||||||
#:target target)))))
|
#:target target)))))
|
||||||
|
|
||||||
|
(define %profile-generation-rx
|
||||||
|
;; Regexp that matches profile generation.
|
||||||
|
(make-regexp "(.*)-([0-9]+)-link$"))
|
||||||
|
|
||||||
|
(define (home-generation-base file)
|
||||||
|
"If FILE is a Home generation GC root such as \"guix-home-42-link\",
|
||||||
|
return its corresponding base---e.g., \"guix-home\". Otherwise return #f.
|
||||||
|
|
||||||
|
This is similar to the 'generation-profile' procedure but applied to Home
|
||||||
|
generations."
|
||||||
|
(match (regexp-exec %profile-generation-rx file)
|
||||||
|
(#f #f)
|
||||||
|
(m (let ((profile (match:substring m 1)))
|
||||||
|
;; Distinguish from a "real" profile and from a system generation.
|
||||||
|
(and (file-exists? (string-append profile "/on-first-login"))
|
||||||
|
(file-exists? (string-append profile "/profile/manifest"))
|
||||||
|
profile)))))
|
||||||
|
|
Loading…
Reference in a new issue