From 944ace71947682e727dcf94faba425be66fbd703 Mon Sep 17 00:00:00 2001 From: Nicolas Goaziou Date: Sat, 1 Jul 2023 21:40:42 +0200 Subject: guix: Fix sub-directories in texlive importer locations. * guix/import/texlive.scm (files->locations): When removing a sub-directory, make sure to actually remove the sub-directory and not the parent. --- guix/import/texlive.scm | 14 ++++++-------- 1 file changed, 6 insertions(+), 8 deletions(-) (limited to 'guix/import') diff --git a/guix/import/texlive.scm b/guix/import/texlive.scm index 3b5c7192b1..8f90be0c7b 100644 --- a/guix/import/texlive.scm +++ b/guix/import/texlive.scm @@ -352,7 +352,8 @@ (define (strip-directory-prefix file-name) (map strip-directory-prefix existing) files)))) (define (files->locations files) - (define name->parts (cut string-split <> #\/)) + (define (trim-filename entry) + (string-join (drop-right (string-split entry #\/) 1) "/" 'suffix)) ;; Generic locations are shared by multiple packages. Provide the full file ;; name to make so as to extract only the files related to the package being ;; imported. @@ -362,13 +363,10 @@ (define name->parts (cut string-split <> #\/)) texlive-generic-locations)) files))) (append generic - (map (cut string-join <> "/" 'suffix) - (delete-duplicates (map (lambda (file) - (drop-right (name->parts file) 1)) - (sort specific string<)) - ;; Remove sub-directories, i.e. more - ;; specific entries with the same prefix. - (lambda (x y) (every equal? x y))))))) + ;; Remove sub-directories, i.e., more specific entries with the + ;; same prefix. + (delete-duplicates (sort (map trim-filename specific) string<) + string-prefix?)))) (define (tlpdb->package name version package-database) (and-let* ((data (assoc-ref package-database name)) -- cgit v1.2.3