From: Ian Lynagh Date: Thu, 17 Jul 2008 15:07:46 +0000 (+0000) Subject: Split building the ghc package and binary into "boot" and "all" steps X-Git-Url: http://git.megacz.com/?p=ghc-hetmet.git;a=commitdiff_plain;h=48c3232a53eb5a0594991e4af602bf91364a2cc4 Split building the ghc package and binary into "boot" and "all" steps In "boot" we configure, and in "all" we do the actual building. --- diff --git a/compiler/Makefile b/compiler/Makefile index 3e2ae8d..4722a5b 100644 --- a/compiler/Makefile +++ b/compiler/Makefile @@ -40,6 +40,8 @@ PRIMOP_BITS = primop-data-decl.hs-incl \ primop-strictness.hs-incl \ primop-primop-info.hs-incl +boot:: boot.stage.$(stage) + all:: build.stage.$(stage) stage1 :: @@ -160,7 +162,7 @@ CONFIGURE_FLAGS_STAGE1 += $(USE_BOOT_CONFIGURE_FLAGS) CONFIGURE_FLAGS_STAGE2 += $(USE_STAGE1_CONFIGURE_FLAGS) CONFIGURE_FLAGS_STAGE3 += $(USE_STAGE2_CONFIGURE_FLAGS) -build.stage.%: $(PRIMOP_BITS) +boot.stage.%: $(CABAL) configure --distpref dist-stage$* \ $(CONFIGURE_FLAGS_STAGE$*) \ $(INSTALL_DIRS_CONFIGURE_FLAGS) \ @@ -168,6 +170,8 @@ build.stage.%: $(PRIMOP_BITS) --ghc-option=-DSTAGE=$* $(RM) -f Makefile-stage$* $(CABAL) makefile --distpref dist-stage$* -f Makefile-stage$* + +build.stage.%: $(PRIMOP_BITS) $(MAKE) -f Makefile-stage$* stage=$* $(CABAL) register --distpref dist-stage$* --inplace diff --git a/ghc/Makefile b/ghc/Makefile index 4b3e05c..312ab05 100644 --- a/ghc/Makefile +++ b/ghc/Makefile @@ -13,8 +13,7 @@ else INSTALL_FLAGS = --enable-shell-wrappers endif -boot: - @: +boot:: boot.stage.$(stage) all:: build.stage.$(stage) @@ -73,12 +72,14 @@ CONFIGURE_FLAGS_STAGE3 += $(USE_STAGE2_CONFIGURE_FLAGS) # It works because installPackage doesn't actually use ghc-pkg, as there's # no library to register -build.stage.%: +boot.stage.%: $(CABAL) configure --distpref dist-stage$* \ $(SET_DATA_SUBDIR) \ $(INSTALL_DIRS_CONFIGURE_FLAGS) \ $(CONFIGURE_FLAGS_STAGE$*) \ $(COMMON_CONFIGURE_FLAGS) + +build.stage.%: $(CABAL) build --distpref dist-stage$* $(BUILD_FLAGS) $(INSTALL_PACKAGE) install '$(GHC_PKG_PROG)' 'XXX/package.conf' "" \ $(FPTOOLS_TOP_ABS)/ghc/stage$*-inplace \