packages: Raise an error condition upon invalid input.

* guix/packages.scm (&package-error, &package-input-error): New
  condition types.
  (package-derivation): Raise a `&package-input-error' when no match is
  made.
This commit is contained in:
Ludovic Courtès 2012-08-23 23:09:13 +02:00
parent dfae21c8cc
commit d36622dc44

View file

@ -23,6 +23,8 @@ (define-module (guix packages)
#:use-module (ice-9 match)
#:use-module (srfi srfi-1)
#:use-module (srfi srfi-9)
#:use-module (srfi srfi-34)
#:use-module (srfi srfi-35)
#:export (location
location?
location-file
@ -60,7 +62,12 @@ (define-module (guix packages)
package-transitive-inputs
package-source-derivation
package-derivation
package-cross-derivation))
package-cross-derivation
&package-error
package-error-package
&package-input-error
package-error-invalid-input))
;;; Commentary:
;;;
@ -116,6 +123,7 @@ (define-syntax base32
#''bv)))))
;; A package.
(define-record-type* <package>
package make-package
package?
@ -156,6 +164,18 @@ (define-record-type* <package>
(default (and=> (current-source-location)
source-properties->location))))
;; Error conditions.
(define-condition-type &package-error &error
package-error?
(package package-error-package))
(define-condition-type &package-input-error &package-error
package-input-error?
(input package-error-invalid-input))
(define (package-source-derivation store source)
"Return the derivation path for SOURCE, a package source."
(match source
@ -209,7 +229,11 @@ (define* (package-derivation store package
;; added anyway, so it can be used as a source.
(list name
(add-to-store store (basename file)
#t #f "sha256" file))))
#t #f "sha256" file)))
(x
(raise (condition (&package-input-error
(package package)
(input x))))))
(package-transitive-inputs package))))
(apply builder
store (string-append name "-" version)