X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=ghc.mk;h=240804931923d98abc38f8d61476234d2099be35;hb=b88939db1ac65aa00df79e6b945f67d63aeced30;hp=d352d5c90ceea8e57a780e7ba7be9452e6e1e3d8;hpb=f65bf7559b3e92607cfcf7a334e9994891dd9c32;p=ghc-hetmet.git diff --git a/ghc.mk b/ghc.mk index d352d5c..2408049 100644 --- a/ghc.mk +++ b/ghc.mk @@ -525,7 +525,7 @@ endif ifneq "$(CLEANING)" "YES" BUILD_DIRS += \ - $(patsubst %, libraries/%, $(PACKAGES) $(PACKAGES_STAGE2)) + $(patsubst %, libraries/%, $(PACKAGES)) endif ifneq "$(BootingFromHc)" "YES" @@ -549,6 +549,12 @@ BUILD_DIRS += \ $(GHC_TOUCHY_DIR) endif +ifneq "$(CLEANING)" "YES" +# After compiler/, because these packages depend on it +BUILD_DIRS += \ + $(patsubst %, libraries/%, $(PACKAGES_STAGE2)) +endif + # XXX libraries/% must come before any programs built with stage1, see # Note [lib-depends]. @@ -685,6 +691,15 @@ libraries/bin-package-db/dist-boot/build/Distribution/InstalledPackageInfo/Binar $(foreach pkg,$(BOOT_PKGS),$(eval libraries/$(pkg)_dist-boot_HC_OPTS += $$(GhcBootLibHcOpts))) +# Make sure we have all the GHCi libs by the time we've built +# ghc-stage2. DPH includes a bit of Template Haskell which needs the +# GHCI libs, and we don't have a better way to express that dependency. +# +GHCI_LIBS = $(foreach lib,$(PACKAGES),$(libraries/$(lib)_dist-install_GHCI_LIB)) \ + $(compiler_stage2_GHCI_LIB) + +ghc/stage2/build/tmp/$(ghc_stage2_PROG) : $(GHCI_LIBS) + endif # -----------------------------------------------------------------------------