X-Git-Url: http://git.megacz.com/?p=ghc-hetmet.git;a=blobdiff_plain;f=rules%2Fbuild-package.mk;h=9e1ab7acf24f4ae2bef61b7fbf296180f07ea153;hp=b2b3093e19ffdd044cc6c01049fbd1c536360aca;hb=0856ac59cfb455d32a3042317fdba0f5e85cab9c;hpb=c59c053f0b8613dd128297ee0b6eef31f001c498 diff --git a/rules/build-package.mk b/rules/build-package.mk index b2b3093..9e1ab7a 100644 --- a/rules/build-package.mk +++ b/rules/build-package.mk @@ -28,8 +28,6 @@ # libraries/base_dist_CC_OPTS = -Iinclude ... # libraries/base_dist_LD_OPTS = -package ghc-prim-0.1.0.0 -# TODO: soext - define build-package # $1 = dir # $2 = distdir @@ -41,22 +39,35 @@ endif # We don't install things compiled by stage 0, so no need to put them # in the bindist. -ifneq "$(BINDIST) $3" "YES 0" +ifneq "$$(BINDIST) $3" "YES 0" $(call all-target,$1,all_$1_$2) - $(call clean-target,$1,$2,$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 distclean : clean_$1_$2_config +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) -r $1/autom4te.cache # --- CONFIGURATION -$1_$2_USE_BOOT_LIBS = YES $(call package-config,$1,$2,$3) ifneq "$$(NO_INCLUDE_PKGDATA)" "YES" @@ -74,10 +85,10 @@ endif $(call all-target,$1_$2,$1/$2/package-data.mk) -ifneq "$(BINDIST)" "YES" +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) +$(call build-package-data,$1,$2,$3) endif else @@ -123,21 +134,28 @@ $1_$2_SplitObjs = NO endif endif -# C and S files are built only once, not once per way -$(call c-objs,$1,$2) -$(call distdir-opts,$1,$2,$3) -$(call c-suffix-rules,$1,$2,v,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) endif # package-data.mk exists # Don't put bootstrapping packages in the bindist -ifeq "$3" "1" -BINDIST_EXTRAS += $1/*.cabal $1/$2/setup-config $1/LICENSE +ifneq "$3" "0" +BINDIST_EXTRAS += $1/*.cabal $$(wildcard $1/*.buildinfo) $1/$2/setup-config $1/LICENSE BINDIST_EXTRAS += $$($1_$2_INSTALL_INCLUDES_SRCS) endif