pull: Honor '--no-grafts'.

* guix/scripts/pull.scm (guix-pull): Parameterize %GRAFT? as a function
of OPTS.
This commit is contained in:
Ludovic Courtès 2017-08-01 23:38:07 +02:00
parent 3085b50200
commit c53fc48144
No known key found for this signature in database
GPG key ID: 090B11993D9AEBB5

View file

@ -27,6 +27,7 @@ (define-module (guix scripts pull)
#:use-module (guix derivations) #:use-module (guix derivations)
#:use-module (guix download) #:use-module (guix download)
#:use-module (guix gexp) #:use-module (guix gexp)
#:use-module (guix grafts)
#:use-module (guix monads) #:use-module (guix monads)
#:use-module (guix scripts build) #:use-module (guix scripts build)
#:use-module ((guix build utils) #:use-module ((guix build utils)
@ -256,33 +257,36 @@ (define (use-le-certs? url)
(unless (assoc-ref opts 'dry-run?) ;XXX: not very useful (unless (assoc-ref opts 'dry-run?) ;XXX: not very useful
(with-store store (with-store store
(set-build-options-from-command-line store opts) (parameterize ((%graft? (assoc-ref opts 'graft?)))
(set-build-options-from-command-line store opts)
;; For reproducibility, always refer to the LE certificates when we ;; For reproducibility, always refer to the LE certificates when we
;; know we're talking to Savannah. ;; know we're talking to Savannah.
(when (use-le-certs? url) (when (use-le-certs? url)
(honor-lets-encrypt-certificates! store)) (honor-lets-encrypt-certificates! store))
(format (current-error-port)
(G_ "Updating from Git repository at '~a'...~%")
url)
(let-values (((checkout commit)
(latest-repository-commit store url
#:ref ref
#:cache-directory cache)))
(format (current-error-port) (format (current-error-port)
(G_ "Building from Git commit ~a...~%") (G_ "Updating from Git repository at '~a'...~%")
commit) url)
(parameterize ((%guile-for-build
(package-derivation store (let-values (((checkout commit)
(if (assoc-ref opts 'bootstrap?) (latest-repository-commit store url
%bootstrap-guile #:ref ref
(canonical-package guile-2.0))))) #:cache-directory cache)))
(run-with-store store
(build-and-install checkout (config-directory) (format (current-error-port)
#:commit commit (G_ "Building from Git commit ~a...~%")
#:verbose? (assoc-ref opts 'verbose?))))))))))) commit)
(parameterize ((%guile-for-build
(package-derivation
store
(if (assoc-ref opts 'bootstrap?)
%bootstrap-guile
(canonical-package guile-2.0)))))
(run-with-store store
(build-and-install checkout (config-directory)
#:commit commit
#:verbose?
(assoc-ref opts 'verbose?))))))))))))
;;; pull.scm ends here ;;; pull.scm ends here