mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2024-12-26 06:18:07 -05:00
8da7f4a110
* gnu/home/services/guix.scm (extend-channel-list): Add function. (home-channels-service-type)[extend]: Use extend-channel-list. Change-Id: I587207b86216f075a54b6ed0b8fa998896bbed74 Signed-off-by: Ludovic Courtès <ludo@gnu.org>
51 lines
1.9 KiB
Scheme
51 lines
1.9 KiB
Scheme
;;; GNU Guix --- Functional package management for GNU
|
|
;;; Copyright © 2022 Reily Siegel <mail@reilysiegel.com>
|
|
;;; Copyright © 2024 Nicolas Graves <ngraves@ngraves.fr>
|
|
;;;
|
|
;;; This file is part of GNU Guix.
|
|
;;;
|
|
;;; GNU Guix is free software; you can redistribute it and/or modify it
|
|
;;; under the terms of the GNU General Public License as published by
|
|
;;; the Free Software Foundation; either version 3 of the License, or (at
|
|
;;; your option) any later version.
|
|
;;;
|
|
;;; GNU Guix is distributed in the hope that it will be useful, but
|
|
;;; WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
;;; GNU General Public License for more details.
|
|
;;;
|
|
;;; You should have received a copy of the GNU General Public License
|
|
;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
(define-module (gnu home services guix)
|
|
#:use-module (gnu home services)
|
|
#:use-module (guix channels)
|
|
#:use-module (guix gexp)
|
|
#:use-module (ice-9 pretty-print)
|
|
#:use-module (srfi srfi-1)
|
|
#:export (home-channels-service-type))
|
|
|
|
(define (extend-channel-list initial new)
|
|
(delete-duplicates
|
|
(append initial new)
|
|
(lambda (channel1 channel2)
|
|
(eq? (channel-name channel1) (channel-name channel2)))))
|
|
|
|
(define (channels-xdg-files channels)
|
|
`(("guix/channels.scm"
|
|
,(plain-file
|
|
"channels.scm"
|
|
(call-with-output-string
|
|
(lambda (port)
|
|
(pretty-print (cons 'list (map channel->code channels)) port)))))))
|
|
|
|
(define home-channels-service-type
|
|
(service-type
|
|
(name 'home-channels)
|
|
(default-value %default-channels)
|
|
(compose concatenate)
|
|
(extend extend-channel-list)
|
|
(extensions
|
|
(list (service-extension home-xdg-configuration-files-service-type
|
|
channels-xdg-files)))
|
|
(description "Manages the per-user Guix channels specification.")))
|