transformations: Add '--with-configure-flag'.

* guix/transformations.scm (transform-package-configure-flag): New
procedure.
(%transformation-options, %transformation-options)
(show-transformation-options-help/detailed): Add it.
* tests/transformations.scm ("options->transformation,
with-configure-flag"): New test.
* doc/guix.texi (Package Transformation Options): Document it.

Co-authored-by: Ludovic Courtès <ludo@gnu.org>
This commit is contained in:
Sarthak Shah 2023-04-25 17:52:10 +05:30 committed by Ludovic Courtès
parent b20b7e61a3
commit ae11fcb84a
No known key found for this signature in database
GPG key ID: 090B11993D9AEBB5
3 changed files with 88 additions and 1 deletions

View file

@ -12919,6 +12919,35 @@ guix build coreutils --with-patch=glibc=./glibc-frob.patch
In this example, glibc itself as well as everything that leads to In this example, glibc itself as well as everything that leads to
Coreutils in the dependency graph is rebuilt. Coreutils in the dependency graph is rebuilt.
@cindex configure flags, changing them
@item --with-configure-flag=@var{package}=@var{flag}
Append @var{flag} to the configure flags of @var{package}, where
@var{package} is a spec such as @code{guile@@3.0} or @code{glibc}. The
build system of @var{package} must support the @code{#:configure-flags}
argument.
For example, the command below builds GNU@tie{}Hello with the
configure flag @code{--disable-nls}:
@example
guix build hello --with-configure-flag=hello=--disable-nls
@end example
The following command passes an extra flag to @command{cmake} as it
builds @code{lapack}:
@example
guix build lapack \
--with-configure-flag=lapack=-DBUILD_COMPLEX=OFF
@end example
@quotation Note
Under the hood, this option works by passing the
@samp{#:configure-flags} argument to the build system of the package of
interest (@pxref{Build Systems}). Most build systems support that
option but some do not. In that case, an error is raised.
@end quotation
@cindex upstream, latest version @cindex upstream, latest version
@item --with-latest=@var{package} @item --with-latest=@var{package}
@itemx --with-version=@var{package}=@var{version} @itemx --with-version=@var{package}=@var{version}

View file

@ -1,6 +1,7 @@
;;; GNU Guix --- Functional package management for GNU ;;; GNU Guix --- Functional package management for GNU
;;; Copyright © 2016-2023 Ludovic Courtès <ludo@gnu.org> ;;; Copyright © 2016-2023 Ludovic Courtès <ludo@gnu.org>
;;; Copyright © 2021 Marius Bakke <marius@gnu.org> ;;; Copyright © 2021 Marius Bakke <marius@gnu.org>
;;; Copyright © 2023 Sarthak Shah <shahsarthakw@gmail.com>
;;; ;;;
;;; This file is part of GNU Guix. ;;; This file is part of GNU Guix.
;;; ;;;
@ -676,6 +677,46 @@ (define rewrite
(rewrite obj) (rewrite obj)
obj))) obj)))
(define (transform-package-configure-flag specs)
"Return a procedure that, when passed a package and a flag, adds the flag to
#:configure-flags in the package's 'arguments' field."
(define (package-with-configure-flag p extra-flag)
(package/inherit p
(arguments
(substitute-keyword-arguments (package-arguments p)
((#:configure-flags flags #~'())
;; Add EXTRA-FLAG to the end so it can potentially override FLAGS.
#~(append #$flags '(#$extra-flag)))))))
(define configure-flags
;; Spec/flag alist.
(map (lambda (spec)
;; Split SPEC on the first equal sign (the configure flag might
;; contain equal signs, as in '-DINTSIZE=32').
(let ((equal (string-index spec #\=)))
(match (and equal
(list (string-take spec equal)
(string-drop spec (+ 1 equal))))
((spec flag)
(cons spec flag))
(_
(raise (formatted-message
(G_ "~a: invalid package configure flag specification")
spec))))))
specs))
(define rewrite
(package-input-rewriting/spec
(map (match-lambda
((spec . flags)
(cons spec (cut package-with-configure-flag <> flags))))
configure-flags)))
(lambda (obj)
(if (package? obj)
(rewrite obj)
obj)))
(define (patched-source name source patches) (define (patched-source name source patches)
"Return a file-like object with the given NAME that applies PATCHES to "Return a file-like object with the given NAME that applies PATCHES to
SOURCE. SOURCE must itself be a file-like object of any type, including SOURCE. SOURCE must itself be a file-like object of any type, including
@ -845,6 +886,7 @@ (define %transformations
(tune . ,transform-package-tuning) (tune . ,transform-package-tuning)
(with-debug-info . ,transform-package-with-debug-info) (with-debug-info . ,transform-package-with-debug-info)
(without-tests . ,transform-package-tests) (without-tests . ,transform-package-tests)
(with-configure-flag . ,transform-package-configure-flag)
(with-patch . ,transform-package-patches) (with-patch . ,transform-package-patches)
(with-latest . ,transform-package-latest) (with-latest . ,transform-package-latest)
(with-version . ,transform-package-version))) (with-version . ,transform-package-version)))
@ -915,6 +957,8 @@ (define micro-architecture
(parser 'with-debug-info)) (parser 'with-debug-info))
(option '("without-tests") #t #f (option '("without-tests") #t #f
(parser 'without-tests)) (parser 'without-tests))
(option '("with-configure-flag") #t #f
(parser 'with-configure-flag))
(option '("with-patch") #t #f (option '("with-patch") #t #f
(parser 'with-patch)) (parser 'with-patch))
(option '("with-latest") #t #f (option '("with-latest") #t #f
@ -952,6 +996,9 @@ (define (show-transformation-options-help/detailed)
(display (G_ " (display (G_ "
--with-patch=PACKAGE=FILE --with-patch=PACKAGE=FILE
add FILE to the list of patches of PACKAGE")) add FILE to the list of patches of PACKAGE"))
(display (G_ "
--with-configure-flag=PACKAGE=FLAG
append FLAG to the configure flags of PACKAGE"))
(display (G_ " (display (G_ "
--with-latest=PACKAGE --with-latest=PACKAGE
use the latest upstream release of PACKAGE")) use the latest upstream release of PACKAGE"))

View file

@ -33,7 +33,7 @@ (define-module (test-transformations)
#:use-module ((guix gexp) #:use-module ((guix gexp)
#:select (local-file? local-file-file #:select (local-file? local-file-file
computed-file? computed-file-gexp computed-file? computed-file-gexp
gexp-input-thing)) gexp-input-thing gexp->approximate-sexp))
#:use-module (guix ui) #:use-module (guix ui)
#:use-module (guix utils) #:use-module (guix utils)
#:use-module (guix git) #:use-module (guix git)
@ -408,6 +408,17 @@ (define (package-name* obj)
(package-full-name grep)) (package-full-name grep))
(package-arguments (package-replacement dep0)))))))) (package-arguments (package-replacement dep0))))))))
(test-equal "options->transformation, with-configure-flag"
'(append '() '("--flag=42"))
(let* ((p (dummy-package "foo"
(build-system gnu-build-system)))
(t (options->transformation
'((with-configure-flag . "foo=--flag=42")))))
(let ((new (t p)))
(match (package-arguments new)
((#:configure-flags flags)
(gexp->approximate-sexp flags))))))
(test-assert "options->transformation, without-tests" (test-assert "options->transformation, without-tests"
(let* ((dep (dummy-package "dep")) (let* ((dep (dummy-package "dep"))
(p (dummy-package "foo" (p (dummy-package "foo"