build-system: cargo: Handle Cargo.lock file not present.

* guix/build-system/cargo.scm (cargo-build): Add src output.
  (private-keywords): Add #:outputs.
* guix/build/cargo-build-system.scm (configure): Use /share/rust-source
  when replacing inputs.
  (build, check): Don't do anything when there isn't a Cargo.lock file
  present.
  (install): Install sources to src output. When a Cargo.lock file is
  present use cargo install to install binaries to out.
* guix/import/crate.scm (make-crate-sexp): Importer uses the src output
  for crate inputs by default.
* guix/import/utils.scm (package-names->package-inputs, maybe-inputs,
  maybe-native-inputs): Take an optional output argument.
* tests/crate.scm (crate->guix-package test): Update.

Problem reported by Francisco Gómez García <espectalll@kydara.com>.
This commit is contained in:
David Craven 2016-12-29 16:29:24 +01:00
parent f53a5514e0
commit f1d136957d
No known key found for this signature in database
GPG key ID: C5E051C79C0BECDB
5 changed files with 25 additions and 19 deletions

View file

@ -109,7 +109,7 @@ (define guile-for-build
#:inputs inputs
#:system system
#:modules imported-modules
#:outputs outputs
#:outputs (cons "src" outputs)
#:guile-for-build guile-for-build))
(define* (lower name
@ -121,7 +121,7 @@ (define* (lower name
"Return a bag for NAME."
(define private-keywords
'(#:source #:target #:cargo #:rustc #:inputs #:native-inputs))
'(#:source #:target #:cargo #:rustc #:inputs #:native-inputs #:outputs))
(and (not target) ;; TODO: support cross-compilation
(bag

View file

@ -54,7 +54,7 @@ (define* (configure #:key inputs #:allow-other-keys)
(when (and crate path)
(match (string-split (basename path) #\-)
((_ ... version)
(format port "\"~a:~a\" = { path = \"~a/rustsrc\" }~%"
(format port "\"~a:~a\" = { path = \"~a/share/rust-source\" }~%"
crate version path)))))))
inputs)
(close-port port))
@ -63,19 +63,22 @@ (define* (configure #:key inputs #:allow-other-keys)
(define* (build #:key (cargo-build-flags '("--release" "--frozen"))
#:allow-other-keys)
"Build a given Cargo package."
(zero? (apply system* `("cargo" "build" ,@cargo-build-flags))))
(if (file-exists? "Cargo.lock")
(zero? (apply system* `("cargo" "build" ,@cargo-build-flags)))
#t))
(define* (check #:key tests? #:allow-other-keys)
"Run tests for a given Cargo package."
(when tests?
(zero? (system* "cargo" "test"))))
(if (and tests? (file-exists? "Cargo.lock"))
(zero? (system* "cargo" "test"))
#t))
(define* (install #:key inputs outputs #:allow-other-keys)
"Install a given Cargo package."
(let* ((out (assoc-ref outputs "out"))
(src (assoc-ref inputs "source"))
(bin (string-append out "/bin"))
(rsrc (string-append out "/rustsrc")))
(rsrc (string-append (assoc-ref outputs "src")
"/share/rust-source")))
(mkdir-p rsrc)
;; Rust doesn't have a stable ABI yet. Because of this
;; Cargo doesn't have a search path for binaries yet.
@ -87,8 +90,9 @@ (define* (install #:key inputs outputs #:allow-other-keys)
;; When the package includes executables we install
;; it using cargo install. This fails when the crate
;; doesn't contain an executable.
(system* "cargo" "install" "--root" bin)
#t))
(if (file-exists? "Cargo.lock")
(system* "cargo" "install" "--root" out)
(mkdir out))))
(define %standard-phases
;; 'configure' phase is not needed.

View file

@ -97,8 +97,8 @@ (define* (make-crate-sexp #:key name version inputs native-inputs
(base32
,(bytevector->nix-base32-string (port-sha256 port))))))
(build-system cargo-build-system)
,@(maybe-native-inputs native-inputs)
,@(maybe-inputs inputs)
,@(maybe-native-inputs native-inputs "src")
,@(maybe-inputs inputs "src")
(home-page ,(match home-page
(() "")
(_ home-page)))

View file

@ -211,24 +211,26 @@ (define (beautify-description description)
(regexp-substitute/global #f "\\. \\b"
cleaned 'pre ". " 'post)))
(define (package-names->package-inputs names)
(define* (package-names->package-inputs names #:optional (output #f))
(map (lambda (input)
(list input (list 'unquote (string->symbol input))))
(cons* input (list 'unquote (string->symbol input))
(or (and output (list output))
'())))
names))
(define (maybe-inputs package-names)
(define* (maybe-inputs package-names #:optional (output #f))
"Given a list of PACKAGE-NAMES, tries to generate the 'inputs' field of a
package definition."
(match (package-names->package-inputs package-names)
(match (package-names->package-inputs package-names output)
(()
'())
((package-inputs ...)
`((inputs (,'quasiquote ,package-inputs))))))
(define (maybe-native-inputs package-names)
(define* (maybe-native-inputs package-names #:optional (output #f))
"Given a list of PACKAGE-NAMES, tries to generate the 'inputs' field of a
package definition."
(match (package-names->package-inputs package-names)
(match (package-names->package-inputs package-names output)
(()
'())
((package-inputs ...)

View file

@ -91,7 +91,7 @@ (define test-source-hash
('build-system 'cargo-build-system)
('inputs
('quasiquote
(("rust-bar" ('unquote 'rust-bar)))))
(("rust-bar" ('unquote 'rust-bar) "src"))))
('home-page "http://example.com")
('synopsis "summary")
('description "summary")