mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-11 13:49:23 -05:00
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:
parent
dba6b34bdd
commit
35f3c5f5ad
2 changed files with 42 additions and 2 deletions
|
@ -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."
|
||||||
|
|
|
@ -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))
|
||||||
|
|
Loading…
Reference in a new issue