X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=ghc%2FMakefile;h=4bd84b963caeec356809863717169e4fde88b517;hb=f18200e94cd2d240e7fd38494c3244ec253596a6;hp=68541ab7daeaca51fd06e2ddaae73a335b82a101;hpb=f3665286395b7fab0a2d40ab4bf47f0295f3cbd6;p=ghc-hetmet.git diff --git a/ghc/Makefile b/ghc/Makefile index 68541ab..4bd84b9 100644 --- a/ghc/Makefile +++ b/ghc/Makefile @@ -1,43 +1,119 @@ -#----------------------------------------------------------------------------- -# $Id: Makefile,v 1.14 2000/11/06 13:14:52 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 docs compiler rts lib +ifeq "$(stage)" "" +stage=1 +endif + +ifeq "$(HOSTPLATFORM)" "i386-unknown-mingw32" +INSTALL_FLAGS = +else +INSTALL_FLAGS = --enable-shell-wrappers +endif + +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 -SUBDIRS = includes utils driver rts docs lib compiler +SET_DATA_SUBDIR = +INPLACE_DATA_DIR = '$$prefix/data' endif -# Easier to copy -ifeq "$(BIN_DIST)" "1" -SUBDIRS := $(filter-out docs,$(SUBDIRS)) +build.stage1: + $(CABAL) configure --distpref dist-stage1 \ + --flags=-ghci \ + $(SET_DATA_SUBDIR) \ + $(INSTALL_DIRS_CONFIGURE_FLAGS) \ + $(USE_BOOT_CONFIGURE_FLAGS) \ + $(COMMON_CONFIGURE_FLAGS) + $(CABAL) build --distpref dist-stage1 $(BUILD_FLAGS) + $(INSTALL_PACKAGE) install '$(GHC_PKG_PROG)' 'XXX/package.conf' "" \ + $(FPTOOLS_TOP_ABS)/ghc/stage1-inplace \ + $(FPTOOLS_TOP_ABS)/ghc/stage1-inplace \ + '$$prefix/bin' \ + '$$prefix/lib' \ + '$$prefix/libexec' \ + '$$prefix/dynlib' \ + $(INPLACE_DATA_DIR) \ + '$$prefix/doc' \ + '$$prefix/html' \ + '$$prefix/haddock' \ + --distpref dist-stage1 \ + $(INSTALL_FLAGS) + +ifeq "$(GhcWithInterpreter)" "YES" +CONFIGURE_FLAGS_STAGE2 += --flags=ghci +else +CONFIGURE_FLAGS_STAGE2 += --flags=-ghci endif -ifeq ($(IncludeTestDirsInBuild),YES) -SUBDIRS += tests +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 + +# 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 -SRC_DIST_FILES += configure +build.stage2: + $(CABAL) configure --distpref dist-stage2 \ + $(SET_DATA_SUBDIR) \ + $(CONFIGURE_FLAGS_STAGE2) \ + $(INSTALL_DIRS_CONFIGURE_FLAGS) \ + $(USE_STAGE1_CONFIGURE_FLAGS) \ + $(COMMON_CONFIGURE_FLAGS) + $(CABAL) build --distpref dist-stage2 $(BUILD_FLAGS) + $(INSTALL_PACKAGE) install '$(GHC_PKG_PROG)' 'XXX/package.conf' "" \ + $(FPTOOLS_TOP_ABS)/ghc/stage2-inplace \ + $(FPTOOLS_TOP_ABS)/ghc/stage2-inplace \ + '$$prefix/bin' \ + '$$prefix/lib' \ + '$$prefix/libexec' \ + '$$prefix/dynlib' \ + $(INPLACE_DATA_DIR) \ + '$$prefix/doc' \ + '$$prefix/html' \ + '$$prefix/haddock' \ + --distpref dist-stage2 \ + $(INSTALL_FLAGS) -DIST_CLEAN_FILES += ghc.spec config.status -MAINTAINER_CLEAN_FILES += configure +# 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