[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
15/15: gnu: Boost: Use #:configure-flags.
From: |
guix-commits |
Subject: |
15/15: gnu: Boost: Use #:configure-flags. |
Date: |
Tue, 5 Jul 2022 18:38:51 -0400 (EDT) |
mbakke pushed a commit to branch core-updates
in repository guix.
commit eb32bcea32c419f7b501fe292535d4b65d6031d6
Author: Marius Bakke <marius@gnu.org>
AuthorDate: Tue Jul 5 23:53:35 2022 +0200
gnu: Boost: Use #:configure-flags.
* gnu/packages/boost.scm (boost)[arguments]: Add #:configure-flags. Adjust
configure phase accordingly. Split out shell patching to separate phase.
While at it, remove obsolete GNU/Hurd substitution.
(boost-for-mysql)[arguments]: Adjust accordingly.
---
gnu/packages/boost.scm | 123 ++++++++++++++++++++++---------------------------
1 file changed, 55 insertions(+), 68 deletions(-)
diff --git a/gnu/packages/boost.scm b/gnu/packages/boost.scm
index bb8789bc28..2aab222d4a 100644
--- a/gnu/packages/boost.scm
+++ b/gnu/packages/boost.scm
@@ -99,6 +99,25 @@
#:modules `(((guix build python-build-system) #:select (python-version))
,@%gnu-build-system-modules)
#:tests? #f
+ #:configure-flags
+ #~(let ((icu (dirname (dirname (search-input-file
+ %build-inputs "bin/uconv")))))
+ (list
+ ;; Auto-detection looks for ICU only in traditional
+ ;; install locations.
+ (string-append "--with-icu=" icu)
+ ;; Ditto for Python.
+ #$@(if (%current-target-system)
+ #~()
+ #~((let ((python (dirname (dirname (search-input-file
+ %build-inputs
+ "bin/python")))))
+ (string-append "--with-python-root=" python)
+ (string-append "--with-python=" python
+ "/bin/python")
+ (string-append "--with-python-version="
+ (python-version python)))))
+ "--with-toolset=gcc"))
#:make-flags
#~(list "threading=multi" "link=shared"
@@ -124,49 +143,29 @@
#~()))
#:phases
#~(modify-phases %standard-phases
+ (add-after 'unpack 'patch-shells
+ (lambda _
+ (substitute* '("libs/config/configure"
+ "libs/spirit/classic/phoenix/test/runtest.sh"
+ "tools/build/src/engine/execunix.cpp")
+ (("/bin/sh") (which "sh")))))
(delete 'bootstrap)
(replace 'configure
- (lambda* (#:key inputs #:allow-other-keys)
- (let ((icu (dirname (dirname (search-input-file
- inputs "bin/uconv")))))
- (substitute* '("libs/config/configure"
- "libs/spirit/classic/phoenix/test/runtest.sh"
- "tools/build/src/engine/execunix.cpp")
- (("/bin/sh") (which "sh")))
+ (lambda* (#:key (configure-flags ''()) #:allow-other-keys)
+ (setenv "SHELL" (which "sh"))
+ (setenv "CONFIG_SHELL" (which "sh"))
- (setenv "SHELL" (which "sh"))
- (setenv "CONFIG_SHELL" (which "sh"))
-
- #$@(if (%current-target-system)
- #~((call-with-output-file "user-config.jam"
- (lambda (port)
- (format port
- "using gcc : cross : ~a-c++ ;"
- #$(%current-target-system)))))
- #~())
-
- ;; Change an #ifdef __MACH__ that really targets macOS.
- (substitute* "boost/test/utils/timer.hpp"
- (("defined\\(__MACH__\\)")
- "(defined __MACH__ && !defined __GNU__)"))
+ #$@(if (%current-target-system)
+ #~((call-with-output-file "user-config.jam"
+ (lambda (port)
+ (format port
+ "using gcc : cross : ~a-c++ ;"
+ #$(%current-target-system)))))
+ #~())
- (invoke "./bootstrap.sh"
- (string-append "--prefix=" #$output)
- ;; Auto-detection looks for ICU only in traditional
- ;; install locations.
- (string-append "--with-icu=" #$output)
- ;; Ditto for Python.
- #$@(if (%current-target-system)
- #~()
- #~((let ((python (dirname (dirname
(search-input-file
- inputs
-
"bin/python")))))
- (string-append "--with-python-root="
python)
- (string-append "--with-python=" python
- "/bin/python")
- (string-append "--with-python-version="
- (python-version python)))))
- "--with-toolset=gcc"))))
+ (apply invoke "./bootstrap.sh"
+ (string-append "--prefix=" #$output)
+ configure-flags)))
(replace 'build
(lambda* (#:key make-flags #:allow-other-keys)
(apply invoke "./b2"
@@ -317,37 +316,25 @@ across a broad spectrum of applications.")
"1jj1aai5rdmd72g90a3pd8sw9vi32zad46xv5av8fhnr48ir6ykj"))))
(arguments
(substitute-keyword-arguments (package-arguments boost)
+ ((#:configure-flags _ #~'())
+ #~(let ((icu (dirname (dirname (search-input-file
+ %build-inputs "bin/uconv")))))
+ (list
+ ;; Auto-detection looks for ICU only in traditional
+ ;; install locations.
+ (string-append "--with-icu=" icu)
+ "--with-toolset=gcc")))
((#:phases phases)
#~(modify-phases #$phases
- (replace 'configure
- (lambda* (#:key inputs outputs #:allow-other-keys)
- (let ((icu (dirname (dirname (search-input-file
- inputs "bin/uconv")))))
- (substitute* (append
- (find-files "tools/build/src/engine/"
"execunix\\.c.*")
- '("libs/config/configure"
- "libs/spirit/classic/phoenix/test/runtest.sh"
- "tools/build/doc/bjam.qbk"
- "tools/build/src/engine/Jambase"))
- (("/bin/sh") (which "sh")))
-
- (setenv "SHELL" (which "sh"))
- (setenv "CONFIG_SHELL" (which "sh"))
-
- #$@(if (%current-target-system)
- #~((call-with-output-file "user-config.jam"
- (lambda (port)
- (format port
- "using gcc : cross : ~a-c++ ;"
- #$(%current-target-system)))))
- #~())
-
- (invoke "./bootstrap.sh"
- (string-append "--prefix=" #$output)
- ;; Auto-detection looks for ICU only in traditional
- ;; install locations.
- (string-append "--with-icu=" icu)
- "--with-toolset=gcc"))))
+ (replace 'patch-shells
+ (lambda _
+ (substitute* (append
+ (find-files "tools/build/src/engine/"
"execunix\\.c.*")
+ '("libs/config/configure"
+ "libs/spirit/classic/phoenix/test/runtest.sh"
+ "tools/build/doc/bjam.qbk"
+ "tools/build/src/engine/Jambase"))
+ (("/bin/sh") (which "sh")))))
(delete 'provide-libboost_python)))
((#:make-flags make-flags)
#~(cons* "--without-python" #$make-flags))))
- 01/15: gnu: pango: Update to 1.50.7., (continued)
- 01/15: gnu: pango: Update to 1.50.7., guix-commits, 2022/07/05
- 11/15: gnu: boost, boost-static: Consolidate libboost_python phases., guix-commits, 2022/07/05
- 08/15: gnu: gd: Add release-monitoring-url., guix-commits, 2022/07/05
- 12/15: gnu: Boost: Python input is not native., guix-commits, 2022/07/05
- 04/15: gnu: harfbuzz: Update to 4.4.1., guix-commits, 2022/07/05
- 05/15: gnu: Poppler: Disable tests., guix-commits, 2022/07/05
- 07/15: gnu: libvdpau: Update to 1.5., guix-commits, 2022/07/05
- 09/15: gnu: gd: Remove input labels., guix-commits, 2022/07/05
- 10/15: gnu: boost-mpi: Remove input labels., guix-commits, 2022/07/05
- 13/15: gnu: boost-mpi: OpenMPI is not native., guix-commits, 2022/07/05
- 15/15: gnu: Boost: Use #:configure-flags.,
guix-commits <=
- 14/15: gnu: Boost: Avoid usage of 'this-package-input'., guix-commits, 2022/07/05