mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2024-12-28 23:32:24 -05:00
build-system/glib-or-gtk: Support cross-compilaton.
* guix/build-system/glib-or-gtk.scm (lower): Add 'implicit-cross-inputs?' argument. Generate a bag when cross-compiling. (glib-or-gtk-cross-build): New procedure.
This commit is contained in:
parent
fa81c31ce9
commit
881a5d26b2
1 changed files with 126 additions and 18 deletions
|
@ -2,6 +2,7 @@
|
||||||
;;; Copyright © 2013, 2014, 2015, 2019, 2020, 2021 Ludovic Courtès <ludo@gnu.org>
|
;;; Copyright © 2013, 2014, 2015, 2019, 2020, 2021 Ludovic Courtès <ludo@gnu.org>
|
||||||
;;; Copyright © 2013 Cyril Roelandt <tipecaml@gmail.com>
|
;;; Copyright © 2013 Cyril Roelandt <tipecaml@gmail.com>
|
||||||
;;; Copyright © 2014 Federico Beffa <beffa@fbengineering.ch>
|
;;; Copyright © 2014 Federico Beffa <beffa@fbengineering.ch>
|
||||||
|
;;; Copyright © 2021 Maxime Devos <maximedevos@telenet.be>
|
||||||
;;;
|
;;;
|
||||||
;;; This file is part of GNU Guix.
|
;;; This file is part of GNU Guix.
|
||||||
;;;
|
;;;
|
||||||
|
@ -31,6 +32,7 @@ (define-module (guix build-system glib-or-gtk)
|
||||||
#:use-module (ice-9 match)
|
#:use-module (ice-9 match)
|
||||||
#:export (%glib-or-gtk-build-system-modules
|
#:export (%glib-or-gtk-build-system-modules
|
||||||
glib-or-gtk-build
|
glib-or-gtk-build
|
||||||
|
glib-or-gtk-cross-build
|
||||||
glib-or-gtk-build-system))
|
glib-or-gtk-build-system))
|
||||||
|
|
||||||
;; Commentary:
|
;; Commentary:
|
||||||
|
@ -82,30 +84,42 @@ (define* (lower name
|
||||||
#:key source inputs native-inputs outputs system target
|
#:key source inputs native-inputs outputs system target
|
||||||
(glib (default-glib))
|
(glib (default-glib))
|
||||||
(implicit-inputs? #t)
|
(implicit-inputs? #t)
|
||||||
|
(implicit-cross-inputs? #t)
|
||||||
(strip-binaries? #t)
|
(strip-binaries? #t)
|
||||||
#:allow-other-keys
|
#:allow-other-keys
|
||||||
#:rest arguments)
|
#:rest arguments)
|
||||||
"Return a bag for NAME."
|
"Return a bag for NAME."
|
||||||
(define private-keywords
|
(define private-keywords
|
||||||
'(#:target #:glib #:inputs #:native-inputs
|
`(#:glib #:inputs #:native-inputs
|
||||||
#:outputs #:implicit-inputs?))
|
#:outputs #:implicit-inputs? #:implicit-cross-inputs?
|
||||||
|
,@(if target '() '(#:target))))
|
||||||
|
|
||||||
(and (not target) ;XXX: no cross-compilation
|
(bag
|
||||||
(bag
|
(name name)
|
||||||
(name name)
|
(system system) (target target)
|
||||||
(system system)
|
(host-inputs `(,@(if source
|
||||||
(host-inputs (if source
|
`(("source" ,source))
|
||||||
`(("source" ,source))
|
'())
|
||||||
'()))
|
,@(if target
|
||||||
(build-inputs `(,@native-inputs
|
inputs
|
||||||
,@inputs
|
'())))
|
||||||
("glib:bin" ,glib "bin") ; to compile schemas
|
(build-inputs `(,@native-inputs
|
||||||
,@(if implicit-inputs?
|
,@(if target '() inputs)
|
||||||
(standard-packages)
|
("glib:bin" ,glib "bin") ; to compile schemas
|
||||||
'())))
|
;; Keep standard inputs of gnu-build-system.
|
||||||
(outputs outputs)
|
,@(if (and target implicit-cross-inputs?)
|
||||||
(build glib-or-gtk-build)
|
(standard-cross-packages target 'host)
|
||||||
(arguments (strip-keyword-arguments private-keywords arguments)))))
|
'())
|
||||||
|
,@(if implicit-inputs?
|
||||||
|
(standard-packages)
|
||||||
|
'())))
|
||||||
|
;; Keep standard inputs of 'gnu-build-system'.
|
||||||
|
(target-inputs (if (and target implicit-cross-inputs?)
|
||||||
|
(standard-cross-packages target 'target)
|
||||||
|
'()))
|
||||||
|
(outputs outputs)
|
||||||
|
(build (if target glib-or-gtk-cross-build glib-or-gtk-build))
|
||||||
|
(arguments (strip-keyword-arguments private-keywords arguments))))
|
||||||
|
|
||||||
(define* (glib-or-gtk-build name inputs
|
(define* (glib-or-gtk-build name inputs
|
||||||
#:key guile source
|
#:key guile source
|
||||||
|
@ -176,6 +190,100 @@ (define build
|
||||||
#:disallowed-references disallowed-references
|
#:disallowed-references disallowed-references
|
||||||
#:guile-for-build guile)))
|
#:guile-for-build guile)))
|
||||||
|
|
||||||
|
(define* (glib-or-gtk-cross-build name
|
||||||
|
#:key
|
||||||
|
target
|
||||||
|
build-inputs target-inputs host-inputs
|
||||||
|
guile source
|
||||||
|
(outputs '("out"))
|
||||||
|
(search-paths '())
|
||||||
|
(native-search-paths '())
|
||||||
|
(configure-flags ''())
|
||||||
|
;; Disable icon theme cache generation.
|
||||||
|
(make-flags ''("gtk_update_icon_cache=true"))
|
||||||
|
(out-of-source? #f)
|
||||||
|
(tests? #f)
|
||||||
|
(test-target "check")
|
||||||
|
(parallel-build? #t)
|
||||||
|
(parallel-tests? #t)
|
||||||
|
(validate-runpath? #t)
|
||||||
|
(make-dynamic-linker-cache? #f)
|
||||||
|
(patch-shebangs? #t)
|
||||||
|
(strip-binaries? #t)
|
||||||
|
(strip-flags ''("--strip-debug"))
|
||||||
|
(strip-directories ''("lib" "lib64" "libexec"
|
||||||
|
"bin" "sbin"))
|
||||||
|
(phases '(@ (guix build glib-or-gtk-build-system)
|
||||||
|
%standard-phases))
|
||||||
|
(glib-or-gtk-wrap-excluded-outputs ''())
|
||||||
|
(system (%current-system))
|
||||||
|
(build (nix-system->gnu-triplet system))
|
||||||
|
(imported-modules %glib-or-gtk-build-system-modules)
|
||||||
|
(modules %default-modules)
|
||||||
|
allowed-references
|
||||||
|
disallowed-references)
|
||||||
|
"Cross-build SOURCE with INPUTS. See GNU-BUILD for more details."
|
||||||
|
(define builder
|
||||||
|
#~(begin
|
||||||
|
(use-modules #$@(sexp->gexp modules))
|
||||||
|
|
||||||
|
(define %build-host-inputs
|
||||||
|
#+(input-tuples->gexp build-inputs))
|
||||||
|
|
||||||
|
(define %build-target-inputs
|
||||||
|
(append #$(input-tuples->gexp host-inputs)
|
||||||
|
#+(input-tuples->gexp target-inputs)))
|
||||||
|
|
||||||
|
(define %build-inputs
|
||||||
|
(append %build-host-inputs %build-target-inputs))
|
||||||
|
|
||||||
|
(define %outputs
|
||||||
|
#$(outputs->gexp outputs))
|
||||||
|
|
||||||
|
(glib-or-gtk-build #:source #+source
|
||||||
|
#:system #$system
|
||||||
|
#:build #$build
|
||||||
|
#:target #$target
|
||||||
|
#:outputs %outputs
|
||||||
|
#:inputs %build-target-inputs
|
||||||
|
#:native-inputs %build-host-inputs
|
||||||
|
#:search-paths '#$(sexp->gexp
|
||||||
|
(map search-path-specification->sexp
|
||||||
|
search-paths))
|
||||||
|
#:native-search-paths '#$(sexp->gexp
|
||||||
|
(map search-path-specification->sexp
|
||||||
|
native-search-paths))
|
||||||
|
#:phases #$(if (pair? phases)
|
||||||
|
(sexp->gexp phases)
|
||||||
|
phases)
|
||||||
|
#:glib-or-gtk-wrap-excluded-outputs
|
||||||
|
#$glib-or-gtk-wrap-excluded-outputs
|
||||||
|
#:configure-flags #$configure-flags
|
||||||
|
#:make-flags #$make-flags
|
||||||
|
#:out-of-source? #$out-of-source?
|
||||||
|
#:tests? #$tests?
|
||||||
|
#:test-target #$test-target
|
||||||
|
#:parallel-build? #$parallel-build?
|
||||||
|
#:parallel-tests? #$parallel-tests?
|
||||||
|
#:validate-runpath? #$validate-runpath?
|
||||||
|
#:make-dynamic-linker-cache? #$make-dynamic-linker-cache?
|
||||||
|
#:patch-shebangs? #$patch-shebangs?
|
||||||
|
#:strip-binaries? #$strip-binaries?
|
||||||
|
#:strip-flags #$(sexp->gexp strip-flags)
|
||||||
|
#:strip-directories
|
||||||
|
#$(sexp->gexp strip-directories))))
|
||||||
|
|
||||||
|
|
||||||
|
(mlet %store-monad ((guile (package->derivation (or guile (default-guile))
|
||||||
|
system #:graft? #f)))
|
||||||
|
(gexp->derivation name builder
|
||||||
|
#:system system
|
||||||
|
#:target target
|
||||||
|
#:modules imported-modules
|
||||||
|
#:allowed-references allowed-references
|
||||||
|
#:disallowed-references disallowed-references
|
||||||
|
#:guile-for-build guile)))
|
||||||
|
|
||||||
(define glib-or-gtk-build-system
|
(define glib-or-gtk-build-system
|
||||||
(build-system
|
(build-system
|
||||||
(name 'glib-or-gtk)
|
(name 'glib-or-gtk)
|
||||||
|
|
Loading…
Reference in a new issue