services: static-networking: 'eval-when' for code used at expansion-time.

Reported by bjc on #guix.

* gnu/services/base.scm (valid-name, cidr->netmask): Wrap in 'eval-when'
since they are used by "compile-time procedures" (macros).
This commit is contained in:
Ludovic Courtès 2023-03-20 14:44:19 +01:00
parent 4f63b4b86d
commit 0143e3f291
No known key found for this signature in database
GPG key ID: 090B11993D9AEBB5

View file

@ -1,5 +1,5 @@
;;; GNU Guix --- Functional package management for GNU ;;; GNU Guix --- Functional package management for GNU
;;; Copyright © 2013-2022 Ludovic Courtès <ludo@gnu.org> ;;; Copyright © 2013-2023 Ludovic Courtès <ludo@gnu.org>
;;; Copyright © 2015, 2016 Alex Kost <alezost@gmail.com> ;;; Copyright © 2015, 2016 Alex Kost <alezost@gmail.com>
;;; Copyright © 2015, 2016, 2020 Mark H Weaver <mhw@netris.org> ;;; Copyright © 2015, 2016, 2020 Mark H Weaver <mhw@netris.org>
;;; Copyright © 2015 Sou Bunnbu <iyzsong@gmail.com> ;;; Copyright © 2015 Sou Bunnbu <iyzsong@gmail.com>
@ -703,9 +703,10 @@ (define-deprecated (rngd-service #:key (rng-tools rng-tools)
;;; /etc/hosts ;;; /etc/hosts
;;; ;;;
(define (valid-name? name) (eval-when (expand load eval)
"Return true if @var{name} is likely to be a valid host name." (define (valid-name? name)
(false-if-exception (not (string-any char-set:whitespace name)))) "Return true if @var{name} is likely to be a valid host name."
(false-if-exception (not (string-any char-set:whitespace name)))))
(define-compile-time-procedure (assert-valid-name (name valid-name?)) (define-compile-time-procedure (assert-valid-name (name valid-name?))
"Ensure @var{name} is likely to be a valid host name." "Ensure @var{name} is likely to be a valid host name."
@ -2664,16 +2665,17 @@ (define-record-type* <network-route>
ipv6-address?)))) ipv6-address?))))
(gateway network-route-gateway (default #f))) (gateway network-route-gateway (default #f)))
(define* (cidr->netmask str #:optional (family AF_INET)) (eval-when (expand load eval)
"Given @var{str}, a string in CIDR notation (e.g., \"1.2.3.4/24\"), return (define* (cidr->netmask str #:optional (family AF_INET))
"Given @var{str}, a string in CIDR notation (e.g., \"1.2.3.4/24\"), return
the netmask as a string like \"255.255.255.0\"." the netmask as a string like \"255.255.255.0\"."
(match (string-split str #\/) (match (string-split str #\/)
((ip (= string->number bits)) ((ip (= string->number bits))
(let ((mask (ash (- (expt 2 bits) 1) (let ((mask (ash (- (expt 2 bits) 1)
(- (if (= family AF_INET6) 128 32) (- (if (= family AF_INET6) 128 32)
bits)))) bits))))
(inet-ntop family mask))) (inet-ntop family mask)))
(_ #f))) (_ #f))))
(define (cidr->ip str) (define (cidr->ip str)
"Strip the netmask bit of @var{str}, a CIDR-notation IP/netmask address." "Strip the netmask bit of @var{str}, a CIDR-notation IP/netmask address."