123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115 |
- ;;; GNU Guix --- Functional package management for GNU
- ;;; Copyright © 2020 Mathieu Othacehe <m.othacehe@gmail.com>
- ;;;
- ;;; 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 image)
- #:use-module (guix records)
- #:export (partition
- partition?
- partition-device
- partition-size
- partition-offset
- partition-file-system
- partition-file-system-options
- partition-label
- partition-uuid
- partition-flags
- partition-initializer
- image
- image?
- image-name
- image-format
- image-target
- image-size
- image-operating-system
- image-partitions
- image-compression?
- image-volatile-root?
- image-substitutable?
- image-type
- image-type?
- image-type-name
- image-type-constructor
- os->image))
- ;;;
- ;;; Partition record.
- ;;;
- (define-record-type* <partition> partition make-partition
- partition?
- (device partition-device (default #f))
- (size partition-size)
- (offset partition-offset (default 0))
- (file-system partition-file-system (default "ext4"))
- (file-system-options partition-file-system-options
- (default '()))
- (label partition-label (default #f))
- (uuid partition-uuid (default #f))
- (flags partition-flags (default '()))
- (initializer partition-initializer (default #f)))
- ;;;
- ;;; Image record.
- ;;;
- (define-record-type* <image>
- image make-image
- image?
- (name image-name ;symbol
- (default #f))
- (format image-format) ;symbol
- (target image-target
- (default #f))
- (size image-size ;size in bytes as integer
- (default 'guess))
- (operating-system image-operating-system ;<operating-system>
- (default #f))
- (partitions image-partitions ;list of <partition>
- (default '()))
- (compression? image-compression? ;boolean
- (default #t))
- (volatile-root? image-volatile-root? ;boolean
- (default #t))
- (substitutable? image-substitutable? ;boolean
- (default #t)))
- ;;;
- ;;; Image type.
- ;;;
- (define-record-type* <image-type>
- image-type make-image-type
- image-type?
- (name image-type-name) ;symbol
- (constructor image-type-constructor)) ;<operating-system> -> <image>
- ;;;
- ;;; Image creation.
- ;;;
- (define* (os->image os #:key type)
- (let ((constructor (image-type-constructor type)))
- (constructor os)))
|