summaryrefslogtreecommitdiff
path: root/guix
diff options
context:
space:
mode:
authorLudovic Courtès <ludo@gnu.org>2021-07-02 13:49:00 -0400
committerMaxim Cournoyer <maxim.cournoyer@gmail.com>2021-07-02 16:50:10 -0400
commit20cf23e4f89ad97bd089d87b9fe2622fecd088ee (patch)
treecfa8811b68205ffbd51f9e77f8576ee15d03c2b1 /guix
parent86c9f5a5fa60b0344d2c521f1c08a912a8cce872 (diff)
build: qt-utils: Refactor the code to filter XDG_DATA_DIRS.
This partially reinstate the reverted c5fd1b0bd362f8b8578a76a26a65ba5d00d48992. * guix/build/qt-utils.scm (variables-for-wrapping)[collect-sub-dirs]: Add 'selectors' parameter and honor it. Change caller to handle selectors. Modified-by: Maxim Cournoyer <maxim.cournoyer@gmail.com>
Diffstat (limited to 'guix')
-rw-r--r--guix/build/qt-utils.scm70
1 files changed, 36 insertions, 34 deletions
diff --git a/guix/build/qt-utils.scm b/guix/build/qt-utils.scm
index 8e6db10ca1..9f09623ddc 100644
--- a/guix/build/qt-utils.scm
+++ b/guix/build/qt-utils.scm
@@ -2,6 +2,7 @@
;;; Copyright © 2016 David Craven <david@craven.ch>
;;; Copyright © 2019, 2020, 2021 Hartmut Goebel <h.goebel@crazy-compilers.com>
;;; Copyright © 2020 Jakub Kądziołka <kuba@kadziolka.net>
+;;; Copyright © 2021 Ludovic Courtès <ludo@gnu.org>
;;;
;;; This file is part of GNU Guix.
;;;
@@ -36,40 +37,41 @@
;; contain any of the standard subdirectories.
(define (variables-for-wrapping base-directories output-directory)
- (define (collect-sub-dirs base-directories subdirectory-spec)
- (filter-map
- (lambda (dir)
- (match
- subdirectory-spec
- ((subdir)
- (and (directory-exists? (string-append dir subdir))
- (string-append dir (car subdirectory-spec))))
- ((subdir children)
- (and
- (or
- (and (string=? dir output-directory)
- (directory-exists? (string-append dir subdir)))
- (or-map
- (lambda (kid) (directory-exists? (string-append dir subdir kid)))
- children))
- (string-append dir subdir)))))
- base-directories))
-
- (filter
- (lambda (var-to-wrap) (not (null? (last var-to-wrap))))
- (map
- (match-lambda
- ((var kind . subdir-spec)
- `(,var ,kind ,(collect-sub-dirs base-directories subdir-spec))))
- (list
- ;; these shall match the search-path-specification for Qt and KDE
- ;; libraries
- '("XDG_DATA_DIRS" suffix "/share" ("/applications" "/fonts"
- "/icons" "/mime"))
- '("XDG_CONFIG_DIRS" suffix "/etc/xdg")
- '("QT_PLUGIN_PATH" prefix "/lib/qt5/plugins")
- '("QML2_IMPORT_PATH" prefix "/lib/qt5/qml")))))
-
+ (define (collect-sub-dirs base-directories subdirectory selectors)
+ ;; Append SUBDIRECTORY and each of BASE-DIRECTORIES, and return the subset
+ ;; that exists and has at least one of the SELECTORS sub-directories,
+ ;; unless SELECTORS is the empty list.
+ (filter-map (lambda (dir)
+ (let ((directory (string-append dir subdirectory)))
+ (and (directory-exists? directory)
+ (or (null? selectors)
+ (any (lambda (selector)
+ (directory-exists?
+ (string-append directory selector)))
+ selectors))
+ directory)))
+ base-directories))
+
+ (filter-map
+ (match-lambda
+ ((variable type directory selectors ...)
+ (match (collect-sub-dirs base-directories directory selectors)
+ (()
+ #f)
+ (directories
+ `(,variable ,type ,directories)))))
+ ;; These shall match the search-path-specification for Qt and KDE
+ ;; libraries.
+ (list '("XDG_DATA_DIRS" suffix "/share"
+ ;; These are "selectors": consider /share if and only if at least
+ ;; one of these sub-directories exist. This avoids adding
+ ;; irrelevant packages to XDG_DATA_DIRS just because they have a
+ ;; /share sub-directory.
+ "/applications" "/cursors" "/fonts" "/icons" "/glib-2.0/schemas"
+ "/mime" "/sounds" "/themes" "/wallpapers")
+ '("XDG_CONFIG_DIRS" suffix "/etc/xdg")
+ '("QT_PLUGIN_PATH" prefix "/lib/qt5/plugins")
+ '("QML2_IMPORT_PATH" prefix "/lib/qt5/qml"))))
(define* (wrap-qt-program* program #:key inputs output-dir
qt-wrap-excluded-inputs)