GNU bug report logs -
#67598
[PATCH] gnu: services: guix: Allow gexps evaluating to a list of build-machines
Previous Next
Reported by: Saku Laesvuori <saku <at> laesvuori.fi>
Date: Sun, 3 Dec 2023 09:34:02 UTC
Severity: normal
Tags: patch
Done: Ludovic Courtès <ludo <at> gnu.org>
Bug is archived. No further changes may be made.
Full log
View this message in rfc822 format
[Message part 1 (text/plain, inline)]
Your bug report
#67598: [PATCH] gnu: services: guix: Allow gexps evaluating to a list of build-machines
which was filed against the guix-patches package, has been closed.
The explanation is attached below, along with your original report.
If you require more details, please reply to 67598 <at> debbugs.gnu.org.
--
67598: https://debbugs.gnu.org/cgi/bugreport.cgi?bug=67598
GNU Bug Tracking System
Contact help-debbugs <at> gnu.org with problems
[Message part 2 (message/rfc822, inline)]
[Message part 3 (text/plain, inline)]
Hi,
Saku Laesvuori <saku <at> laesvuori.fi> skribis:
> * gnu/services/base.scm (guix-machines-files-installation): Handle
> machines being a mixed list of build-machines and lists of
> build-machines.
> * doc/guix.texi: Document it.
>
> Change-Id: Ie404562ca0b564413233c3a624046da831893dc3
Applied with the small change below (hadn’t realized earlier that we
could use ‘append-map’). Thanks!
Ludo’.
[Message part 4 (text/x-patch, inline)]
diff --git a/gnu/services/base.scm b/gnu/services/base.scm
index 3a4d8e789c..6539bfd6ce 100644
--- a/gnu/services/base.scm
+++ b/gnu/services/base.scm
@@ -1768,12 +1768,12 @@ (define (guix-machines-files-installation machines)
;; Installed the declared machines file.
(symlink #+(scheme-file "machines.scm"
- #~((@ (srfi srfi-1) concatenate)
- (map (lambda (entry)
- (if (build-machine? entry)
- (list entry)
- entry))
- #$machines)))
+ #~((@ (srfi srfi-1) append-map)
+ (lambda (entry)
+ (if (build-machine? entry)
+ (list entry)
+ entry))
+ #$machines))
machines-file))))
(define-record-type* <guix-configuration>
[Message part 5 (message/rfc822, inline)]
* gnu/services/base.scm (guix-machines-files-installation): Handle
machines being a mixed list of build-machines and lists of
build-machines.
* doc/guix.texi: Document it.
Change-Id: Ie404562ca0b564413233c3a624046da831893dc3
---
This enables doing things like the DNS-SD example mentioned in '2.4.2
Using the Offload Facility' directly from the operating-system
declaration.
doc/guix.texi | 9 ++++++---
gnu/services/base.scm | 8 +++++++-
2 files changed, 13 insertions(+), 4 deletions(-)
diff --git a/doc/guix.texi b/doc/guix.texi
index 1fd2e21608..3e599742c3 100644
--- a/doc/guix.texi
+++ b/doc/guix.texi
@@ -19316,7 +19316,8 @@ Base Services
@anchor{guix-configuration-build-machines}
@item @code{build-machines} (default: @code{#f})
This field must be either @code{#f} or a list of gexps evaluating to a
-@code{build-machine} record (@pxref{Daemon Offload Setup}).
+@code{build-machine} record or to a list of @code{build-machine} records
+(@pxref{Daemon Offload Setup}).
When it is @code{#f}, the @file{/etc/guix/machines.scm} file is left
untouched. Otherwise, the list of of gexps is written to
@@ -19329,7 +19330,8 @@ Base Services
(guix-configuration
(build-machines
(list #~(build-machine (name "foo.example.org") @dots{})
- #~(build-machine (name "bar.example.org") @dots{}))))
+ #~(list (build-machine (name "bar.example.org") @dots{})
+ (build-machine (name "foobaz.example.org") @dots{})))))
@end lisp
Additional build machines may be added @i{via} the @code{guix-extension}
@@ -19385,7 +19387,8 @@ Base Services
A list of strings where each element is a substitute URL.
@item @code{build-machines} (default: @code{'()})
-A list of gexps that evaluate to @code{build-machine} records
+A list of gexps that evaluate to @code{build-machine} records or to a list of
+@code{build-machine} records.
(@pxref{Daemon Offload Setup}).
Using this field, a service may add new build machines to receive builds
diff --git a/gnu/services/base.scm b/gnu/services/base.scm
index 82c6940780..beb710f95c 100644
--- a/gnu/services/base.scm
+++ b/gnu/services/base.scm
@@ -1765,7 +1765,13 @@ (define (guix-machines-files-installation machines)
(mkdir-p (dirname machines-file)))
;; Installed the declared machines file.
- (symlink #+(scheme-file "machines.scm" machines)
+ (symlink #+(scheme-file "machines.scm"
+ `(apply append
+ (map (lambda (entry)
+ (if (list? entry)
+ entry
+ (list entry)))
+ ,machines)))
machines-file))))
(define-record-type* <guix-configuration>
base-commit: cd46757c1a0f886848fbb6828c028dd2a2532767
--
2.41.0
This bug report was last modified 1 year and 156 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.