profiles: Add gtk-icon-themes hook.
* guix/profiles.scm (gtk-icon-themes): New function. (%default-profile-hooks): Add it.master
parent
628bd9b8a7
commit
b04af0ec67
|
@ -3,6 +3,7 @@
|
||||||
;;; Copyright © 2013 Nikita Karetnikov <nikita@karetnikov.org>
|
;;; Copyright © 2013 Nikita Karetnikov <nikita@karetnikov.org>
|
||||||
;;; Copyright © 2014 Alex Kost <alezost@gmail.com>
|
;;; Copyright © 2014 Alex Kost <alezost@gmail.com>
|
||||||
;;; Copyright © 2015 Mark H Weaver <mhw@netris.org>
|
;;; Copyright © 2015 Mark H Weaver <mhw@netris.org>
|
||||||
|
;;; Copyright © 2015 Sou Bunnbu <iyzsong@gmail.com>
|
||||||
;;;
|
;;;
|
||||||
;;; This file is part of GNU Guix.
|
;;; This file is part of GNU Guix.
|
||||||
;;;
|
;;;
|
||||||
|
@ -588,12 +589,88 @@ MANIFEST. Single-file bundles are required by programs such as Git and Lynx."
|
||||||
#:modules '((guix build utils))
|
#:modules '((guix build utils))
|
||||||
#:local-build? #t))
|
#:local-build? #t))
|
||||||
|
|
||||||
|
(define (gtk-icon-themes manifest)
|
||||||
|
"Return a derivation that unions all icon themes from manifest entries and
|
||||||
|
creates the GTK+ 'icon-theme.cache' file for each theme."
|
||||||
|
;; Return as a monadic value the GTK+ package or store path referenced by the
|
||||||
|
;; manifest ENTRY, or #f if not referenced.
|
||||||
|
(define (entry-lookup-gtk+ entry)
|
||||||
|
(define (find-among-packages packages)
|
||||||
|
(find (lambda (package)
|
||||||
|
(equal? "gtk+" (package-name package)))
|
||||||
|
packages))
|
||||||
|
|
||||||
|
(define (find-among-store-items items)
|
||||||
|
(find (lambda (item)
|
||||||
|
(equal? "gtk+"
|
||||||
|
(package-name->name+version
|
||||||
|
(store-path-package-name item))))
|
||||||
|
items))
|
||||||
|
|
||||||
|
;; TODO: Factorize.
|
||||||
|
(define references*
|
||||||
|
(store-lift references))
|
||||||
|
|
||||||
|
(with-monad %store-monad
|
||||||
|
(match (manifest-entry-item entry)
|
||||||
|
((? package? package)
|
||||||
|
(match (package-transitive-inputs package)
|
||||||
|
(((labels packages . _) ...)
|
||||||
|
(return (find-among-packages packages)))))
|
||||||
|
((? string? item)
|
||||||
|
(mlet %store-monad ((refs (references* item)))
|
||||||
|
(return (find-among-store-items refs)))))))
|
||||||
|
|
||||||
|
(define (manifest-lookup-gtk+ manifest)
|
||||||
|
(anym %store-monad
|
||||||
|
entry-lookup-gtk+ (manifest-entries manifest)))
|
||||||
|
|
||||||
|
(mlet %store-monad ((gtk+ (manifest-lookup-gtk+ manifest)))
|
||||||
|
(define build
|
||||||
|
#~(begin
|
||||||
|
(use-modules (guix build utils)
|
||||||
|
(guix build union)
|
||||||
|
(srfi srfi-26)
|
||||||
|
(ice-9 ftw))
|
||||||
|
(let* ((destdir (string-append #$output "/share/icons"))
|
||||||
|
(icondirs (filter file-exists?
|
||||||
|
(map (cut string-append <> "/share/icons")
|
||||||
|
'#$(manifest-inputs manifest))))
|
||||||
|
(update-icon-cache (string-append
|
||||||
|
#+gtk+ "/bin/gtk-update-icon-cache")))
|
||||||
|
;; XXX: Should move to (guix build utils).
|
||||||
|
(define ensure-writable-directory
|
||||||
|
(@@ (guix build profiles) ensure-writable-directory))
|
||||||
|
|
||||||
|
;; Union all the icons.
|
||||||
|
(mkdir-p (string-append #$output "/share"))
|
||||||
|
(union-build destdir icondirs)
|
||||||
|
;; Update the 'icon-theme.cache' file for each icon theme.
|
||||||
|
(for-each
|
||||||
|
(lambda (theme)
|
||||||
|
(let ((dir (string-append #$output "/share/icons/" theme)))
|
||||||
|
(ensure-writable-directory dir)
|
||||||
|
(system* update-icon-cache "-t" dir)))
|
||||||
|
(scandir destdir (negate (cut member <> '("." ".."))))))))
|
||||||
|
|
||||||
|
;; Don't run the hook when there's nothing to do.
|
||||||
|
(if gtk+
|
||||||
|
(gexp->derivation "gtk-icon-themes" build
|
||||||
|
#:modules '((guix build utils)
|
||||||
|
(guix build union)
|
||||||
|
(guix build profiles)
|
||||||
|
(guix search-paths)
|
||||||
|
(guix records))
|
||||||
|
#:local-build? #t)
|
||||||
|
(return #f))))
|
||||||
|
|
||||||
(define %default-profile-hooks
|
(define %default-profile-hooks
|
||||||
;; This is the list of derivation-returning procedures that are called by
|
;; This is the list of derivation-returning procedures that are called by
|
||||||
;; default when making a non-empty profile.
|
;; default when making a non-empty profile.
|
||||||
(list info-dir-file
|
(list info-dir-file
|
||||||
ghc-package-cache-file
|
ghc-package-cache-file
|
||||||
ca-certificate-bundle))
|
ca-certificate-bundle
|
||||||
|
gtk-icon-themes))
|
||||||
|
|
||||||
(define* (profile-derivation manifest
|
(define* (profile-derivation manifest
|
||||||
#:key
|
#:key
|
||||||
|
|
Reference in New Issue