mirror of
https://git.savannah.gnu.org/git/guix.git
synced 2026-04-06 21:20:33 +02:00
profiles: Use ‘with-imported-modules’.
* guix/profiles.scm (fonts-dir-file)[build]: Wrap in ‘with-imported-modules’. Remove #:modules argument to ‘gexp->derivation’. Change-Id: I29d71d0ff61cf8b81796ad412f2f95b111f028a7 Signed-off-by: Ludovic Courtès <ludo@gnu.org>
This commit is contained in:
@@ -1,5 +1,5 @@
|
|||||||
;;; GNU Guix --- Functional package management for GNU
|
;;; GNU Guix --- Functional package management for GNU
|
||||||
;;; Copyright © 2013-2025 Ludovic Courtès <ludo@gnu.org>
|
;;; Copyright © 2013-2026 Ludovic Courtès <ludo@gnu.org>
|
||||||
;;; Copyright © 2013 Nikita Karetnikov <nikita@karetnikov.org>
|
;;; Copyright © 2013 Nikita Karetnikov <nikita@karetnikov.org>
|
||||||
;;; Copyright © 2014, 2016 Alex Kost <alezost@gmail.com>
|
;;; Copyright © 2014, 2016 Alex Kost <alezost@gmail.com>
|
||||||
;;; Copyright © 2015 Mark H Weaver <mhw@netris.org>
|
;;; Copyright © 2015 Mark H Weaver <mhw@netris.org>
|
||||||
@@ -1676,60 +1676,62 @@ files for the fonts of the @var{manifest} entries."
|
|||||||
(module-ref (resolve-interface '(gnu packages xorg)) 'mkfontdir))
|
(module-ref (resolve-interface '(gnu packages xorg)) 'mkfontdir))
|
||||||
|
|
||||||
(define build
|
(define build
|
||||||
#~(begin
|
(with-imported-modules '((guix build utils)
|
||||||
(use-modules (srfi srfi-26)
|
(guix build union))
|
||||||
(guix build utils)
|
#~(begin
|
||||||
(guix build union))
|
(use-modules (srfi srfi-26)
|
||||||
(let ((fonts-dirs (filter file-exists?
|
(guix build utils)
|
||||||
(map (cut string-append <>
|
(guix build union))
|
||||||
"/share/fonts")
|
|
||||||
'#$(manifest-inputs manifest)))))
|
(let ((fonts-dirs (filter file-exists?
|
||||||
(mkdir #$output)
|
(map (cut string-append <>
|
||||||
(if (null? fonts-dirs)
|
"/share/fonts")
|
||||||
(exit #t)
|
'#$(manifest-inputs manifest)))))
|
||||||
(let* ((share-dir (string-append #$output "/share"))
|
(mkdir #$output)
|
||||||
(fonts-dir (string-append share-dir "/fonts"))
|
(if (null? fonts-dirs)
|
||||||
(mkfontscale (string-append #+mkfontscale
|
(exit #t)
|
||||||
"/bin/mkfontscale"))
|
(let* ((share-dir (string-append #$output "/share"))
|
||||||
(mkfontdir (string-append #+mkfontdir
|
(fonts-dir (string-append share-dir "/fonts"))
|
||||||
"/bin/mkfontdir"))
|
(mkfontscale (string-append #+mkfontscale
|
||||||
(empty-file? (lambda (filename)
|
"/bin/mkfontscale"))
|
||||||
(call-with-ascii-input-file filename
|
(mkfontdir (string-append #+mkfontdir
|
||||||
(lambda (p)
|
"/bin/mkfontdir"))
|
||||||
(eqv? #\0 (read-char p))))))
|
(empty-file? (lambda (filename)
|
||||||
(fonts-dir-file "fonts.dir")
|
(call-with-ascii-input-file filename
|
||||||
(fonts-scale-file "fonts.scale"))
|
(lambda (p)
|
||||||
(mkdir-p share-dir)
|
(eqv? #\0 (read-char p))))))
|
||||||
;; Create all sub-directories, because we may create fonts.dir
|
(fonts-dir-file "fonts.dir")
|
||||||
;; and fonts.scale files in the sub-directories.
|
(fonts-scale-file "fonts.scale"))
|
||||||
(union-build fonts-dir fonts-dirs
|
(mkdir-p share-dir)
|
||||||
#:log-port (%make-void-port "w")
|
;; Create all sub-directories, because we may create fonts.dir
|
||||||
#:create-all-directories? #t)
|
;; and fonts.scale files in the sub-directories.
|
||||||
(let ((directories (find-files fonts-dir
|
(union-build fonts-dir fonts-dirs
|
||||||
(lambda (file stat)
|
#:log-port (%make-void-port "w")
|
||||||
(eq? 'directory (stat:type stat)))
|
#:create-all-directories? #t)
|
||||||
#:directories? #t)))
|
(let ((directories
|
||||||
(for-each (lambda (dir)
|
(find-files fonts-dir
|
||||||
(with-directory-excursion dir
|
(lambda (file stat)
|
||||||
(when (file-exists? fonts-scale-file)
|
(eq? 'directory (stat:type stat)))
|
||||||
(delete-file fonts-scale-file))
|
#:directories? #t)))
|
||||||
(when (file-exists? fonts-dir-file)
|
(for-each (lambda (dir)
|
||||||
(delete-file fonts-dir-file))
|
(with-directory-excursion dir
|
||||||
(unless (and (zero? (system* mkfontscale))
|
(when (file-exists? fonts-scale-file)
|
||||||
(zero? (system* mkfontdir)))
|
(delete-file fonts-scale-file))
|
||||||
(exit #f))
|
(when (file-exists? fonts-dir-file)
|
||||||
(when (and (file-exists? fonts-scale-file)
|
(delete-file fonts-dir-file))
|
||||||
(empty-file? fonts-scale-file))
|
(unless (and (zero? (system* mkfontscale))
|
||||||
(delete-file fonts-scale-file))
|
(zero? (system* mkfontdir)))
|
||||||
(when (and (file-exists? fonts-dir-file)
|
(exit #f))
|
||||||
(empty-file? fonts-dir-file))
|
(when (and (file-exists? fonts-scale-file)
|
||||||
(delete-file fonts-dir-file))))
|
(empty-file? fonts-scale-file))
|
||||||
directories)))))))
|
(delete-file fonts-scale-file))
|
||||||
|
(when (and (file-exists? fonts-dir-file)
|
||||||
|
(empty-file? fonts-dir-file))
|
||||||
|
(delete-file fonts-dir-file))))
|
||||||
|
directories))))))))
|
||||||
|
|
||||||
(gexp->derivation "fonts-dir" build
|
(gexp->derivation "fonts-dir" build
|
||||||
#:system system
|
#:system system
|
||||||
#:modules '((guix build utils)
|
|
||||||
(guix build union))
|
|
||||||
#:local-build? #t
|
#:local-build? #t
|
||||||
#:substitutable? #f
|
#:substitutable? #f
|
||||||
#:properties
|
#:properties
|
||||||
|
|||||||
Reference in New Issue
Block a user