guix-commits
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

55/65: build: Build gnu/packages/*.go in five steps.


From: guix-commits
Subject: 55/65: build: Build gnu/packages/*.go in five steps.
Date: Fri, 14 Jul 2023 10:06:07 -0400 (EDT)

janneke pushed a commit to branch hurd-team
in repository guix.

commit aa5681e84374fef41cdeaf1e0b88911bc28c271c
Author: Janneke Nieuwenhuizen <janneke@gnu.org>
AuthorDate: Wed May 24 15:46:44 2023 +0200

    build: Build gnu/packages/*.go in five steps.
    
    This breaks-up packages into five chunks of ~150,000 lines, allowing guix
    build --target=i586-pc-gnu from an x86 host.
    
    This is a followup to 1aa7ee52c6c520c2dbbdb06f1381466e9fd96294.
    
    * Makefile.am (first_half): Rename to...
    (first_quart): ...this, and also split into...
    (second_quart): ...this.
    (third_quart, MODULES_PACKAGES3, MODULES_PACKAGE4): New variables.
    (make-packages3-go, make-packages4-go): New targets.
    (make-packages-go): Add them.
---
 Makefile.am | 62 +++++++++++++++++++++++++++++++++++++++++++++++++++++--------
 1 file changed, 54 insertions(+), 8 deletions(-)

diff --git a/Makefile.am b/Makefile.am
index a386e6033c..abe97db46a 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -772,19 +772,45 @@ endef
 # in <https://issues.guix.gnu.org/48963>.  Each 'eval' call below creates a
 # 'make-*-go' phony target that builds the corresponding subset.
 
-first_half :=                                                          \
-  gnu/packages/a% gnu/packages/b% gnu/packages/c% gnu/packages/d%      \
-  gnu/packages/e% gnu/packages/f% gnu/packages/g% gnu/packages/h%      \
-  gnu/packages/i% gnu/packages/j% gnu/packages/k% gnu/packages/l%
+first_fifth :=                                                         \
+  gnu/packages/a% gnu/packages/b% gnu/packages/c%
+
+second_fifth :=                                                                
\
+  gnu/packages/d% gnu/packages/e% gnu/packages/f%
+
+third_fifth :=                                                         \
+  gnu/packages/g%  gnu/packages/h% gnu/packages/i%
+
+fourth_fifth :=                                                                
\
+  gnu/packages/j% gnu/packages/k% gnu/packages/l% gnu/packages/m%      \
+  gnu/packages/n% gnu/packages/o%
 
 MODULES_CORE      := guix.scm $(filter-out guix/scripts/%,$(filter 
guix/%,$(MODULES)))
-MODULES_PACKAGES1 := $(filter $(first_half),$(MODULES))
-MODULES_PACKAGES2 := $(filter-out $(first_half),$(filter 
gnu/packages/%,$(MODULES)))
-MODULES_PACKAGES  := $(MODULES_PACKAGES1) $(MODULES_PACKAGES2)
+MODULES_PACKAGES1 := $(filter $(first_fifth),$(MODULES))
+MODULES_PACKAGES2 := $(filter $(second_fifth),$(MODULES))
+MODULES_PACKAGES3 := $(filter $(third_fifth),$(MODULES))
+MODULES_PACKAGES4 := $(filter $(fourth_fifth),$(MODULES))
+MODULES_PACKAGES5 := $(filter-out $(first_fifth) $(second_fifth)       \
+                       $(third_fifth) $(fourth_fifth),                 \
+                       $(filter gnu/packages/%,$(MODULES)))
+MODULES_PACKAGES  := $(MODULES_PACKAGES1) $(MODULES_PACKAGES2)         \
+                       $(MODULES_PACKAGES3) $(MODULES_PACKAGES4)       \
+                       $(MODULES_PACKAGES5)
 MODULES_SYSTEM    := gnu.scm $(filter-out gnu/packages/%,$(filter 
gnu/%,$(MODULES)))
 MODULES_CLI       := $(filter guix/scripts/%,$(MODULES))
 MODULES_PO        := guix/build/po.scm
 
+print-p1:
+       @echo $(MODULES_PACKAGES1)
+print-p2:
+       @echo $(MODULES_PACKAGES2)
+print-p3:
+       @echo $(MODULES_PACKAGES3)
+print-p4:
+       @echo $(MODULES_PACKAGES4)
+print-p5:
+       @echo $(MODULES_PACKAGES5)
+
 $(eval $(call guile-compilation-rule,make-core-go,     \
   $(MODULES_CORE) guix/config.scm $(dist_noinst_DATA), \
   0))
@@ -800,7 +826,27 @@ $(eval $(call guile-compilation-rule,make-packages2-go,    
\
   $(words $(MODULES_CORE) $(MODULES_PACKAGES1))))
 .PHONY: make-packages2-go
 
-make-packages-go: make-packages1-go make-packages2-go
+$(eval $(call guile-compilation-rule,make-packages3-go,                        
        \
+  $(MODULES_PACKAGES3) make-core-go make-packages1-go make-packages2-go,       
\
+  $(words $(MODULES_CORE) $(MODULES_PACKAGES1) $(MODULES_PACKAGES2))))
+.PHONY: make-packages3-go
+
+$(eval $(call guile-compilation-rule,make-packages4-go,                        
\
+  $(MODULES_PACKAGES4) make-core-go make-packages1-go make-packages2-go        
\
+    make-packages3-go,                                                 \
+  $(words $(MODULES_CORE) $(MODULES_PACKAGES1) $(MODULES_PACKAGES2)    \
+    $(MODULES_PACKAGES3))))
+.PHONY: make-packages4-go
+
+$(eval $(call guile-compilation-rule,make-packages5-go,                        
\
+  $(MODULES_PACKAGES5) make-core-go make-packages1-go make-packages2-go        
\
+    make-packages3-go make-packages4-go,                               \
+  $(words $(MODULES_CORE) $(MODULES_PACKAGES1) $(MODULES_PACKAGES2)    \
+    $(MODULES_PACKAGES3) $(MODULES_PACKAGES4))))
+.PHONY: make-packages5-go
+
+make-packages-go: make-packages1-go make-packages2-go \
+  make-packages3-go make-packages4-go make-packages5-go
 .PHONY: make-packages-go
 
 $(eval $(call guile-compilation-rule,make-system-go,   \



reply via email to

[Prev in Thread] Current Thread [Next in Thread]