mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2024-12-25 05:48:07 -05:00
gnu: mingw-w64: Add -winpthreads variants.
This recursive package definition really demonstrates how magical Guix can be :-) Try invoking: ./pre-inst-env guix build mingw-w64-{x86_64,i686}{,-winpthreads} * gnu/packages/mingw.scm (make-mingw-w64): Add XGCC, XBINUTILS optional arguments to specify using a non-default cross-compiler/binutils. Add WITH-WINPTHREADS? optional argument to allow building with winpthreads support. Adjust accordingly for the new arguments. (mingw-w64-i686-winpthreads, mingw-w64-x86_64-winpthreads): Add variables. * gnu/packages/cross-base.scm (native-libc): Add XGCC, XBINUTILS key arugments and pass to MAKE-MINGW-W64. (cross-libc): Pass XGCC and XBINUTILS to NATIVE-LIBC.
This commit is contained in:
parent
8b438f85cf
commit
f5d6c88d0f
2 changed files with 49 additions and 11 deletions
|
@ -454,7 +454,9 @@ (define* (cross-libc target
|
||||||
"Return LIBC cross-built for TARGET, a GNU triplet. Use XGCC and XBINUTILS
|
"Return LIBC cross-built for TARGET, a GNU triplet. Use XGCC and XBINUTILS
|
||||||
and the cross tool chain."
|
and the cross tool chain."
|
||||||
(if (cross-newlib? target libc)
|
(if (cross-newlib? target libc)
|
||||||
(native-libc target libc)
|
(native-libc target libc
|
||||||
|
#:xgcc xgcc
|
||||||
|
#:xbinutils xbinutils)
|
||||||
(let ((libc libc))
|
(let ((libc libc))
|
||||||
(package (inherit libc)
|
(package (inherit libc)
|
||||||
(name (string-append "glibc-cross-" target))
|
(name (string-append "glibc-cross-" target))
|
||||||
|
@ -511,10 +513,15 @@ (define* (cross-libc target
|
||||||
|
|
||||||
(define* (native-libc target
|
(define* (native-libc target
|
||||||
#:optional
|
#:optional
|
||||||
(libc glibc))
|
(libc glibc)
|
||||||
|
#:key
|
||||||
|
xgcc
|
||||||
|
xbinutils)
|
||||||
(if (target-mingw? target)
|
(if (target-mingw? target)
|
||||||
(let ((machine (substring target 0 (string-index target #\-))))
|
(let ((machine (substring target 0 (string-index target #\-))))
|
||||||
(make-mingw-w64 machine))
|
(make-mingw-w64 machine
|
||||||
|
#:xgcc xgcc
|
||||||
|
#:xbinutils xbinutils))
|
||||||
libc))
|
libc))
|
||||||
|
|
||||||
(define* (cross-newlib? target
|
(define* (cross-newlib? target
|
||||||
|
|
|
@ -30,12 +30,21 @@ (define-module (gnu packages mingw)
|
||||||
#:use-module (guix packages)
|
#:use-module (guix packages)
|
||||||
#:use-module (guix download)
|
#:use-module (guix download)
|
||||||
#:use-module (guix utils)
|
#:use-module (guix utils)
|
||||||
#:use-module (ice-9 match))
|
#:use-module (ice-9 match)
|
||||||
|
#:export (make-mingw-w64))
|
||||||
|
|
||||||
(define-public (make-mingw-w64 machine)
|
(define* (make-mingw-w64 machine
|
||||||
(let ((triplet (string-append machine "-" "w64-mingw32")))
|
#:key
|
||||||
|
xgcc
|
||||||
|
xbinutils
|
||||||
|
with-winpthreads?)
|
||||||
|
"Return a mingw-w64 for targeting MACHINE. If XGCC or XBINUTILS is specified,
|
||||||
|
use that gcc or binutils when cross-compiling. If WITH-WINPTHREADS? is
|
||||||
|
specified, recurse and return a mingw-w64 with support for winpthreads."
|
||||||
|
(let* ((triplet (string-append machine "-" "w64-mingw32")))
|
||||||
(package
|
(package
|
||||||
(name (string-append "mingw-w64" "-" machine))
|
(name (string-append "mingw-w64" "-" machine
|
||||||
|
(if with-winpthreads? "-winpthreads" "")))
|
||||||
(version "6.0.0")
|
(version "6.0.0")
|
||||||
(source (origin
|
(source (origin
|
||||||
(method url-fetch)
|
(method url-fetch)
|
||||||
|
@ -45,8 +54,13 @@ (define-public (make-mingw-w64 machine)
|
||||||
(sha256
|
(sha256
|
||||||
(base32 "1w28mynv500y03h92nh87rgw3fnp82qwnjbxrrzqkmr63q812pl0"))
|
(base32 "1w28mynv500y03h92nh87rgw3fnp82qwnjbxrrzqkmr63q812pl0"))
|
||||||
(patches (search-patches "mingw-w64-6.0.0-gcc.patch"))))
|
(patches (search-patches "mingw-w64-6.0.0-gcc.patch"))))
|
||||||
(native-inputs `(("xgcc-core" ,(cross-gcc triplet))
|
(native-inputs `(("xgcc-core" ,(if xgcc xgcc (cross-gcc triplet)))
|
||||||
("xbinutils" ,(cross-binutils triplet))))
|
("xbinutils" ,(if xbinutils xbinutils (cross-binutils triplet)))
|
||||||
|
,@(if with-winpthreads?
|
||||||
|
`(("xlibc" ,(make-mingw-w64 machine
|
||||||
|
#:xgcc xgcc
|
||||||
|
#:xbinutils xbinutils)))
|
||||||
|
'())))
|
||||||
(build-system gnu-build-system)
|
(build-system gnu-build-system)
|
||||||
(search-paths
|
(search-paths
|
||||||
(list (search-path-specification
|
(list (search-path-specification
|
||||||
|
@ -59,7 +73,10 @@ (define-public (make-mingw-w64 machine)
|
||||||
,(string-append triplet "/lib")
|
,(string-append triplet "/lib")
|
||||||
,(string-append triplet "/lib64"))))))
|
,(string-append triplet "/lib64"))))))
|
||||||
(arguments
|
(arguments
|
||||||
`(#:configure-flags '(,(string-append "--host=" triplet))
|
`(#:configure-flags '(,(string-append "--host=" triplet)
|
||||||
|
,@(if with-winpthreads?
|
||||||
|
'("--with-libraries=winpthreads")
|
||||||
|
'()))
|
||||||
#:phases
|
#:phases
|
||||||
(modify-phases %standard-phases
|
(modify-phases %standard-phases
|
||||||
(add-before 'configure 'setenv
|
(add-before 'configure 'setenv
|
||||||
|
@ -74,7 +91,13 @@ (define-public (make-mingw-w64 machine)
|
||||||
":" mingw-headers "/include"
|
":" mingw-headers "/include"
|
||||||
":" mingw-headers "/crt"
|
":" mingw-headers "/crt"
|
||||||
":" mingw-headers "/defaults/include"
|
":" mingw-headers "/defaults/include"
|
||||||
":" mingw-headers "/direct-x/include"))))))
|
":" mingw-headers "/direct-x/include"))
|
||||||
|
(when ,with-winpthreads?
|
||||||
|
(let ((xlibc (assoc-ref inputs "xlibc")))
|
||||||
|
(setenv "CROSS_LIBRARY_PATH"
|
||||||
|
(string-append
|
||||||
|
xlibc "/lib" ":"
|
||||||
|
xlibc "/" ,triplet "/lib"))))))))
|
||||||
#:make-flags (list "DEFS=-DHAVE_CONFIG_H -D__MINGW_HAS_DXSDK=1")
|
#:make-flags (list "DEFS=-DHAVE_CONFIG_H -D__MINGW_HAS_DXSDK=1")
|
||||||
#:tests? #f ; compiles and includes glibc headers
|
#:tests? #f ; compiles and includes glibc headers
|
||||||
#:strip-binaries? #f))
|
#:strip-binaries? #f))
|
||||||
|
@ -98,4 +121,12 @@ (define-public mingw-w64-i686
|
||||||
(define-public mingw-w64-x86_64
|
(define-public mingw-w64-x86_64
|
||||||
(make-mingw-w64 "x86_64"))
|
(make-mingw-w64 "x86_64"))
|
||||||
|
|
||||||
|
(define-public mingw-w64-i686-winpthreads
|
||||||
|
(make-mingw-w64 "i686"
|
||||||
|
#:with-winpthreads? #t))
|
||||||
|
|
||||||
|
(define-public mingw-w64-x86_64-winpthreads
|
||||||
|
(make-mingw-w64 "x86_64"
|
||||||
|
#:with-winpthreads? #t))
|
||||||
|
|
||||||
(define-public mingw-w64 mingw-w64-i686)
|
(define-public mingw-w64 mingw-w64-i686)
|
||||||
|
|
Loading…
Reference in a new issue