X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=ghc%2FMakefile;h=4b3e05cfb57f86ae8118ba5df57285e2bd55e2a8;hb=bcbd8d8e5f42e11c68d36c601233b37afb2b11be;hp=767ddc84cd7c7ddab6f4fdc43290d39227e29cc3;hpb=dbdd86ba6cd527756becd70941544f4d599e8141;p=ghc-hetmet.git diff --git a/ghc/Makefile b/ghc/Makefile index 767ddc8..4b3e05c 100644 --- a/ghc/Makefile +++ b/ghc/Makefile @@ -1,43 +1,113 @@ -#----------------------------------------------------------------------------- -# $Id: Makefile,v 1.12 2000/11/03 17:08:36 simonmar Exp $ -# -TOP=. +TOP=.. include $(TOP)/mk/boilerplate.mk +include $(TOP)/mk/cabal-flags.mk -# -# subdir dependencies: -# everything needs utils -# includes/ needs driver (to easily c.pile mkNativeGen.c) -# make depend except in {utils,driver} needs includes -# RTS and compiler need includes -# - -# -# Order is important! It's e.g. necessary to descend into include/ -# before the rest to have a config.h, etc. -# -# If we're booting from .hc files, swap the order -# we descend into compiler/ and lib/ -# -ifeq "$(GhcWithHscBuiltViaC)" "NO" -SUBDIRS = includes utils driver rts docs compiler lib +ifeq "$(stage)" "" +stage=1 +endif + +ifeq "$(HOSTPLATFORM)" "i386-unknown-mingw32" +INSTALL_FLAGS = else -SUBDIRS = includes utils driver rts docs lib compiler +INSTALL_FLAGS = --enable-shell-wrappers endif -# Easier to copy -ifeq "$(BIN_DIST)" "1" -SUBDIRS := $(filter-out docs,$(SUBDIRS)) +boot: + @: + +all:: build.stage.$(stage) + +stage1 :: + $(MAKE) stage=1 + +stage2 :: + $(MAKE) stage=2 + +stage3 :: + $(MAKE) stage=3 + +clean distclean:: + -$(CABAL) clean --distpref dist-stage1 + -$(CABAL) clean --distpref dist-stage2 + $(RM) -rf stage1-inplace + $(RM) -rf stage2-inplace + +# XXX Eugh, can we do this better? The problem is making extra-gcc-opts +# infdable on both Linux and Windows. I guess this will go away when we +# drop the mangler? +ifeq "$(HOSTPLATFORM)" "i386-unknown-mingw32" +SET_DATA_SUBDIR = --datasubdir=. +INPLACE_DATA_DIR = '$$prefix' +else +SET_DATA_SUBDIR = +INPLACE_DATA_DIR = '$$prefix/data' endif -ifeq ($(IncludeTestDirsInBuild),YES) -SUBDIRS += tests +CONFIGURE_FLAGS_STAGE1 += --flags=-ghci + +ifeq "$(GhcWithInterpreter)" "YES" +CONFIGURE_FLAGS_STAGE2 += --flags=ghci +else +CONFIGURE_FLAGS_STAGE2 += --flags=-ghci +endif + +ifeq "$(GhcProfiled)" "YES" +CONFIGURE_FLAGS_STAGE2 += --enable-executable-profiling +endif +ifeq "$(GhcDebugged)" "YES" +CONFIGURE_FLAGS_STAGE2 += --ghc-option=-debug +endif +ifeq "$(GhcThreaded)" "YES" +# Use threaded RTS with GHCi, so threads don't get blocked at the prompt. +CONFIGURE_FLAGS_STAGE2 += --ghc-option=-threaded endif -SRC_DIST_FILES += configure +CONFIGURE_FLAGS_STAGE3 = $(CONFIGURE_FLAGS_STAGE2) + +CONFIGURE_FLAGS_STAGE1 += $(USE_BOOT_CONFIGURE_FLAGS) +CONFIGURE_FLAGS_STAGE2 += $(USE_STAGE1_CONFIGURE_FLAGS) +CONFIGURE_FLAGS_STAGE3 += $(USE_STAGE2_CONFIGURE_FLAGS) + +# XXX In stage2+ we should really use the inplace ghc-pkg +# It works because installPackage doesn't actually use ghc-pkg, as there's +# no library to register + +build.stage.%: + $(CABAL) configure --distpref dist-stage$* \ + $(SET_DATA_SUBDIR) \ + $(INSTALL_DIRS_CONFIGURE_FLAGS) \ + $(CONFIGURE_FLAGS_STAGE$*) \ + $(COMMON_CONFIGURE_FLAGS) + $(CABAL) build --distpref dist-stage$* $(BUILD_FLAGS) + $(INSTALL_PACKAGE) install '$(GHC_PKG_PROG)' 'XXX/package.conf' "" \ + $(FPTOOLS_TOP_ABS)/ghc/stage$*-inplace \ + $(FPTOOLS_TOP_ABS)/ghc/stage$*-inplace \ + '$$prefix/bin' \ + '$$prefix/lib' \ + '$$prefix/libexec' \ + '$$prefix/dynlib' \ + $(INPLACE_DATA_DIR) \ + '$$prefix/doc' \ + '$$prefix/html' \ + '$$prefix/haddock' \ + --distpref dist-stage$* \ + $(INSTALL_FLAGS) + +# XXX For now we always install the stage 2 compiler +install: + $(INSTALL_PACKAGE) install UNUSED UNUSED '$(DESTDIR)' '$(prefix)' \ + '$(prefix)' '$(bindir)' '$(libdir)' \ + '$(libexecdir)' '$(dynlibdir)' '$(datadir)' \ + '$(docdir)' '$(htmldir)' '$(haddockdir)' \ + --distpref dist-stage2 \ + $(INSTALL_FLAGS) -DIST_CLEAN_FILES += ghc.spec -MAINTAINER_CLEAN_FILES += configure config.status +# XXX fix: +#binary-dist: +# $(INSTALL_DIR) $(BIN_DIST_DIR)/utils/hsc2hs +# $(INSTALL_DATA) Makefile $(BIN_DIST_DIR)/utils/hsc2hs/ +# $(INSTALL_DATA) hsc2hs.sh $(BIN_DIST_DIR)/utils/hsc2hs/ +# $(INSTALL_DATA) $(INSTALL_DATAS) $(BIN_DIST_DIR)/utils/hsc2hs/ +# $(INSTALL_PROGRAM) $(HS_PROG) $(BIN_DIST_DIR)/utils/hsc2hs/ -include $(TOP)/mk/target.mk