2013-01-05 18:47:50 -05:00
|
|
|
|
;;; GNU Guix --- Functional package management for GNU
|
2016-01-19 15:57:40 -05:00
|
|
|
|
;;; Copyright © 2012, 2013, 2014, 2015, 2016 Ludovic Courtès <ludo@gnu.org>
|
Build newest versions unless specified, and implement upgrades.
* gnu/packages.scm (find-newest-available-packages):
New exported procedure.
* guix-build.in (newest-available-packages, find-best-packages-by-name):
New procedures.
(find-package): Use find-best-packages-by-name, to guarantee that
if a version number is not specified, only the newest versions will
be considered.
* guix-package.in (%options): Add --upgrade/-u option.
(newest-available-packages, find-best-packages-by-name, upgradeable?):
New procedures.
(find-package): Use find-best-packages-by-name, to guarantee that
if a version number is not specified, only the newest versions will
be considered.
(process-actions): Implement upgrade option.
* doc/guix.texi (Invoking guix-package): In the description of --install,
mention that if no version number is specified, the newest available
version will be selected.
2013-02-12 01:24:21 -05:00
|
|
|
|
;;; Copyright © 2013 Mark H Weaver <mhw@netris.org>
|
2012-06-30 18:56:24 -04:00
|
|
|
|
;;;
|
2013-01-05 18:47:50 -05:00
|
|
|
|
;;; This file is part of GNU Guix.
|
2012-06-30 18:56:24 -04:00
|
|
|
|
;;;
|
2013-01-05 18:47:50 -05:00
|
|
|
|
;;; GNU Guix is free software; you can redistribute it and/or modify it
|
2012-06-30 18:56:24 -04:00
|
|
|
|
;;; under the terms of the GNU General Public License as published by
|
|
|
|
|
;;; the Free Software Foundation; either version 3 of the License, or (at
|
|
|
|
|
;;; your option) any later version.
|
|
|
|
|
;;;
|
2013-01-05 18:47:50 -05:00
|
|
|
|
;;; GNU Guix is distributed in the hope that it will be useful, but
|
2012-06-30 18:56:24 -04:00
|
|
|
|
;;; WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
;;; GNU General Public License for more details.
|
|
|
|
|
;;;
|
|
|
|
|
;;; You should have received a copy of the GNU General Public License
|
2013-01-05 18:47:50 -05:00
|
|
|
|
;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
|
2012-06-30 18:56:24 -04:00
|
|
|
|
|
Replace individual scripts with master 'guix' script.
* scripts/guix.in: New script.
* Makefile.am (bin_SCRIPTS): Add 'scripts/guix'. Remove 'guix-build',
'guix-download', 'guix-import', 'guix-package', and 'guix-gc'.
(MODULES): Add 'guix/scripts/build.scm', 'guix/scripts/download.scm',
'guix/scripts/import.scm', 'guix/scripts/package.scm', and
'guix/scripts/gc.scm'.
* configure.ac (AC_CONFIG_FILES): Add 'scripts/guix'. Remove 'guix-build',
'guix-download', 'guix-import', 'guix-package', and 'guix-gc'.
* guix-build.in, guix-download.in, guix-gc.in, guix-import.in,
guix-package.in: Remove shell script boilerplate. Move to guix-COMMAND.in
to guix/scripts/COMMAND.scm. Rename module from (guix-COMMAND) to
(guix scripts COMMAND). Change "guix-COMMAND" to "guix COMMAND" in
usage help string.
* pre-inst-env.in: Add "@abs_top_builddir@/scripts" to the front of $PATH.
Export $GUIX_UNINSTALLED.
* tests/guix-build.sh, tests/guix-daemon.sh, tests/guix-download.sh,
tests/guix-gc.sh, tests/guix-package.sh: Use "guix COMMAND" instead of
"guix-COMMAND".
* doc/guix.texi: Replace all occurrences of "guix-COMMAND" with
"guix COMMAND".
* po/POTFILES.in: Update.
2013-02-14 04:15:25 -05:00
|
|
|
|
(define-module (guix scripts build)
|
2012-10-31 19:50:01 -04:00
|
|
|
|
#:use-module (guix ui)
|
2015-09-10 05:37:36 -04:00
|
|
|
|
#:use-module (guix scripts)
|
2012-06-30 18:56:24 -04:00
|
|
|
|
#:use-module (guix store)
|
|
|
|
|
#:use-module (guix derivations)
|
|
|
|
|
#:use-module (guix packages)
|
2016-02-22 10:29:44 -05:00
|
|
|
|
#:use-module (guix grafts)
|
2016-03-23 17:32:44 -04:00
|
|
|
|
|
|
|
|
|
;; Use the procedure that destructures "NAME-VERSION" forms.
|
|
|
|
|
#:use-module ((guix utils) #:hide (package-name->name+version))
|
|
|
|
|
#:use-module ((guix build utils) #:select (package-name->name+version))
|
|
|
|
|
|
2013-11-18 17:08:20 -05:00
|
|
|
|
#:use-module (guix monads)
|
2014-06-14 16:37:24 -04:00
|
|
|
|
#:use-module (guix gexp)
|
2015-09-10 17:10:50 -04:00
|
|
|
|
#:autoload (guix http-client) (http-fetch http-get-error?)
|
2012-06-30 18:56:24 -04:00
|
|
|
|
#:use-module (ice-9 format)
|
|
|
|
|
#:use-module (ice-9 match)
|
Build newest versions unless specified, and implement upgrades.
* gnu/packages.scm (find-newest-available-packages):
New exported procedure.
* guix-build.in (newest-available-packages, find-best-packages-by-name):
New procedures.
(find-package): Use find-best-packages-by-name, to guarantee that
if a version number is not specified, only the newest versions will
be considered.
* guix-package.in (%options): Add --upgrade/-u option.
(newest-available-packages, find-best-packages-by-name, upgradeable?):
New procedures.
(find-package): Use find-best-packages-by-name, to guarantee that
if a version number is not specified, only the newest versions will
be considered.
(process-actions): Implement upgrade option.
* doc/guix.texi (Invoking guix-package): In the description of --install,
mention that if no version number is specified, the newest available
version will be selected.
2013-02-12 01:24:21 -05:00
|
|
|
|
#:use-module (ice-9 vlist)
|
2012-06-30 18:56:24 -04:00
|
|
|
|
#:use-module (srfi srfi-1)
|
2013-01-22 16:13:10 -05:00
|
|
|
|
#:use-module (srfi srfi-11)
|
2012-06-30 18:56:24 -04:00
|
|
|
|
#:use-module (srfi srfi-26)
|
2012-10-27 08:56:38 -04:00
|
|
|
|
#:use-module (srfi srfi-34)
|
2012-06-30 18:56:24 -04:00
|
|
|
|
#:use-module (srfi srfi-37)
|
2014-09-24 05:26:30 -04:00
|
|
|
|
#:autoload (gnu packages) (specification->package %package-module-path)
|
2014-03-11 17:08:40 -04:00
|
|
|
|
#:autoload (guix download) (download-to-store)
|
2014-03-13 14:21:49 -04:00
|
|
|
|
#:export (%standard-build-options
|
guix build: Factorize common options.
* guix/scripts/build.scm (show-build-options-help,
set-build-options-from-command-line): New procedures.
(show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%standard-build-options): New variable.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(guix-build): Use 'set-build-options-from-command-line' instead of
'set-build-options'.
* guix/scripts/archive.scm (show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(export-from-store): Call 'set-build-options-from-command-line'
instead of 'set-build-options.
2014-02-17 18:13:06 -05:00
|
|
|
|
set-build-options-from-command-line
|
2015-05-20 18:48:10 -04:00
|
|
|
|
set-build-options-from-command-line*
|
guix build: Factorize common options.
* guix/scripts/build.scm (show-build-options-help,
set-build-options-from-command-line): New procedures.
(show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%standard-build-options): New variable.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(guix-build): Use 'set-build-options-from-command-line' instead of
'set-build-options'.
* guix/scripts/archive.scm (show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(export-from-store): Call 'set-build-options-from-command-line'
instead of 'set-build-options.
2014-02-17 18:13:06 -05:00
|
|
|
|
show-build-options-help
|
2016-01-31 14:44:21 -05:00
|
|
|
|
|
|
|
|
|
%transformation-options
|
2016-01-31 14:18:52 -05:00
|
|
|
|
options->transformation
|
2016-01-31 14:44:21 -05:00
|
|
|
|
show-transformation-options-help
|
guix build: Factorize common options.
* guix/scripts/build.scm (show-build-options-help,
set-build-options-from-command-line): New procedures.
(show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%standard-build-options): New variable.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(guix-build): Use 'set-build-options-from-command-line' instead of
'set-build-options'.
* guix/scripts/archive.scm (show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(export-from-store): Call 'set-build-options-from-command-line'
instead of 'set-build-options.
2014-02-17 18:13:06 -05:00
|
|
|
|
|
2013-12-21 19:08:21 -05:00
|
|
|
|
guix-build))
|
2012-06-30 18:56:24 -04:00
|
|
|
|
|
2015-09-10 17:10:50 -04:00
|
|
|
|
(define %default-log-urls
|
|
|
|
|
;; Default base URLs for build logs.
|
|
|
|
|
'("http://hydra.gnu.org/log"))
|
|
|
|
|
|
|
|
|
|
;; XXX: The following procedure cannot be in (guix store) because of the
|
|
|
|
|
;; dependency on (guix derivations).
|
|
|
|
|
(define* (log-url store file #:key (base-urls %default-log-urls))
|
|
|
|
|
"Return a URL under one of the BASE-URLS where a build log for FILE can be
|
|
|
|
|
found. Return #f if no build log was found."
|
|
|
|
|
(define (valid-url? url)
|
|
|
|
|
;; Probe URL and return #t if it is accessible.
|
|
|
|
|
(guard (c ((http-get-error? c) #f))
|
|
|
|
|
(close-port (http-fetch url #:buffered? #f))
|
|
|
|
|
#t))
|
|
|
|
|
|
|
|
|
|
(define (find-url file)
|
|
|
|
|
(let ((base (basename file)))
|
|
|
|
|
(any (lambda (base-url)
|
|
|
|
|
(let ((url (string-append base-url "/" base)))
|
|
|
|
|
(and (valid-url? url) url)))
|
|
|
|
|
base-urls)))
|
|
|
|
|
|
|
|
|
|
(cond ((derivation-path? file)
|
|
|
|
|
(catch 'system-error
|
|
|
|
|
(lambda ()
|
|
|
|
|
;; Usually we'll have more luck with the output file name since
|
|
|
|
|
;; the deriver that was used by the server could be different, so
|
|
|
|
|
;; try one of the output file names.
|
|
|
|
|
(let ((drv (call-with-input-file file read-derivation)))
|
|
|
|
|
(or (find-url (derivation->output-path drv))
|
|
|
|
|
(find-url file))))
|
|
|
|
|
(lambda args
|
|
|
|
|
;; As a last resort, try the .drv.
|
|
|
|
|
(if (= ENOENT (system-error-errno args))
|
|
|
|
|
(find-url file)
|
|
|
|
|
(apply throw args)))))
|
|
|
|
|
(else
|
|
|
|
|
(find-url file))))
|
|
|
|
|
|
2013-12-21 16:53:58 -05:00
|
|
|
|
(define (register-root store paths root)
|
|
|
|
|
"Register ROOT as an indirect GC root for all of PATHS."
|
|
|
|
|
(let* ((root (string-append (canonicalize-path (dirname root))
|
|
|
|
|
"/" root)))
|
|
|
|
|
(catch 'system-error
|
|
|
|
|
(lambda ()
|
|
|
|
|
(match paths
|
|
|
|
|
((path)
|
|
|
|
|
(symlink path root)
|
|
|
|
|
(add-indirect-root store root))
|
|
|
|
|
((paths ...)
|
|
|
|
|
(fold (lambda (path count)
|
|
|
|
|
(let ((root (string-append root
|
|
|
|
|
"-"
|
|
|
|
|
(number->string count))))
|
|
|
|
|
(symlink path root)
|
|
|
|
|
(add-indirect-root store root))
|
|
|
|
|
(+ 1 count))
|
|
|
|
|
0
|
|
|
|
|
paths))))
|
|
|
|
|
(lambda args
|
|
|
|
|
(leave (_ "failed to create GC root `~a': ~a~%")
|
|
|
|
|
root (strerror (system-error-errno args)))))))
|
|
|
|
|
|
2014-03-11 17:08:40 -04:00
|
|
|
|
(define (package-with-source store p uri)
|
|
|
|
|
"Return a package based on P but with its source taken from URI. Extract
|
|
|
|
|
the new package's version number from URI."
|
|
|
|
|
(define (numeric-extension? file-name)
|
|
|
|
|
;; Return true if FILE-NAME ends with digits.
|
|
|
|
|
(string-every char-set:hex-digit (file-extension file-name)))
|
|
|
|
|
|
|
|
|
|
(define (tarball-base-name file-name)
|
|
|
|
|
;; Return the "base" of FILE-NAME, removing '.tar.gz' or similar
|
|
|
|
|
;; extensions.
|
|
|
|
|
;; TODO: Factorize.
|
2015-06-11 05:19:12 -04:00
|
|
|
|
(cond ((not (file-extension file-name))
|
|
|
|
|
file-name)
|
|
|
|
|
((numeric-extension? file-name)
|
2014-03-11 17:08:40 -04:00
|
|
|
|
file-name)
|
|
|
|
|
((string=? (file-extension file-name) "tar")
|
|
|
|
|
(file-sans-extension file-name))
|
2015-06-11 05:19:12 -04:00
|
|
|
|
((file-extension file-name)
|
|
|
|
|
(tarball-base-name (file-sans-extension file-name)))
|
2014-03-11 17:08:40 -04:00
|
|
|
|
(else
|
2015-06-11 05:19:12 -04:00
|
|
|
|
file-name)))
|
2014-03-11 17:08:40 -04:00
|
|
|
|
|
|
|
|
|
(let ((base (tarball-base-name (basename uri))))
|
|
|
|
|
(let-values (((name version)
|
|
|
|
|
(package-name->name+version base)))
|
|
|
|
|
(package (inherit p)
|
|
|
|
|
(version (or version (package-version p)))
|
2015-06-11 05:19:12 -04:00
|
|
|
|
|
|
|
|
|
;; Use #:recursive? #t to allow for directories.
|
|
|
|
|
(source (download-to-store store uri
|
|
|
|
|
#:recursive? #t))))))
|
2014-03-11 17:08:40 -04:00
|
|
|
|
|
2016-01-31 14:44:21 -05:00
|
|
|
|
|
|
|
|
|
;;;
|
|
|
|
|
;;; Transformations.
|
|
|
|
|
;;;
|
|
|
|
|
|
|
|
|
|
(define (transform-package-source sources)
|
|
|
|
|
"Return a transformation procedure that replaces package sources with the
|
|
|
|
|
matching URIs given in SOURCES."
|
|
|
|
|
(define new-sources
|
|
|
|
|
(map (lambda (uri)
|
|
|
|
|
(cons (package-name->name+version (basename uri))
|
|
|
|
|
uri))
|
|
|
|
|
sources))
|
|
|
|
|
|
|
|
|
|
(lambda (store obj)
|
|
|
|
|
(let loop ((sources new-sources)
|
|
|
|
|
(result '()))
|
|
|
|
|
(match obj
|
|
|
|
|
((? package? p)
|
|
|
|
|
(let ((source (assoc-ref sources (package-name p))))
|
|
|
|
|
(if source
|
|
|
|
|
(package-with-source store p source)
|
|
|
|
|
p)))
|
|
|
|
|
(_
|
|
|
|
|
obj)))))
|
|
|
|
|
|
2016-01-31 17:22:18 -05:00
|
|
|
|
(define (transform-package-inputs replacement-specs)
|
|
|
|
|
"Return a procedure that, when passed a package, replaces its direct
|
|
|
|
|
dependencies according to REPLACEMENT-SPECS. REPLACEMENT-SPECS is a list of
|
|
|
|
|
strings like \"guile=guile@2.1\" meaning that, any direct dependency on a
|
|
|
|
|
package called \"guile\" must be replaced with a dependency on a version 2.1
|
|
|
|
|
of \"guile\"."
|
|
|
|
|
(define not-equal
|
|
|
|
|
(char-set-complement (char-set #\=)))
|
|
|
|
|
|
|
|
|
|
(define replacements
|
|
|
|
|
;; List of name/package pairs.
|
|
|
|
|
(map (lambda (spec)
|
|
|
|
|
(match (string-tokenize spec not-equal)
|
|
|
|
|
((old new)
|
|
|
|
|
(cons old (specification->package new)))
|
|
|
|
|
(_
|
|
|
|
|
(leave (_ "invalid replacement specification: ~s~%") spec))))
|
|
|
|
|
replacement-specs))
|
|
|
|
|
|
|
|
|
|
(define (rewrite input)
|
|
|
|
|
(match input
|
|
|
|
|
((label (? package? package) outputs ...)
|
|
|
|
|
(match (assoc-ref replacements (package-name package))
|
|
|
|
|
(#f (cons* label (replace package) outputs))
|
|
|
|
|
(new (cons* label new outputs))))
|
|
|
|
|
(_
|
|
|
|
|
input)))
|
|
|
|
|
|
|
|
|
|
(define replace
|
|
|
|
|
(memoize ;XXX: use eq?
|
|
|
|
|
(lambda (p)
|
|
|
|
|
(package
|
|
|
|
|
(inherit p)
|
|
|
|
|
(inputs (map rewrite (package-inputs p)))
|
|
|
|
|
(native-inputs (map rewrite (package-native-inputs p)))
|
|
|
|
|
(propagated-inputs (map rewrite (package-propagated-inputs p)))))))
|
|
|
|
|
|
|
|
|
|
(lambda (store obj)
|
|
|
|
|
(if (package? obj)
|
|
|
|
|
(replace obj)
|
|
|
|
|
obj)))
|
|
|
|
|
|
2016-01-31 14:44:21 -05:00
|
|
|
|
(define %transformations
|
|
|
|
|
;; Transformations that can be applied to things to build. The car is the
|
|
|
|
|
;; key used in the option alist, and the cdr is the transformation
|
|
|
|
|
;; procedure; it is called with two arguments: the store, and a list of
|
|
|
|
|
;; things to build.
|
2016-01-31 17:22:18 -05:00
|
|
|
|
`((with-source . ,transform-package-source)
|
|
|
|
|
(with-input . ,transform-package-inputs)))
|
2016-01-31 14:44:21 -05:00
|
|
|
|
|
|
|
|
|
(define %transformation-options
|
|
|
|
|
;; The command-line interface to the above transformations.
|
|
|
|
|
(list (option '("with-source") #t #f
|
|
|
|
|
(lambda (opt name arg result . rest)
|
|
|
|
|
(apply values
|
|
|
|
|
(cons (alist-cons 'with-source arg result)
|
2016-01-31 17:22:18 -05:00
|
|
|
|
rest))))
|
|
|
|
|
(option '("with-input") #t #f
|
|
|
|
|
(lambda (opt name arg result . rest)
|
|
|
|
|
(apply values
|
|
|
|
|
(cons (alist-cons 'with-input arg result)
|
2016-01-31 14:44:21 -05:00
|
|
|
|
rest))))))
|
|
|
|
|
|
|
|
|
|
(define (show-transformation-options-help)
|
|
|
|
|
(display (_ "
|
|
|
|
|
--with-source=SOURCE
|
2016-01-31 17:22:18 -05:00
|
|
|
|
use SOURCE when building the corresponding package"))
|
|
|
|
|
(display (_ "
|
|
|
|
|
--with-input=PACKAGE=REPLACEMENT
|
|
|
|
|
replace dependency PACKAGE by REPLACEMENT")))
|
2016-01-31 14:44:21 -05:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
(define (options->transformation opts)
|
|
|
|
|
"Return a procedure that, when passed an object to build (package,
|
|
|
|
|
derivation, etc.), applies the transformations specified by OPTS."
|
|
|
|
|
(define applicable
|
|
|
|
|
;; List of applicable transformations as symbol/procedure pairs.
|
|
|
|
|
(filter-map (match-lambda
|
|
|
|
|
((key . transform)
|
|
|
|
|
(match (filter-map (match-lambda
|
|
|
|
|
((k . arg)
|
|
|
|
|
(and (eq? k key) arg)))
|
|
|
|
|
opts)
|
|
|
|
|
(() #f)
|
|
|
|
|
(args (cons key (transform args))))))
|
|
|
|
|
%transformations))
|
|
|
|
|
|
|
|
|
|
(lambda (store obj)
|
|
|
|
|
(fold (match-lambda*
|
|
|
|
|
(((name . transform) obj)
|
|
|
|
|
(let ((new (transform store obj)))
|
|
|
|
|
(when (eq? new obj)
|
|
|
|
|
(warning (_ "transformation '~a' had no effect on ~a~%")
|
|
|
|
|
name
|
|
|
|
|
(if (package? obj)
|
|
|
|
|
(package-full-name obj)
|
|
|
|
|
obj)))
|
|
|
|
|
new)))
|
|
|
|
|
obj
|
|
|
|
|
applicable)))
|
|
|
|
|
|
2012-06-30 18:56:24 -04:00
|
|
|
|
|
|
|
|
|
;;;
|
guix build: Factorize common options.
* guix/scripts/build.scm (show-build-options-help,
set-build-options-from-command-line): New procedures.
(show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%standard-build-options): New variable.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(guix-build): Use 'set-build-options-from-command-line' instead of
'set-build-options'.
* guix/scripts/archive.scm (show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(export-from-store): Call 'set-build-options-from-command-line'
instead of 'set-build-options.
2014-02-17 18:13:06 -05:00
|
|
|
|
;;; Standard command-line build options.
|
2012-06-30 18:56:24 -04:00
|
|
|
|
;;;
|
|
|
|
|
|
guix build: Factorize common options.
* guix/scripts/build.scm (show-build-options-help,
set-build-options-from-command-line): New procedures.
(show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%standard-build-options): New variable.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(guix-build): Use 'set-build-options-from-command-line' instead of
'set-build-options'.
* guix/scripts/archive.scm (show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(export-from-store): Call 'set-build-options-from-command-line'
instead of 'set-build-options.
2014-02-17 18:13:06 -05:00
|
|
|
|
(define (show-build-options-help)
|
|
|
|
|
"Display on the current output port help about the standard command-line
|
|
|
|
|
options handled by 'set-build-options-from-command-line', and listed in
|
|
|
|
|
'%standard-build-options'."
|
2014-09-24 05:26:30 -04:00
|
|
|
|
(display (_ "
|
|
|
|
|
-L, --load-path=DIR prepend DIR to the package module search path"))
|
2012-09-04 17:43:24 -04:00
|
|
|
|
(display (_ "
|
2012-06-30 18:56:24 -04:00
|
|
|
|
-K, --keep-failed keep build tree of failed builds"))
|
|
|
|
|
(display (_ "
|
2016-01-19 15:57:40 -05:00
|
|
|
|
-k, --keep-going keep going when some of the derivations fail"))
|
|
|
|
|
(display (_ "
|
2012-06-30 18:56:24 -04:00
|
|
|
|
-n, --dry-run do not build the derivations"))
|
2013-05-29 17:08:06 -04:00
|
|
|
|
(display (_ "
|
|
|
|
|
--fallback fall back to building when the substituter fails"))
|
2012-10-18 16:24:49 -04:00
|
|
|
|
(display (_ "
|
2012-10-24 09:01:16 -04:00
|
|
|
|
--no-substitutes build instead of resorting to pre-built substitutes"))
|
2015-07-13 10:07:59 -04:00
|
|
|
|
(display (_ "
|
|
|
|
|
--substitute-urls=URLS
|
|
|
|
|
fetch substitute from URLS if they are authorized"))
|
2016-03-02 07:43:13 -05:00
|
|
|
|
(display (_ "
|
|
|
|
|
--no-grafts do not graft packages"))
|
2014-01-05 16:58:32 -05:00
|
|
|
|
(display (_ "
|
|
|
|
|
--no-build-hook do not attempt to offload builds via the build hook"))
|
2013-05-20 12:14:55 -04:00
|
|
|
|
(display (_ "
|
|
|
|
|
--max-silent-time=SECONDS
|
|
|
|
|
mark the build as failed after SECONDS of silence"))
|
2014-03-09 18:09:18 -04:00
|
|
|
|
(display (_ "
|
|
|
|
|
--timeout=SECONDS mark the build as failed after SECONDS of activity"))
|
2012-12-15 09:21:38 -05:00
|
|
|
|
(display (_ "
|
|
|
|
|
--verbosity=LEVEL use the given verbosity LEVEL"))
|
2015-12-08 17:27:53 -05:00
|
|
|
|
(display (_ "
|
|
|
|
|
--rounds=N build N times in a row to detect non-determinism"))
|
2013-11-11 19:06:25 -05:00
|
|
|
|
(display (_ "
|
2014-11-25 16:32:26 -05:00
|
|
|
|
-c, --cores=N allow the use of up to N CPU cores for the build"))
|
|
|
|
|
(display (_ "
|
|
|
|
|
-M, --max-jobs=N allow at most N build jobs")))
|
2012-06-30 18:56:24 -04:00
|
|
|
|
|
guix build: Factorize common options.
* guix/scripts/build.scm (show-build-options-help,
set-build-options-from-command-line): New procedures.
(show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%standard-build-options): New variable.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(guix-build): Use 'set-build-options-from-command-line' instead of
'set-build-options'.
* guix/scripts/archive.scm (show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(export-from-store): Call 'set-build-options-from-command-line'
instead of 'set-build-options.
2014-02-17 18:13:06 -05:00
|
|
|
|
(define (set-build-options-from-command-line store opts)
|
|
|
|
|
"Given OPTS, an alist as returned by 'args-fold' given
|
|
|
|
|
'%standard-build-options', set the corresponding build options on STORE."
|
|
|
|
|
;; TODO: Add more options.
|
|
|
|
|
(set-build-options store
|
|
|
|
|
#:keep-failed? (assoc-ref opts 'keep-failed?)
|
2016-01-19 15:57:40 -05:00
|
|
|
|
#:keep-going? (assoc-ref opts 'keep-going?)
|
2015-12-08 17:27:53 -05:00
|
|
|
|
#:rounds (assoc-ref opts 'rounds)
|
guix build: Factorize common options.
* guix/scripts/build.scm (show-build-options-help,
set-build-options-from-command-line): New procedures.
(show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%standard-build-options): New variable.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(guix-build): Use 'set-build-options-from-command-line' instead of
'set-build-options'.
* guix/scripts/archive.scm (show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(export-from-store): Call 'set-build-options-from-command-line'
instead of 'set-build-options.
2014-02-17 18:13:06 -05:00
|
|
|
|
#:build-cores (or (assoc-ref opts 'cores) 0)
|
2014-11-25 16:32:26 -05:00
|
|
|
|
#:max-build-jobs (or (assoc-ref opts 'max-jobs) 1)
|
guix build: Factorize common options.
* guix/scripts/build.scm (show-build-options-help,
set-build-options-from-command-line): New procedures.
(show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%standard-build-options): New variable.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(guix-build): Use 'set-build-options-from-command-line' instead of
'set-build-options'.
* guix/scripts/archive.scm (show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(export-from-store): Call 'set-build-options-from-command-line'
instead of 'set-build-options.
2014-02-17 18:13:06 -05:00
|
|
|
|
#:fallback? (assoc-ref opts 'fallback?)
|
|
|
|
|
#:use-substitutes? (assoc-ref opts 'substitutes?)
|
2015-10-28 10:20:06 -04:00
|
|
|
|
#:substitute-urls (assoc-ref opts 'substitute-urls)
|
guix build: Factorize common options.
* guix/scripts/build.scm (show-build-options-help,
set-build-options-from-command-line): New procedures.
(show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%standard-build-options): New variable.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(guix-build): Use 'set-build-options-from-command-line' instead of
'set-build-options'.
* guix/scripts/archive.scm (show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(export-from-store): Call 'set-build-options-from-command-line'
instead of 'set-build-options.
2014-02-17 18:13:06 -05:00
|
|
|
|
#:use-build-hook? (assoc-ref opts 'build-hook?)
|
|
|
|
|
#:max-silent-time (assoc-ref opts 'max-silent-time)
|
2014-03-09 18:09:18 -04:00
|
|
|
|
#:timeout (assoc-ref opts 'timeout)
|
2014-06-09 12:54:52 -04:00
|
|
|
|
#:print-build-trace (assoc-ref opts 'print-build-trace?)
|
guix build: Factorize common options.
* guix/scripts/build.scm (show-build-options-help,
set-build-options-from-command-line): New procedures.
(show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%standard-build-options): New variable.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(guix-build): Use 'set-build-options-from-command-line' instead of
'set-build-options'.
* guix/scripts/archive.scm (show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(export-from-store): Call 'set-build-options-from-command-line'
instead of 'set-build-options.
2014-02-17 18:13:06 -05:00
|
|
|
|
#:verbosity (assoc-ref opts 'verbosity)))
|
2012-06-30 18:56:24 -04:00
|
|
|
|
|
2015-05-20 18:48:10 -04:00
|
|
|
|
(define set-build-options-from-command-line*
|
|
|
|
|
(store-lift set-build-options-from-command-line))
|
|
|
|
|
|
guix build: Factorize common options.
* guix/scripts/build.scm (show-build-options-help,
set-build-options-from-command-line): New procedures.
(show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%standard-build-options): New variable.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(guix-build): Use 'set-build-options-from-command-line' instead of
'set-build-options'.
* guix/scripts/archive.scm (show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(export-from-store): Call 'set-build-options-from-command-line'
instead of 'set-build-options.
2014-02-17 18:13:06 -05:00
|
|
|
|
(define %standard-build-options
|
|
|
|
|
;; List of standard command-line options for tools that build something.
|
2014-09-24 05:26:30 -04:00
|
|
|
|
(list (option '(#\L "load-path") #t #f
|
|
|
|
|
(lambda (opt name arg result . rest)
|
|
|
|
|
;; XXX: Imperatively modify the search paths.
|
|
|
|
|
(%package-module-path (cons arg (%package-module-path)))
|
2015-12-30 12:15:54 -05:00
|
|
|
|
(%patch-path (cons arg (%patch-path)))
|
2014-09-24 05:26:30 -04:00
|
|
|
|
(set! %load-path (cons arg %load-path))
|
|
|
|
|
(set! %load-compiled-path (cons arg %load-compiled-path))
|
|
|
|
|
|
|
|
|
|
(apply values (cons result rest))))
|
|
|
|
|
(option '(#\K "keep-failed") #f #f
|
2014-03-01 12:29:29 -05:00
|
|
|
|
(lambda (opt name arg result . rest)
|
|
|
|
|
(apply values
|
|
|
|
|
(alist-cons 'keep-failed? #t result)
|
|
|
|
|
rest)))
|
2016-01-19 15:57:40 -05:00
|
|
|
|
(option '(#\k "keep-going") #f #f
|
|
|
|
|
(lambda (opt name arg result . rest)
|
|
|
|
|
(apply values
|
|
|
|
|
(alist-cons 'keep-going? #t result)
|
|
|
|
|
rest)))
|
2015-12-08 17:27:53 -05:00
|
|
|
|
(option '("rounds") #t #f
|
|
|
|
|
(lambda (opt name arg result . rest)
|
|
|
|
|
(apply values
|
|
|
|
|
(alist-cons 'rounds (string->number* arg)
|
|
|
|
|
result)
|
|
|
|
|
rest)))
|
2013-05-29 17:08:06 -04:00
|
|
|
|
(option '("fallback") #f #f
|
2014-03-01 12:29:29 -05:00
|
|
|
|
(lambda (opt name arg result . rest)
|
|
|
|
|
(apply values
|
|
|
|
|
(alist-cons 'fallback? #t
|
|
|
|
|
(alist-delete 'fallback? result))
|
|
|
|
|
rest)))
|
2012-10-24 09:01:16 -04:00
|
|
|
|
(option '("no-substitutes") #f #f
|
2014-03-01 12:29:29 -05:00
|
|
|
|
(lambda (opt name arg result . rest)
|
|
|
|
|
(apply values
|
|
|
|
|
(alist-cons 'substitutes? #f
|
|
|
|
|
(alist-delete 'substitutes? result))
|
|
|
|
|
rest)))
|
2015-07-13 10:07:59 -04:00
|
|
|
|
(option '("substitute-urls") #t #f
|
|
|
|
|
(lambda (opt name arg result . rest)
|
|
|
|
|
(apply values
|
|
|
|
|
(alist-cons 'substitute-urls
|
|
|
|
|
(string-tokenize arg)
|
|
|
|
|
(alist-delete 'substitute-urls result))
|
|
|
|
|
rest)))
|
2016-03-02 07:43:13 -05:00
|
|
|
|
(option '("no-grafts") #f #f
|
|
|
|
|
(lambda (opt name arg result . rest)
|
|
|
|
|
(apply values
|
|
|
|
|
(alist-cons 'graft? #f
|
|
|
|
|
(alist-delete 'graft? result eq?))
|
|
|
|
|
rest)))
|
2014-01-05 16:58:32 -05:00
|
|
|
|
(option '("no-build-hook") #f #f
|
2014-03-01 12:29:29 -05:00
|
|
|
|
(lambda (opt name arg result . rest)
|
|
|
|
|
(apply values
|
|
|
|
|
(alist-cons 'build-hook? #f
|
|
|
|
|
(alist-delete 'build-hook? result))
|
|
|
|
|
rest)))
|
2013-05-20 12:14:55 -04:00
|
|
|
|
(option '("max-silent-time") #t #f
|
2014-03-01 12:29:29 -05:00
|
|
|
|
(lambda (opt name arg result . rest)
|
|
|
|
|
(apply values
|
|
|
|
|
(alist-cons 'max-silent-time (string->number* arg)
|
|
|
|
|
result)
|
|
|
|
|
rest)))
|
2014-03-09 18:09:18 -04:00
|
|
|
|
(option '("timeout") #t #f
|
|
|
|
|
(lambda (opt name arg result . rest)
|
|
|
|
|
(apply values
|
|
|
|
|
(alist-cons 'timeout (string->number* arg) result)
|
|
|
|
|
rest)))
|
2012-12-15 09:21:38 -05:00
|
|
|
|
(option '("verbosity") #t #f
|
2014-03-01 12:29:29 -05:00
|
|
|
|
(lambda (opt name arg result . rest)
|
2012-12-15 09:21:38 -05:00
|
|
|
|
(let ((level (string->number arg)))
|
2014-03-01 12:29:29 -05:00
|
|
|
|
(apply values
|
|
|
|
|
(alist-cons 'verbosity level
|
|
|
|
|
(alist-delete 'verbosity result))
|
|
|
|
|
rest))))
|
guix build: Factorize common options.
* guix/scripts/build.scm (show-build-options-help,
set-build-options-from-command-line): New procedures.
(show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%standard-build-options): New variable.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(guix-build): Use 'set-build-options-from-command-line' instead of
'set-build-options'.
* guix/scripts/archive.scm (show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(export-from-store): Call 'set-build-options-from-command-line'
instead of 'set-build-options.
2014-02-17 18:13:06 -05:00
|
|
|
|
(option '(#\c "cores") #t #f
|
2014-03-01 12:29:29 -05:00
|
|
|
|
(lambda (opt name arg result . rest)
|
guix build: Factorize common options.
* guix/scripts/build.scm (show-build-options-help,
set-build-options-from-command-line): New procedures.
(show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%standard-build-options): New variable.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(guix-build): Use 'set-build-options-from-command-line' instead of
'set-build-options'.
* guix/scripts/archive.scm (show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(export-from-store): Call 'set-build-options-from-command-line'
instead of 'set-build-options.
2014-02-17 18:13:06 -05:00
|
|
|
|
(let ((c (false-if-exception (string->number arg))))
|
|
|
|
|
(if c
|
2014-03-01 12:29:29 -05:00
|
|
|
|
(apply values (alist-cons 'cores c result) rest)
|
2014-11-25 16:32:26 -05:00
|
|
|
|
(leave (_ "not a number: '~a' option argument: ~a~%")
|
|
|
|
|
name arg)))))
|
|
|
|
|
(option '(#\M "max-jobs") #t #f
|
|
|
|
|
(lambda (opt name arg result . rest)
|
|
|
|
|
(let ((c (false-if-exception (string->number arg))))
|
|
|
|
|
(if c
|
|
|
|
|
(apply values (alist-cons 'max-jobs c result) rest)
|
|
|
|
|
(leave (_ "not a number: '~a' option argument: ~a~%")
|
|
|
|
|
name arg)))))))
|
guix build: Factorize common options.
* guix/scripts/build.scm (show-build-options-help,
set-build-options-from-command-line): New procedures.
(show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%standard-build-options): New variable.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(guix-build): Use 'set-build-options-from-command-line' instead of
'set-build-options'.
* guix/scripts/archive.scm (show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(export-from-store): Call 'set-build-options-from-command-line'
instead of 'set-build-options.
2014-02-17 18:13:06 -05:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
;;;
|
|
|
|
|
;;; Command-line options.
|
|
|
|
|
;;;
|
|
|
|
|
|
|
|
|
|
(define %default-options
|
|
|
|
|
;; Alist of default option values.
|
|
|
|
|
`((system . ,(%current-system))
|
2015-12-09 05:04:57 -05:00
|
|
|
|
(build-mode . ,(build-mode normal))
|
packages: Implement grafts.
Thanks to Mark H. Weaver <mhw@netris.org> for insightful discussions
and suggestions.
* guix/packages.scm (<package>)[graft]: New field.
(patch-and-repack): Invoke 'package-derivation' with #:graft? #f.
(package-source-derivation): Likewise. Do not use (%guile-for-build)
in call to 'patch-and-repack', and we could end up using a grafted
Guile.
(expand-input): Likewise, also for 'package-cross-derivation' call.
(package->bag): Add #:graft? parameter. Honor it. Use 'strip-append'
instead of 'package-full-name'.
(input-graft, input-cross-graft, bag-grafts, package-grafts): New
procedures.
(package-derivation, package-cross-derivation): Add #:graft? parameter
and honor it.
* gnu/packages/bootstrap.scm (package-with-bootstrap-guile): Add
recursive call on 'graft'.
* guix/build-system/gnu.scm (package-with-explicit-inputs,
package-with-extra-configure-variable, static-package): Likewise.
(gnu-build): Use the ungrafted Guile to avoid full rebuilds.
(gnu-cross-build): Likewise.
* guix/build-system/cmake.scm (cmake-build): Likewise.
* guix/build-system/glib-or-gtk.scm (glib-or-gtk-build): Likewise.
* guix/build-system/perl.scm (perl-build): Likewise.
* guix/build-system/python.scm (python-build): Likewise.
* guix/build-system/ruby.scm (ruby-build): Likewise.
* guix/build-system/trivial.scm (guile-for-build): Likewise.
* tests/packages.scm ("package-derivation, direct graft",
"package-cross-derivation, direct graft", "package-grafts,
indirect grafts", "package-grafts, indirect grafts, cross",
"package-grafts, indirect grafts, propagated inputs",
"package-derivation, indirect grafts"): New tests.
("bag->derivation", "bag->derivation, cross-compilation"): Wrap in
'parameterize'.
* doc/guix.texi (Security Updates): New node.
(Invoking guix build): Document --no-graft.
2014-10-27 13:09:00 -04:00
|
|
|
|
(graft? . #t)
|
guix build: Factorize common options.
* guix/scripts/build.scm (show-build-options-help,
set-build-options-from-command-line): New procedures.
(show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%standard-build-options): New variable.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(guix-build): Use 'set-build-options-from-command-line' instead of
'set-build-options'.
* guix/scripts/archive.scm (show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(export-from-store): Call 'set-build-options-from-command-line'
instead of 'set-build-options.
2014-02-17 18:13:06 -05:00
|
|
|
|
(substitutes? . #t)
|
|
|
|
|
(build-hook? . #t)
|
2014-06-09 12:54:52 -04:00
|
|
|
|
(print-build-trace? . #t)
|
guix build: Factorize common options.
* guix/scripts/build.scm (show-build-options-help,
set-build-options-from-command-line): New procedures.
(show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%standard-build-options): New variable.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(guix-build): Use 'set-build-options-from-command-line' instead of
'set-build-options'.
* guix/scripts/archive.scm (show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(export-from-store): Call 'set-build-options-from-command-line'
instead of 'set-build-options.
2014-02-17 18:13:06 -05:00
|
|
|
|
(max-silent-time . 3600)
|
|
|
|
|
(verbosity . 0)))
|
|
|
|
|
|
|
|
|
|
(define (show-help)
|
|
|
|
|
(display (_ "Usage: guix build [OPTION]... PACKAGE-OR-DERIVATION...
|
|
|
|
|
Build the given PACKAGE-OR-DERIVATION and return their output paths.\n"))
|
|
|
|
|
(display (_ "
|
|
|
|
|
-e, --expression=EXPR build the package or derivation EXPR evaluates to"))
|
|
|
|
|
(display (_ "
|
2015-10-26 18:09:28 -04:00
|
|
|
|
-f, --file=FILE build the package or derivation that the code within
|
|
|
|
|
FILE evaluates to"))
|
|
|
|
|
(display (_ "
|
guix build: Factorize common options.
* guix/scripts/build.scm (show-build-options-help,
set-build-options-from-command-line): New procedures.
(show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%standard-build-options): New variable.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(guix-build): Use 'set-build-options-from-command-line' instead of
'set-build-options'.
* guix/scripts/archive.scm (show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(export-from-store): Call 'set-build-options-from-command-line'
instead of 'set-build-options.
2014-02-17 18:13:06 -05:00
|
|
|
|
-S, --source build the packages' source derivations"))
|
|
|
|
|
(display (_ "
|
2015-05-04 15:16:28 -04:00
|
|
|
|
--sources[=TYPE] build source derivations; TYPE may optionally be one
|
2015-01-28 14:33:28 -05:00
|
|
|
|
of \"package\", \"all\" (default), or \"transitive\""))
|
|
|
|
|
(display (_ "
|
guix build: Factorize common options.
* guix/scripts/build.scm (show-build-options-help,
set-build-options-from-command-line): New procedures.
(show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%standard-build-options): New variable.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(guix-build): Use 'set-build-options-from-command-line' instead of
'set-build-options'.
* guix/scripts/archive.scm (show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(export-from-store): Call 'set-build-options-from-command-line'
instead of 'set-build-options.
2014-02-17 18:13:06 -05:00
|
|
|
|
-s, --system=SYSTEM attempt to build for SYSTEM--e.g., \"i686-linux\""))
|
|
|
|
|
(display (_ "
|
|
|
|
|
--target=TRIPLET cross-build for TRIPLET--e.g., \"armel-linux-gnu\""))
|
|
|
|
|
(display (_ "
|
|
|
|
|
-d, --derivations return the derivation paths of the given packages"))
|
2015-12-09 05:04:57 -05:00
|
|
|
|
(display (_ "
|
|
|
|
|
--check rebuild items to check for non-determinism issues"))
|
guix build: Factorize common options.
* guix/scripts/build.scm (show-build-options-help,
set-build-options-from-command-line): New procedures.
(show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%standard-build-options): New variable.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(guix-build): Use 'set-build-options-from-command-line' instead of
'set-build-options'.
* guix/scripts/archive.scm (show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(export-from-store): Call 'set-build-options-from-command-line'
instead of 'set-build-options.
2014-02-17 18:13:06 -05:00
|
|
|
|
(display (_ "
|
|
|
|
|
-r, --root=FILE make FILE a symlink to the result, and register it
|
|
|
|
|
as a garbage collector root"))
|
2016-03-08 16:00:17 -05:00
|
|
|
|
(display (_ "
|
|
|
|
|
-q, --quiet do not show the build log"))
|
guix build: Factorize common options.
* guix/scripts/build.scm (show-build-options-help,
set-build-options-from-command-line): New procedures.
(show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%standard-build-options): New variable.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(guix-build): Use 'set-build-options-from-command-line' instead of
'set-build-options'.
* guix/scripts/archive.scm (show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(export-from-store): Call 'set-build-options-from-command-line'
instead of 'set-build-options.
2014-02-17 18:13:06 -05:00
|
|
|
|
(display (_ "
|
|
|
|
|
--log-file return the log file names for the given derivations"))
|
|
|
|
|
(newline)
|
|
|
|
|
(show-build-options-help)
|
|
|
|
|
(newline)
|
2016-01-31 14:44:21 -05:00
|
|
|
|
(show-transformation-options-help)
|
|
|
|
|
(newline)
|
guix build: Factorize common options.
* guix/scripts/build.scm (show-build-options-help,
set-build-options-from-command-line): New procedures.
(show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%standard-build-options): New variable.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(guix-build): Use 'set-build-options-from-command-line' instead of
'set-build-options'.
* guix/scripts/archive.scm (show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(export-from-store): Call 'set-build-options-from-command-line'
instead of 'set-build-options.
2014-02-17 18:13:06 -05:00
|
|
|
|
(display (_ "
|
|
|
|
|
-h, --help display this help and exit"))
|
|
|
|
|
(display (_ "
|
|
|
|
|
-V, --version display version information and exit"))
|
|
|
|
|
(newline)
|
|
|
|
|
(show-bug-report-information))
|
|
|
|
|
|
|
|
|
|
(define %options
|
|
|
|
|
;; Specifications of the command-line options.
|
|
|
|
|
(cons* (option '(#\h "help") #f #f
|
|
|
|
|
(lambda args
|
|
|
|
|
(show-help)
|
|
|
|
|
(exit 0)))
|
|
|
|
|
(option '(#\V "version") #f #f
|
|
|
|
|
(lambda args
|
|
|
|
|
(show-version-and-exit "guix build")))
|
|
|
|
|
(option '(#\S "source") #f #f
|
|
|
|
|
(lambda (opt name arg result)
|
2015-01-28 14:33:28 -05:00
|
|
|
|
(alist-cons 'source #t result)))
|
|
|
|
|
(option '("sources") #f #t
|
|
|
|
|
(lambda (opt name arg result)
|
|
|
|
|
(match arg
|
|
|
|
|
("package"
|
|
|
|
|
(alist-cons 'source #t result))
|
|
|
|
|
((or "all" #f)
|
|
|
|
|
(alist-cons 'source package-direct-sources result))
|
|
|
|
|
("transitive"
|
|
|
|
|
(alist-cons 'source package-transitive-sources result))
|
|
|
|
|
(else
|
|
|
|
|
(leave (_ "invalid argument: '~a' option argument: ~a, ~
|
|
|
|
|
must be one of 'package', 'all', or 'transitive'~%")
|
|
|
|
|
name arg)))))
|
2016-01-31 14:44:21 -05:00
|
|
|
|
(option '("check") #f #f
|
|
|
|
|
(lambda (opt name arg result . rest)
|
|
|
|
|
(apply values
|
|
|
|
|
(alist-cons 'build-mode (build-mode check)
|
|
|
|
|
result)
|
|
|
|
|
rest)))
|
guix build: Factorize common options.
* guix/scripts/build.scm (show-build-options-help,
set-build-options-from-command-line): New procedures.
(show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%standard-build-options): New variable.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(guix-build): Use 'set-build-options-from-command-line' instead of
'set-build-options'.
* guix/scripts/archive.scm (show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(export-from-store): Call 'set-build-options-from-command-line'
instead of 'set-build-options.
2014-02-17 18:13:06 -05:00
|
|
|
|
(option '(#\s "system") #t #f
|
|
|
|
|
(lambda (opt name arg result)
|
|
|
|
|
(alist-cons 'system arg
|
|
|
|
|
(alist-delete 'system result eq?))))
|
|
|
|
|
(option '("target") #t #f
|
|
|
|
|
(lambda (opt name arg result)
|
|
|
|
|
(alist-cons 'target arg
|
|
|
|
|
(alist-delete 'target result eq?))))
|
|
|
|
|
(option '(#\d "derivations") #f #f
|
|
|
|
|
(lambda (opt name arg result)
|
|
|
|
|
(alist-cons 'derivations-only? #t result)))
|
|
|
|
|
(option '(#\e "expression") #t #f
|
|
|
|
|
(lambda (opt name arg result)
|
|
|
|
|
(alist-cons 'expression arg result)))
|
2015-10-26 18:09:28 -04:00
|
|
|
|
(option '(#\f "file") #t #f
|
|
|
|
|
(lambda (opt name arg result)
|
|
|
|
|
(alist-cons 'file arg result)))
|
guix build: Factorize common options.
* guix/scripts/build.scm (show-build-options-help,
set-build-options-from-command-line): New procedures.
(show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%standard-build-options): New variable.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(guix-build): Use 'set-build-options-from-command-line' instead of
'set-build-options'.
* guix/scripts/archive.scm (show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(export-from-store): Call 'set-build-options-from-command-line'
instead of 'set-build-options.
2014-02-17 18:13:06 -05:00
|
|
|
|
(option '(#\n "dry-run") #f #f
|
|
|
|
|
(lambda (opt name arg result)
|
|
|
|
|
(alist-cons 'dry-run? #t result)))
|
|
|
|
|
(option '(#\r "root") #t #f
|
|
|
|
|
(lambda (opt name arg result)
|
|
|
|
|
(alist-cons 'gc-root arg result)))
|
2016-03-08 16:00:17 -05:00
|
|
|
|
(option '(#\q "quiet") #f #f
|
|
|
|
|
(lambda (opt name arg result)
|
|
|
|
|
(alist-cons 'quiet? #t result)))
|
guix build: Factorize common options.
* guix/scripts/build.scm (show-build-options-help,
set-build-options-from-command-line): New procedures.
(show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%standard-build-options): New variable.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(guix-build): Use 'set-build-options-from-command-line' instead of
'set-build-options'.
* guix/scripts/archive.scm (show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(export-from-store): Call 'set-build-options-from-command-line'
instead of 'set-build-options.
2014-02-17 18:13:06 -05:00
|
|
|
|
(option '("log-file") #f #f
|
|
|
|
|
(lambda (opt name arg result)
|
|
|
|
|
(alist-cons 'log-file? #t result)))
|
|
|
|
|
|
2016-01-31 14:44:21 -05:00
|
|
|
|
(append %transformation-options
|
|
|
|
|
%standard-build-options)))
|
2012-06-30 18:56:24 -04:00
|
|
|
|
|
2015-11-30 16:07:35 -05:00
|
|
|
|
(define (options->things-to-build opts)
|
|
|
|
|
"Read the arguments from OPTS and return a list of high-level objects to
|
|
|
|
|
build---packages, gexps, derivations, and so on."
|
2015-12-13 15:13:16 -05:00
|
|
|
|
(define (validate-type x)
|
|
|
|
|
(unless (or (package? x) (derivation? x) (gexp? x) (procedure? x))
|
|
|
|
|
(leave (_ "~s: not something we can build~%") x)))
|
|
|
|
|
|
|
|
|
|
(define (ensure-list x)
|
|
|
|
|
(let ((lst (match x
|
|
|
|
|
((x ...) x)
|
|
|
|
|
(x (list x)))))
|
|
|
|
|
(for-each validate-type lst)
|
|
|
|
|
lst))
|
2015-11-30 16:07:35 -05:00
|
|
|
|
|
|
|
|
|
(append-map (match-lambda
|
|
|
|
|
(('argument . (? string? spec))
|
|
|
|
|
(cond ((derivation-path? spec)
|
|
|
|
|
(list (call-with-input-file spec read-derivation)))
|
|
|
|
|
((store-path? spec)
|
|
|
|
|
;; Nothing to do; maybe for --log-file.
|
|
|
|
|
'())
|
|
|
|
|
(else
|
|
|
|
|
(list (specification->package spec)))))
|
|
|
|
|
(('file . file)
|
|
|
|
|
(ensure-list (load* file (make-user-module '()))))
|
|
|
|
|
(('expression . str)
|
|
|
|
|
(ensure-list (read/eval str)))
|
|
|
|
|
(('argument . (? derivation? drv))
|
|
|
|
|
drv)
|
|
|
|
|
(_ '()))
|
|
|
|
|
opts))
|
|
|
|
|
|
2013-12-21 16:53:58 -05:00
|
|
|
|
(define (options->derivations store opts)
|
|
|
|
|
"Given OPTS, the result of 'args-fold', return a list of derivations to
|
|
|
|
|
build."
|
2015-11-30 16:07:35 -05:00
|
|
|
|
(define transform
|
|
|
|
|
(options->transformation opts))
|
|
|
|
|
|
2013-12-21 16:53:58 -05:00
|
|
|
|
(define package->derivation
|
|
|
|
|
(match (assoc-ref opts 'target)
|
|
|
|
|
(#f package-derivation)
|
|
|
|
|
(triplet
|
|
|
|
|
(cut package-cross-derivation <> <> triplet <>))))
|
|
|
|
|
|
2015-01-28 14:33:28 -05:00
|
|
|
|
(define src (assoc-ref opts 'source))
|
2015-11-30 16:07:35 -05:00
|
|
|
|
(define system (assoc-ref opts 'system))
|
packages: Implement grafts.
Thanks to Mark H. Weaver <mhw@netris.org> for insightful discussions
and suggestions.
* guix/packages.scm (<package>)[graft]: New field.
(patch-and-repack): Invoke 'package-derivation' with #:graft? #f.
(package-source-derivation): Likewise. Do not use (%guile-for-build)
in call to 'patch-and-repack', and we could end up using a grafted
Guile.
(expand-input): Likewise, also for 'package-cross-derivation' call.
(package->bag): Add #:graft? parameter. Honor it. Use 'strip-append'
instead of 'package-full-name'.
(input-graft, input-cross-graft, bag-grafts, package-grafts): New
procedures.
(package-derivation, package-cross-derivation): Add #:graft? parameter
and honor it.
* gnu/packages/bootstrap.scm (package-with-bootstrap-guile): Add
recursive call on 'graft'.
* guix/build-system/gnu.scm (package-with-explicit-inputs,
package-with-extra-configure-variable, static-package): Likewise.
(gnu-build): Use the ungrafted Guile to avoid full rebuilds.
(gnu-cross-build): Likewise.
* guix/build-system/cmake.scm (cmake-build): Likewise.
* guix/build-system/glib-or-gtk.scm (glib-or-gtk-build): Likewise.
* guix/build-system/perl.scm (perl-build): Likewise.
* guix/build-system/python.scm (python-build): Likewise.
* guix/build-system/ruby.scm (ruby-build): Likewise.
* guix/build-system/trivial.scm (guile-for-build): Likewise.
* tests/packages.scm ("package-derivation, direct graft",
"package-cross-derivation, direct graft", "package-grafts,
indirect grafts", "package-grafts, indirect grafts, cross",
"package-grafts, indirect grafts, propagated inputs",
"package-derivation, indirect grafts"): New tests.
("bag->derivation", "bag->derivation, cross-compilation"): Wrap in
'parameterize'.
* doc/guix.texi (Security Updates): New node.
(Invoking guix build): Document --no-graft.
2014-10-27 13:09:00 -04:00
|
|
|
|
(define graft? (assoc-ref opts 'graft?))
|
2013-12-21 16:53:58 -05:00
|
|
|
|
|
packages: Implement grafts.
Thanks to Mark H. Weaver <mhw@netris.org> for insightful discussions
and suggestions.
* guix/packages.scm (<package>)[graft]: New field.
(patch-and-repack): Invoke 'package-derivation' with #:graft? #f.
(package-source-derivation): Likewise. Do not use (%guile-for-build)
in call to 'patch-and-repack', and we could end up using a grafted
Guile.
(expand-input): Likewise, also for 'package-cross-derivation' call.
(package->bag): Add #:graft? parameter. Honor it. Use 'strip-append'
instead of 'package-full-name'.
(input-graft, input-cross-graft, bag-grafts, package-grafts): New
procedures.
(package-derivation, package-cross-derivation): Add #:graft? parameter
and honor it.
* gnu/packages/bootstrap.scm (package-with-bootstrap-guile): Add
recursive call on 'graft'.
* guix/build-system/gnu.scm (package-with-explicit-inputs,
package-with-extra-configure-variable, static-package): Likewise.
(gnu-build): Use the ungrafted Guile to avoid full rebuilds.
(gnu-cross-build): Likewise.
* guix/build-system/cmake.scm (cmake-build): Likewise.
* guix/build-system/glib-or-gtk.scm (glib-or-gtk-build): Likewise.
* guix/build-system/perl.scm (perl-build): Likewise.
* guix/build-system/python.scm (python-build): Likewise.
* guix/build-system/ruby.scm (ruby-build): Likewise.
* guix/build-system/trivial.scm (guile-for-build): Likewise.
* tests/packages.scm ("package-derivation, direct graft",
"package-cross-derivation, direct graft", "package-grafts,
indirect grafts", "package-grafts, indirect grafts, cross",
"package-grafts, indirect grafts, propagated inputs",
"package-derivation, indirect grafts"): New tests.
("bag->derivation", "bag->derivation, cross-compilation"): Wrap in
'parameterize'.
* doc/guix.texi (Security Updates): New node.
(Invoking guix build): Document --no-graft.
2014-10-27 13:09:00 -04:00
|
|
|
|
(parameterize ((%graft? graft?))
|
2015-11-30 16:07:35 -05:00
|
|
|
|
(append-map (match-lambda
|
|
|
|
|
((? package? p)
|
2016-03-02 17:57:23 -05:00
|
|
|
|
(let ((p (or (and graft? (package-replacement p)) p)))
|
|
|
|
|
(match src
|
|
|
|
|
(#f
|
|
|
|
|
(list (package->derivation store p system)))
|
|
|
|
|
(#t
|
|
|
|
|
(let ((s (package-source p)))
|
|
|
|
|
(list (package-source-derivation store s))))
|
|
|
|
|
(proc
|
|
|
|
|
(map (cut package-source-derivation store <>)
|
|
|
|
|
(proc p))))))
|
2015-11-30 16:07:35 -05:00
|
|
|
|
((? derivation? drv)
|
|
|
|
|
(list drv))
|
|
|
|
|
((? procedure? proc)
|
|
|
|
|
(list (run-with-store store
|
|
|
|
|
(mbegin %store-monad
|
|
|
|
|
(set-guile-for-build (default-guile))
|
|
|
|
|
(proc))
|
|
|
|
|
#:system system)))
|
|
|
|
|
((? gexp? gexp)
|
|
|
|
|
(list (run-with-store store
|
|
|
|
|
(mbegin %store-monad
|
|
|
|
|
(set-guile-for-build (default-guile))
|
|
|
|
|
(gexp->derivation "gexp" gexp
|
|
|
|
|
#:system system))))))
|
2016-01-31 14:18:52 -05:00
|
|
|
|
(map (cut transform store <>)
|
|
|
|
|
(options->things-to-build opts)))))
|
2015-11-30 16:07:35 -05:00
|
|
|
|
|
2015-11-29 11:42:01 -05:00
|
|
|
|
(define (show-build-log store file urls)
|
|
|
|
|
"Show the build log for FILE, falling back to remote logs from URLS if
|
|
|
|
|
needed."
|
|
|
|
|
(let ((log (or (log-file store file)
|
|
|
|
|
(log-url store file #:base-urls urls))))
|
|
|
|
|
(if log
|
|
|
|
|
(format #t "~a~%" log)
|
|
|
|
|
(leave (_ "no build log for '~a'~%") file))))
|
|
|
|
|
|
2012-06-30 18:56:24 -04:00
|
|
|
|
|
|
|
|
|
;;;
|
|
|
|
|
;;; Entry point.
|
|
|
|
|
;;;
|
|
|
|
|
|
|
|
|
|
(define (guix-build . args)
|
2016-03-04 11:50:30 -05:00
|
|
|
|
(define opts
|
|
|
|
|
(parse-command-line args %options
|
|
|
|
|
(list %default-options)))
|
|
|
|
|
|
2016-03-08 16:00:17 -05:00
|
|
|
|
(define quiet?
|
|
|
|
|
(assoc-ref opts 'quiet?))
|
|
|
|
|
|
2012-10-31 19:50:01 -04:00
|
|
|
|
(with-error-handling
|
2013-11-11 19:06:25 -05:00
|
|
|
|
;; Ask for absolute file names so that .drv file names passed from the
|
|
|
|
|
;; user to 'read-derivation' are absolute when it returns.
|
|
|
|
|
(with-fluids ((%file-port-name-canonicalization 'absolute))
|
2016-03-04 11:50:30 -05:00
|
|
|
|
(with-store store
|
|
|
|
|
;; Set the build options before we do anything else.
|
guix build: Factorize common options.
* guix/scripts/build.scm (show-build-options-help,
set-build-options-from-command-line): New procedures.
(show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%standard-build-options): New variable.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(guix-build): Use 'set-build-options-from-command-line' instead of
'set-build-options'.
* guix/scripts/archive.scm (show-help): Remove description of --dry-run,
--fallback, --no-substitutes, --max-silent-time, and --cores. Call
'show-build-options-help'.
(%options): Remove --dry-run, --fallback, --no-substitutes,
--verbosity, --max-silent-time, and --cores. Add
%STANDARD-BUILD-OPTIONS.
(export-from-store): Call 'set-build-options-from-command-line'
instead of 'set-build-options.
2014-02-17 18:13:06 -05:00
|
|
|
|
(set-build-options-from-command-line store opts)
|
2016-03-04 11:50:30 -05:00
|
|
|
|
|
2016-03-08 16:00:17 -05:00
|
|
|
|
(parameterize ((current-build-output-port (if quiet?
|
|
|
|
|
(%make-void-port "w")
|
|
|
|
|
(current-error-port))))
|
|
|
|
|
(let* ((mode (assoc-ref opts 'build-mode))
|
|
|
|
|
(drv (options->derivations store opts))
|
|
|
|
|
(urls (map (cut string-append <> "/log")
|
|
|
|
|
(if (assoc-ref opts 'substitutes?)
|
|
|
|
|
(or (assoc-ref opts 'substitute-urls)
|
|
|
|
|
;; XXX: This does not necessarily match the
|
|
|
|
|
;; daemon's substitute URLs.
|
|
|
|
|
%default-substitute-urls)
|
|
|
|
|
'())))
|
|
|
|
|
(items (filter-map (match-lambda
|
|
|
|
|
(('argument . (? store-path? file))
|
|
|
|
|
file)
|
|
|
|
|
(_ #f))
|
|
|
|
|
opts))
|
|
|
|
|
(roots (filter-map (match-lambda
|
|
|
|
|
(('gc-root . root) root)
|
|
|
|
|
(_ #f))
|
|
|
|
|
opts)))
|
|
|
|
|
|
|
|
|
|
(unless (assoc-ref opts 'log-file?)
|
|
|
|
|
(show-what-to-build store drv
|
|
|
|
|
#:use-substitutes?
|
|
|
|
|
(assoc-ref opts 'substitutes?)
|
|
|
|
|
#:dry-run? (assoc-ref opts 'dry-run?)
|
|
|
|
|
#:mode mode))
|
|
|
|
|
|
|
|
|
|
(cond ((assoc-ref opts 'log-file?)
|
|
|
|
|
(for-each (cut show-build-log store <> urls)
|
|
|
|
|
(delete-duplicates
|
|
|
|
|
(append (map derivation-file-name drv)
|
|
|
|
|
items))))
|
|
|
|
|
((assoc-ref opts 'derivations-only?)
|
|
|
|
|
(format #t "~{~a~%~}" (map derivation-file-name drv))
|
|
|
|
|
(for-each (cut register-root store <> <>)
|
|
|
|
|
(map (compose list derivation-file-name) drv)
|
|
|
|
|
roots))
|
|
|
|
|
((not (assoc-ref opts 'dry-run?))
|
|
|
|
|
(and (build-derivations store drv mode)
|
|
|
|
|
(for-each show-derivation-outputs drv)
|
|
|
|
|
(for-each (cut register-root store <> <>)
|
|
|
|
|
(map (lambda (drv)
|
|
|
|
|
(map cdr
|
|
|
|
|
(derivation->output-paths drv)))
|
|
|
|
|
drv)
|
|
|
|
|
roots))))))))))
|