profiles: Hooks always return a monadic value.

Suggested by 宋文武 <iyzsong@gmail.com>.

* guix/profiles.scm (ghc-package-cache-file): Return a monadic #f, not just
  #f, when MANIFEST contains no GHC package.
  (profile-derivation): Do not filter based on the return value of HOOK;
  instead filter based on the value of items in EXTRAS.
This commit is contained in:
Ludovic Courtès 2015-05-26 23:38:27 +02:00
parent 41766807d0
commit 07eaecfae1

View file

@ -516,12 +516,14 @@ (define (copy-conf-file conf)
(for-each delete-file (find-files db-dir "\\.conf$")) (for-each delete-file (find-files db-dir "\\.conf$"))
success))) success)))
;; Don't depend on GHC when there's nothing to do. (with-monad %store-monad
(and (any (cut string-prefix? "ghc" <>) ;; Don't depend on GHC when there's nothing to do.
(map manifest-entry-name (manifest-entries manifest))) (if (any (cut string-prefix? "ghc" <>)
(gexp->derivation "ghc-package-cache" build (map manifest-entry-name (manifest-entries manifest)))
#:modules '((guix build utils)) (gexp->derivation "ghc-package-cache" build
#:local-build? #t))) #:modules '((guix build utils))
#:local-build? #t)
(return #f))))
(define (ca-certificate-bundle manifest) (define (ca-certificate-bundle manifest)
"Return a derivation that builds a single-file bundle containing the CA "Return a derivation that builds a single-file bundle containing the CA
@ -602,11 +604,14 @@ (define* (profile-derivation manifest
(mlet %store-monad ((extras (if (null? (manifest-entries manifest)) (mlet %store-monad ((extras (if (null? (manifest-entries manifest))
(return '()) (return '())
(sequence %store-monad (sequence %store-monad
(filter-map (lambda (hook) (map (lambda (hook)
(hook manifest)) (hook manifest))
hooks))))) hooks)))))
(define inputs (define inputs
(append (map gexp-input extras) (append (filter-map (lambda (gexp)
(and (gexp? gexp)
(gexp-input gexp)))
extras)
(manifest-inputs manifest))) (manifest-inputs manifest)))
(define builder (define builder