X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=rules%2Fbuild-package.mk;h=c735e5137a60410c1c6377a200e34af08e1b4355;hb=6cec61d14a324285dbb8ce73d4c7215f1f8d6766;hp=f8c48134f6fe0405eddb88c1a54fb4c34ad268a6;hpb=85f096f8051d4a5c20ac36c1b8866007ad4146c3;p=ghc-hetmet.git diff --git a/rules/build-package.mk b/rules/build-package.mk index f8c4813..c735e51 100644 --- a/rules/build-package.mk +++ b/rules/build-package.mk @@ -29,6 +29,8 @@ # libraries/base_dist_LD_OPTS = -package ghc-prim-0.1.0.0 define build-package +$(call trace, build-package($1,$2,$3)) +$(call profStart, build-package($1,$2,$3)) # $1 = dir # $2 = distdir # $3 = GHC stage to use (0 == bootstrapping compiler) @@ -46,11 +48,12 @@ maintainer-clean : distclean .PHONY: clean_$1_$2_config clean_$1_$2_config: "$$(RM)" $$(RM_OPTS) $1/config.log $1/config.status $1/include/Hs*Config.h - "$$(RM)" $$(RM_OPTS) -r $1/autom4te.cache + "$$(RM)" $$(RM_OPTS_REC) $1/autom4te.cache ifneq "$$($1_$2_NOT_NEEDED)" "YES" $$(eval $$(call build-package-helper,$1,$2,$3)) endif +$(call profEnd, build-package($1,$2,$3)) endef @@ -59,62 +62,10 @@ define build-package-helper # $2 = distdir # $3 = GHC stage to use (0 == bootstrapping compiler) -# 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 - -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 - # --- CONFIGURATION $(call package-config,$1,$2,$3) -ifneq "$$(NO_INCLUDE_PKGDATA)" "YES" -include $1/$2/package-data.mk -endif - -ifeq "$$($1_$2_DISABLE)" "YES" - -ifeq "$$(DEBUG)" "YES" -$$(warning $1/$2 disabled) -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" -# 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,$3) -endif - -else - -ifneq "$$(NO_INCLUDE_PKGDATA)" "YES" -ifeq "$$($1_$2_VERSION)" "" -$$(error phase ordering error: $1/$2 is enabled, but $1/$2/package-data.mk does not exist) -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) - # Bootstrapping libs are only built one way ifeq "$3" "0" $1_$2_WAYS = v @@ -122,20 +73,19 @@ else $1_$2_WAYS = $$(GhcLibWays) endif -$(call hs-sources,$1,$2) -$(call c-sources,$1,$2) -$(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_base = $1/$2/build/.depend$$($1_$2_WAYS_DASHED) -$(call build-dependencies,$1,$2) - -# --- BUILDING +$(call build-package-data,$1,$2,$3) +ifneq "$$(NO_INCLUDE_PKGDATA)" "YES" +ifeq "$3" "0" +include $1/$2/package-data.mk +else ifeq "$(phase)" "final" +include $1/$2/package-data.mk +endif +endif # We don't bother splitting the bootstrap packages (built with stage 0) ifeq "$$($1_$2_SplitObjs)" "" @@ -146,24 +96,43 @@ $1_$2_SplitObjs = NO endif endif -# 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 +$(call hs-sources,$1,$2) +$(call c-sources,$1,$2) +$(call includes-sources,$1,$2) + +$(call dependencies,$1,$2,$3) # Now generate all the build rules for each way in this directory: $$(foreach way,$$($1_$2_WAYS),$$(eval \ $$(call c-objs,$1,$2,$$(way)) \ - $$(call c-suffix-rules,$1,$2,$$(way),YES) \ + $$(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) +# 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 + +$(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 + +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 -endif # package-data.mk exists +$(call haddock,$1,$2) # Don't put bootstrapping packages in the bindist ifneq "$3" "0" @@ -171,7 +140,5 @@ BINDIST_EXTRAS += $1/*.cabal $$(wildcard $1/*.buildinfo) $1/$2/setup-config $1/L BINDIST_EXTRAS += $$($1_$2_INSTALL_INCLUDES_SRCS) endif -endif - endef