gnu: Add rust-number-prefix-0.4.
[jackhill/guix/guix.git] / gnu / image.scm
CommitLineData
f19cf27c 1;;; GNU Guix --- Functional package management for GNU
bce7a28a 2;;; Copyright © 2020, 2022 Mathieu Othacehe <othacehe@gnu.org>
f19cf27c
MO
3;;;
4;;; This file is part of GNU Guix.
5;;;
6;;; GNU Guix is free software; you can redistribute it and/or modify it
7;;; under the terms of the GNU General Public License as published by
8;;; the Free Software Foundation; either version 3 of the License, or (at
9;;; your option) any later version.
10;;;
11;;; GNU Guix is distributed in the hope that it will be useful, but
12;;; WITHOUT ANY WARRANTY; without even the implied warranty of
13;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14;;; GNU General Public License for more details.
15;;;
16;;; You should have received a copy of the GNU General Public License
17;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
18
19(define-module (gnu image)
dab819d5 20 #:use-module (guix platform)
f19cf27c 21 #:use-module (guix records)
0dab106a
LC
22 #:use-module (guix diagnostics)
23 #:use-module (guix i18n)
bce7a28a 24 #:use-module (srfi srfi-1)
0dab106a
LC
25 #:use-module (srfi srfi-34)
26 #:use-module (srfi srfi-35)
f19cf27c
MO
27 #:export (partition
28 partition?
29 partition-device
30 partition-size
1b4fa785 31 partition-offset
f19cf27c 32 partition-file-system
bd3716f6 33 partition-file-system-options
f19cf27c
MO
34 partition-label
35 partition-uuid
36 partition-flags
37 partition-initializer
38
39 image
4cce7610 40 image?
f19cf27c
MO
41 image-name
42 image-format
d5073fd1 43 image-platform
f19cf27c
MO
44 image-size
45 image-operating-system
096a2bf8 46 image-partition-table-type
f19cf27c
MO
47 image-partitions
48 image-compression?
49 image-volatile-root?
594e9428 50 image-shared-store?
dcc843a7 51 image-shared-network?
99d036ce
MO
52 image-substitutable?
53
54 image-type
55 image-type?
56 image-type-name
57 image-type-constructor
58
d5073fd1
MO
59 os->image
60 os+platform->image))
f19cf27c
MO
61
62\f
bce7a28a
MO
63;;;
64;;; Sanitizers.
65;;;
66
16a6cbe9
MO
67;; Image and partition sizes can be either be a size in bytes or the 'guess
68;; symbol denoting that the size should be estimated by Guix, according to the
69;; image content.
bce7a28a
MO
70(define-with-syntax-properties (validate-size (value properties))
71 (unless (and value
72 (or (eq? value 'guess) (integer? value)))
73 (raise
74 (make-compound-condition
75 (condition
76 (&error-location
77 (location (source-properties->location properties))))
78 (formatted-message
79 (G_ "size (~a) can only be 'guess or a numeric expression ~%")
80 value 'field))))
81 value)
82
83\f
f19cf27c
MO
84;;;
85;;; Partition record.
86;;;
87
16a6cbe9 88;; The partition offset should be a bytes count as an integer.
bce7a28a
MO
89(define-with-syntax-properties (validate-partition-offset (value properties))
90 (unless (and value (integer? value))
91 (raise
92 (make-compound-condition
93 (condition
94 (&error-location
95 (location (source-properties->location properties))))
96 (formatted-message
97 (G_ "the partition offset (~a) can only be a \
98numeric expression ~%") value 'field))))
99 value)
100
16a6cbe9 101;; The supported partition flags.
bce7a28a
MO
102(define-with-syntax-properties (validate-partition-flags (value properties))
103 (let ((bad-flags (lset-difference eq? value '(boot esp))))
104 (unless (and (list? value) (null? bad-flags))
105 (raise
106 (make-compound-condition
107 (condition
108 (&error-location
109 (location (source-properties->location properties))))
110 (formatted-message
111 (G_ "unsupported partition flag(s): ~a ~%") bad-flags)))))
112 value)
113
f19cf27c
MO
114(define-record-type* <partition> partition make-partition
115 partition?
bce7a28a 116 (size partition-size ;size in bytes as integer or 'guess
a1fb85a5 117 (default 'guess)
bce7a28a
MO
118 (sanitize validate-size))
119 (offset partition-offset
120 (default 0) ;offset in bytes as integer
121 (sanitize validate-partition-offset))
122 (file-system partition-file-system
123 (default "ext4")) ;string
bd3716f6 124 (file-system-options partition-file-system-options
bce7a28a
MO
125 (default '())) ;list of strings
126 (label partition-label) ;string
127 (uuid partition-uuid
0edb79b2 128 (default #false)) ;<uuid>
bce7a28a
MO
129 (flags partition-flags
130 (default '()) ;list of symbols
131 (sanitize validate-partition-flags))
132 (initializer partition-initializer
0edb79b2 133 (default #false))) ;gexp | #false
f19cf27c
MO
134
135\f
136;;;
137;;; Image record.
138;;;
139
0dab106a
LC
140(define-syntax-rule (define-set-sanitizer name field set)
141 "Define NAME as a procedure or macro that raises an error if passed a value
142that is not in SET, mentioning FIELD in the error message."
143 (define-with-syntax-properties (name (value properties))
144 (unless (memq value 'set)
145 (raise
146 (make-compound-condition
147 (condition
148 (&error-location
149 (location (source-properties->location properties))))
150 (formatted-message (G_ "~s: invalid '~a' value") value 'field))))
151 value))
152
16a6cbe9 153;; The supported image formats.
0dab106a
LC
154(define-set-sanitizer validate-image-format format
155 (disk-image compressed-qcow2 docker iso9660))
16a6cbe9
MO
156
157;; The supported partition table types.
0dab106a
LC
158(define-set-sanitizer validate-partition-table-type partition-table-type
159 (mbr gpt))
160
f19cf27c
MO
161(define-record-type* <image>
162 image make-image
163 image?
b904b59c 164 (name image-name ;symbol
0edb79b2 165 (default #false))
0dab106a
LC
166 (format image-format ;symbol
167 (sanitize validate-image-format))
d5073fd1 168 (platform image-platform ;<platform>
0edb79b2 169 (default #false))
f19cf27c 170 (size image-size ;size in bytes as integer
bce7a28a
MO
171 (default 'guess)
172 (sanitize validate-size))
f19cf27c
MO
173 (operating-system image-operating-system ;<operating-system>
174 (default #f))
096a2bf8 175 (partition-table-type image-partition-table-type ; 'mbr or 'gpt
0dab106a
LC
176 (default 'mbr)
177 (sanitize validate-partition-table-type))
f19cf27c
MO
178 (partitions image-partitions ;list of <partition>
179 (default '()))
180 (compression? image-compression? ;boolean
0edb79b2 181 (default #true))
f19cf27c 182 (volatile-root? image-volatile-root? ;boolean
0edb79b2 183 (default #true))
594e9428 184 (shared-store? image-shared-store? ;boolean
0edb79b2 185 (default #false))
dcc843a7 186 (shared-network? image-shared-network? ;boolean
0edb79b2 187 (default #false))
f19cf27c 188 (substitutable? image-substitutable? ;boolean
0edb79b2 189 (default #true)))
99d036ce
MO
190
191\f
192;;;
193;;; Image type.
194;;;
195
16a6cbe9
MO
196;; The role of this record is to provide a constructor that is able to turn an
197;; <operating-system> record into an <image> record. Some basic <image-type>
198;; records are defined in the (gnu system image) module. They are able to
199;; turn an <operating-system> record into an EFI or an ISO 9660 bootable
200;; image, a Docker image or even a QCOW2 image.
201;;
202;; Other <image-type> records are defined in the (gnu system images ...)
203;; modules. They are dedicated to specific machines such as Novena and Pine64
204;; SoC boards that require specific images.
205;;
206;; All the available <image-type> records are collected by the 'image-modules'
207;; procedure. This allows the "guix system image" command to turn a given
208;; <operating-system> record into an image, thanks to the specified
209;; <image-type>. In that case, the <image-type> look up is done using the
210;; name field of the <image-type> record.
211
99d036ce
MO
212(define-record-type* <image-type>
213 image-type make-image-type
214 image-type?
215 (name image-type-name) ;symbol
216 (constructor image-type-constructor)) ;<operating-system> -> <image>
217
218\f
219;;;
220;;; Image creation.
221;;;
222
223(define* (os->image os #:key type)
16a6cbe9
MO
224 "Use the image constructor from TYPE, an <image-type> record to turn the
225given OS, an <operating-system> record into an image and return it."
99d036ce
MO
226 (let ((constructor (image-type-constructor type)))
227 (constructor os)))
d5073fd1
MO
228
229(define* (os+platform->image os platform #:key type)
16a6cbe9
MO
230 "Use the image constructor from TYPE, an <image-type> record to turn the
231given OS, an <operating-system> record into an image targeting PLATFORM, a
232<platform> record and return it."
d5073fd1
MO
233 (image
234 (inherit (os->image os #:type type))
235 (platform platform)))