X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=rules%2Fbuild-package.mk;h=7e2ce68471980edc2eb267ddee899221e5f00c1f;hb=5775d5142da227d65fb86994d363eb16841ee642;hp=afe69ac159797f40f0da866722da1cc2cfca1a4a;hpb=7f65bf79c5b53006cda40fe02b6d8f6ca5351d38;p=ghc-hetmet.git diff --git a/rules/build-package.mk b/rules/build-package.mk index afe69ac..7e2ce68 100644 --- a/rules/build-package.mk +++ b/rules/build-package.mk @@ -29,6 +29,7 @@ # libraries/base_dist_LD_OPTS = -package ghc-prim-0.1.0.0 define build-package +$(call trace, build-package($1,$2,$3)) # $1 = dir # $2 = distdir # $3 = GHC stage to use (0 == bootstrapping compiler) @@ -37,17 +38,6 @@ ifeq "$$(findstring $3,0 1 2)" "" $$(error $1/$2: stage argument to build-package should be 0, 1, or 2) endif -# We don't install things compiled by stage 0, so no need to put them -# in the bindist. -ifneq "$(BINDIST) $3" "YES 0" - -$(call all-target,$1,all_$1_$2) -# This give us things like -# all_libraries: all_libraries/base_dist-install -ifneq "$$($1_$2_GROUP)" "" -all_$$($1_$2_GROUP): all_$1_$2 -endif - $(call clean-target,$1,$2,$1/$2) distclean : clean_$1_$2_config @@ -56,53 +46,96 @@ maintainer-clean : distclean .PHONY: clean_$1_$2_config clean_$1_$2_config: - $(RM) $1/config.log $1/config.status $1/include/Hs*Config.h - $(RM) -r $1/autom4te.cache + "$$(RM)" $$(RM_OPTS) $1/config.log $1/config.status $1/include/Hs*Config.h + "$$(RM)" $$(RM_OPTS_REC) $1/autom4te.cache + +ifneq "$$($1_$2_NOT_NEEDED)" "YES" +$$(eval $$(call build-package-helper,$1,$2,$3)) +endif +endef + + +define build-package-helper +# $1 = dir +# $2 = distdir +# $3 = GHC stage to use (0 == bootstrapping compiler) # --- CONFIGURATION -$1_$2_USE_BOOT_LIBS = YES $(call package-config,$1,$2,$3) -ifneq "$$(NO_INCLUDE_PKGDATA)" "YES" -include $1/$2/package-data.mk +# Bootstrapping libs are only built one way +ifeq "$3" "0" +$1_$2_WAYS = v +else +$1_$2_WAYS = $$(GhcLibWays) endif -ifeq "$$($1_$2_DISABLE)" "YES" +# We must use a different dependency file if $(GhcLibWays) changes, so +# encode the ways into the name of the file. +$1_$2_WAYS_DASHED = $$(subst $$(space),,$$(patsubst %,-%,$$(strip $$($1_$2_WAYS)))) +$1_$2_depfile_base = $1/$2/build/.depend$$($1_$2_WAYS_DASHED) + +######################################## +ifeq "$$($1_$2_CONFIGURE_PHASE)" "" +$$(error No configure phase for $1_$2) +else ifeq "$$($1_$2_CONFIGURE_PHASE)" "$$(phase)" ifeq "$$(DEBUG)" "YES" -$$(warning $1/$2 disabled) +$$(warning $1/$2 configure phase) endif -# A package is disabled when we want to bring its package-data.mk file -# up-to-date first, or due to other build dependencies. - -$(call all-target,$1_$2,$1/$2/package-data.mk) +ifneq "$$(BINDIST)" "YES" +$(call build-package-data,$1,$2,$3) +endif -ifneq "$(BINDIST)" "YES" -# We have a rule for package-data.mk only when the package is -# disabled, because we want the build to fail if we haven't run phase 0. -$(call build-package-data,$1,$2) +ifneq "$$(NO_INCLUDE_PKGDATA)" "YES" +include $1/$2/package-data.mk endif -else +else ifeq "$$(phase_$$($1_$2_CONFIGURE_PHASE)_or_later)" "YES" + +ifeq "$$(DEBUG)" "YES" +$$(warning $1/$2 build phase) +endif ifneq "$$(NO_INCLUDE_PKGDATA)" "YES" +include $1/$2/package-data.mk ifeq "$$($1_$2_VERSION)" "" -$$(error phase ordering error: $1/$2 is enabled, but $1/$2/package-data.mk does not exist) +$$(error No version for $1_$2 found) endif endif -# Sometimes we need to modify the automatically-generated package-data.mk -# bindings in a special way for the GHC build system, so allow that here: -$($1_PACKAGE_MAGIC) +$(call all-target,$1,all_$1_$2) -# Bootstrapping libs are only built one way -ifeq "$3" "0" -$1_$2_WAYS = v else -$1_$2_WAYS = $$(GhcLibWays) + +ifeq "$$(DEBUG)" "YES" +$$(warning $1/$2 disabled phase) +endif + endif +######################################## + +# We don't install things compiled by stage 0, so no need to put them +# in the bindist. +ifneq "$$(BINDIST) $3" "YES 0" + +# This give us things like +# all_libraries: all_libraries/base_dist-install +ifneq "$$($1_$2_GROUP)" "" +all_$$($1_$2_GROUP): all_$1_$2 +endif + +ifneq "$$(CHECKED_$1)" "YES" +CHECKED_$1 = YES +check_packages: check_$1 +.PHONY: check_$1 +check_$1: $$(GHC_CABAL_INPLACE) + $$(GHC_CABAL_INPLACE) check $1 +endif + +ifeq "$$(phase_$$($1_$2_CONFIGURE_PHASE)_done)" "YES" $(call hs-sources,$1,$2) $(call c-sources,$1,$2) @@ -110,12 +143,7 @@ $(call includes-sources,$1,$2) # --- DEPENDENCIES -# We must use a different dependency file if $(GhcLibWays) changes, so -# encode the ways into the name of the file. -$1_$2_WAYS_DASHED = $$(subst $$(space),,$$(patsubst %,-%,$$(strip $$($1_$2_WAYS)))) -$1_$2_depfile = $1/$2/build/.depend$$($1_$2_WAYS_DASHED) - -$(call build-dependencies,$1,$2) +$(call build-dependencies,$1,$2,$3) # --- BUILDING @@ -128,17 +156,20 @@ $1_$2_SplitObjs = NO endif endif -# C and S files are built the "v" vanlilla way and possibly also the "dyn" way. -$(call c-objs,$1,$2,v) -$(call distdir-opts,$1,$2,$3) -$(call c-suffix-rules,$1,$2,v,YES) -ifeq "$(BuildSharedLibs)" "YES" +# C and S files are possibly built the "dyn" way. +ifeq "$$(BuildSharedLibs)" "YES" $(call c-objs,$1,$2,dyn) $(call c-suffix-rules,$1,$2,dyn,YES) endif # Now generate all the build rules for each way in this directory: -$$(foreach way,$$($1_$2_WAYS),$$(eval $$(call build-package-way,$1,$2,$$(way),$3))) +$$(foreach way,$$($1_$2_WAYS),$$(eval \ + $$(call c-objs,$1,$2,$$(way)) \ + $$(call c-suffix-rules,$1,$2,$$(way),YES) \ + $$(call cmm-objs,$1,$2,$$(way)) \ + $$(call cmm-suffix-rules,$1,$2,$$(way)) \ + $$(call build-package-way,$1,$2,$$(way),$3) \ + )) $(call haddock,$1,$2) @@ -146,7 +177,7 @@ endif # package-data.mk exists # Don't put bootstrapping packages in the bindist ifneq "$3" "0" -BINDIST_EXTRAS += $1/*.cabal $1/$2/setup-config $1/LICENSE +BINDIST_EXTRAS += $1/*.cabal $$(wildcard $1/*.buildinfo) $1/$2/setup-config $1/LICENSE BINDIST_EXTRAS += $$($1_$2_INSTALL_INCLUDES_SRCS) endif