X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=ghc%2Fdriver%2FMakefile;h=3a87ab43c504f2d30569176e29305e17e092e069;hb=28a464a75e14cece5db40f2765a29348273ff2d2;hp=8db4b8d4b4414823b23f1a9da58cac73aaabec74;hpb=65ee4e4fe803f6e259fdfa5ad07d315b1891ec7b;p=ghc-hetmet.git diff --git a/ghc/driver/Makefile b/ghc/driver/Makefile index 8db4b8d..3a87ab4 100644 --- a/ghc/driver/Makefile +++ b/ghc/driver/Makefile @@ -1,158 +1,28 @@ -#----------------------------------------------------------------------------- -# $Id: Makefile,v 1.7 1997/07/21 11:31:42 andre Exp $ - -TOP=.. -CURRENT_DIR=ghc/driver -include $(TOP)/mk/boilerplate.mk - -# -# The ways setup doesn't apply to the driver -# -override WAYS= - -INSTALLING=0 - -DYN_LOADABLE_BITS = \ - ghc-asm.prl \ - ghc-iface.prl \ - ghc-consist.prl \ - ghc-split.prl - -SCRIPT_PROG = ghc -SCRIPT_OBJS = ghc.prl - -INTERP=perl - -# -# The driver needs to know the options and names for -# all possible ways, so we magically generate the -# the make variable names for them here. -# - -WAY_NAMES = $(foreach way,$(ALL_WAYS),WAY_$(way)_NAME) -WAY_OPTS = $(foreach way,$(ALL_WAYS),WAY_$(way)_HC_OPTS) - -ifeq "$(INSTALLING)" "1" -TOP_PWD := $(prefix) -else -TOP_PWD := $(FPTOOLS_TOP_ABS) -endif - -SCRIPT_SUBST_VARS := \ - INSTALLING \ - PROJECTNAME PROJECTVERSION PROJECTPATCHLEVEL \ - CURRENT_DIR TMPDIR HOSTPLATFORM TARGETPLATFORM \ - GHC_LIB_DIR GHC_RUNTIME_DIR GHC_UTILS_DIR GHC_INCLUDE_DIR \ - GHC_OPT_HILEV_ASM GhcWithNativeCodeGen LeadingUnderscore\ - GHC_UNLIT GHC_HSCPP GHC_HSC GHC_SYSMAN \ - CP RM CONTEXT_DIFF \ - $(WAY_NAMES) $(WAY_OPTS) - +# -----------------------------------------------------------------------------= +# $Id: Makefile,v 1.76 2005/03/02 09:49:11 simonmar Exp $ # -# When creating a binary distribution, we prefix the driver script -# with a short msg about what variables need to be set to get the -# script going. +# (c) The University of Glasgow 2002 # -ifeq "$(BIN_DIST)" "1" -SCRIPT_PREFIX_FILES=prefix.txt -else -SCRIPT_SUBST_VARS += libdir libexecdir datadir bindir TOP_PWD -endif +TOP=.. +include $(TOP)/mk/boilerplate.mk -all :: $(DYN_LOADABLE_BITS) +SUBDIRS = mangler split ghc ghci -# -# Install setup: -# the driver goes in $(bindir), the perl script helpers -# in $(libdir) -# -# ToDo: allow different install name for driver? -# -INSTALL_SCRIPTS += $(SCRIPT_PROG) -INSTALL_LIBS += $(DYN_LOADABLE_BITS) +boot all :: package.conf.inplace package.conf -# -# Before really installing the driver, we have to -# reconfigure it such that the paths it refers to, -# point to the installed utils. -# -install :: - @$(RM) $(SCRIPT_PROG) - @$(MAKE) $(MFLAGS) INSTALLING=1 $(SCRIPT_PROG) +package.conf.inplace : + echo "[]" > $@ -# -# depend setup: other directories need the driver script to compute -# their dependencies, so `depend' is simply an alias for `all' here. -depend :: all +package.conf : + echo "[]" > $@ -# -# Clean up -# -CLEAN_FILES += $(SCRIPT_OBJS) $(DYN_LOADABLE_BITS) +override datadir = $(libdir) +INSTALL_DATAS += package.conf ghc-usage.txt ghci-usage.txt -# -# Source distribution -# -SRC_DEST_FILES=$(patsubst %.prl,%.lprl,$(DYN_LOADABLE_BITS)) ghc.lprl ordering-passes test_mangler +# Since cleaning effectively uninstalls all the packages, we must +# remove the stamp files that the build system uses to avoid unnecessarily +# re-installing packages. +CLEAN_FILES += package.conf* stamp-pkg-conf* include $(TOP)/mk/target.mk - -# Hack to re-create the in-situ build tree driver script after -# having installed it. -# -install :: - @$(RM) $(SCRIPT_PROG) - @$(MAKE) $(MFLAGS) BIN_DIST=0 $(SCRIPT_PROG) - - -# -# Option vars for the special ways (that the driver has special pleading for). -# - -# Way p: -WAY_p_NAME=profiling -WAY_p_HC_OPTS+=-fscc-profiling -DPROFILING -optc-DPROFILING - -# Way t: -WAY_t_NAME+=ticky-ticky profiling -WAY_t_HC_OPTS=-fticky-ticky -DTICKY_TICKY -optc-DTICKY_TICKY - -# Way `u': -WAY_u_NAME=unregisterized (using portable C only) -WAY_u_HC_OPTS= - -# Way `mc': concurrent -WAY_mc_NAME=concurrent -WAY_mc_HC_OPTS+=-fstack-check -fconcurrent -D__CONCURRENT_HASKELL__ -DCONCURRENT -optcpp-D__CONCURRENT_HASKELL__ -optcpp-DCONCURRENT - -# Way `mr': -WAY_mr_NAME=profiled concurrent -WAY_mr_HC_OPTS+=-fstack-check -fconcurrent -fscc-profiling -D__CONCURRENT_HASKELL__ -DCONCURRENT -DPROFILING -optcpp-D__CONCURRENT_HASKELL__ -optcpp-DCONCURRENT -optcpp-DPROFILING - -# Way `mt': -WAY_mt_NAME=ticky-ticky concurrent -WAY_mt_HC_OPTS+=-fstack-check -fconcurrent -fticky-ticky -D__CONCURRENT_HASKELL__ -DCONCURRENT -DTICKY-TICKY -optc-D__CONCURRENT_HASKELL__ -optc-DCONCURRENT -optc-DTICKY_TICKY - -# Way `mp': -WAY_mp_NAME=parallel -WAY_mp_HC_OPTS+=-fstack-check -fconcurrent -D__PARALLEL_HASKELL__ -DPAR -optcpp-D__PARALLEL_HASKELL__ -optc-DPAR -optc-DCONCURRENT -# try WAY_mp_HC_OPTS+=-fstack-check -fconcurrent -D__PARALLEL_HASKELL__ -DPAR -optcpp-D__CONCURRENT_HASKELL__ -optc-DPAR -optc-DCONCURRENT - -# -# Way `mg': -# Q: is passing -D__GRANSIM__ and -DGRAN to hscpp needed? -WAY_mg_NAME=GranSim -WAY_mg_HC_OPTS+=-fstack-check -fconcurrent -fgransim -D__GRANSIM__ -DGRAN -optcpp-D__GRANSIM__ -optc-DGRAN -optc-D__CONCURRENT_HASKELL__ -optc-DCONCURRENT - -# -# Ways for different garbage collectors -# -WAY_2s_NAME=2-space GC -WAY_2s_HC_OPTS+=-optc-DGC2s - -WAY_1s_NAME=1-space GC -WAY_1s_HC_OPTS+=-optc-DGC1s - -WAY_du_NAME=dual-mode GC -WAY_du_HC_OPTS+=-optc-DGCdu