Track the source location of packages.

* guix/packages.scm (<location>): New record type.
  (location, source-properties->location): New procedures.
  (<package>)[location]: New field.

* tests/packages.scm ("GNU Hello"): Test `package-location'.
This commit is contained in:
Ludovic Courtès 2012-06-28 23:15:24 +02:00
parent dba6b34bdd
commit 35f3c5f5ad
2 changed files with 42 additions and 2 deletions

View file

@ -21,7 +21,14 @@ (define-module (guix packages)
#:use-module (guix store) #:use-module (guix store)
#:use-module (guix build-system) #:use-module (guix build-system)
#:use-module (ice-9 match) #:use-module (ice-9 match)
#:export (source #:use-module (srfi srfi-9)
#:export (location
location?
location-file
location-line
location-column
source
package-source? package-source?
package-source-uri package-source-uri
package-source-method package-source-method
@ -44,6 +51,7 @@ (define-module (guix packages)
package-license package-license
package-platforms package-platforms
package-maintainers package-maintainers
package-location
package-source-derivation package-source-derivation
package-derivation package-derivation
@ -56,6 +64,32 @@ (define-module (guix packages)
;;; ;;;
;;; Code: ;;; Code:
;; A source location.
(define-record-type <location>
(make-location file line column)
location?
(file location-file) ; file name
(line location-line) ; 1-indexed line
(column location-column)) ; 0-indexed column
(define location
(memoize
(lambda (file line column)
"Return the <location> object for the given FILE, LINE, and COLUMN."
(and line column file
(make-location file line column)))))
(define (source-properties->location loc)
"Return a location object based on the info in LOC, an alist as returned
by Guile's `source-properties', `frame-source', `current-source-location',
etc."
(let ((file (assq-ref loc 'filename))
(line (assq-ref loc 'line))
(col (assq-ref loc 'column)))
(location file (and line (+ line 1)) col)))
;; The source of a package, such as a tarball URL and fetcher.
(define-record-type* <package-source> (define-record-type* <package-source>
source make-package-source source make-package-source
package-source? package-source?
@ -65,6 +99,7 @@ (define-record-type* <package-source>
(file-name package-source-file-name ; optional file name (file-name package-source-file-name ; optional file name
(default #f))) (default #f)))
;; A package.
(define-record-type* <package> (define-record-type* <package>
package make-package package make-package
package? package?
@ -88,7 +123,10 @@ (define-record-type* <package>
(long-description package-long-description) ; one or two paragraphs (long-description package-long-description) ; one or two paragraphs
(license package-license (default '())) (license package-license (default '()))
(platforms package-platforms (default '())) (platforms package-platforms (default '()))
(maintainers package-maintainers (default '()))) (maintainers package-maintainers (default '()))
(location package-location
(default (and=> (current-source-location)
source-properties->location))))
(define (package-source-derivation store source) (define (package-source-derivation store source)
"Return the derivation path for SOURCE, a package source." "Return the derivation path for SOURCE, a package source."

View file

@ -36,6 +36,8 @@ (define %store
(test-assert "GNU Hello" (test-assert "GNU Hello"
(and (package? hello) (and (package? hello)
(or (location? (package-location hello))
(not (package-location hello)))
(let* ((drv (package-derivation %store hello)) (let* ((drv (package-derivation %store hello))
(out (derivation-path->output-path drv))) (out (derivation-path->output-path drv)))
(and (build-derivations %store (list drv)) (and (build-derivations %store (list drv))