X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=ghc%2Fdriver%2FMakefile;h=ef11e088473ca7a4e8a27ef03d5a14442ac4d0d6;hb=54cf53b0895e140d73a684e8cf56a1719a499367;hp=fe8e0b8d4b0de18036bdca97ac09bde760085db3;hpb=0936dcc4063c8978286400857f25a91e73b63b3a;p=ghc-hetmet.git diff --git a/ghc/driver/Makefile b/ghc/driver/Makefile index fe8e0b8..ef11e08 100644 --- a/ghc/driver/Makefile +++ b/ghc/driver/Makefile @@ -1,159 +1,64 @@ #----------------------------------------------------------------------------- +# $Id: Makefile,v 1.60 2001/04/03 11:31:39 sewardj Exp $ # TOP=.. CURRENT_DIR=ghc/driver include $(TOP)/mk/boilerplate.mk -# -# The driver needs to get at the version -include $(TOP)/mk/version.mk - -INSTALLING=0 - -DYN_LOADABLE_BITS = \ - ghc-asm.prl \ - ghc-iface.prl \ - ghc-consist.prl \ - ghc-split.prl -SCRIPT_PROG = ghc-$(ProjectVersion) -SCRIPT_LINK = 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. -# +# hack for ghci-inplace script, see below +INSTALLING=1 -WAY_NAMES = $(foreach way,$(ALL_WAYS),WAY_$(way)_NAME) -WAY_OPTS = $(foreach way,$(ALL_WAYS),WAY_$(way)_HC_OPTS) +ifeq "$(INSTALLING)" "1" +SUBDIRS = mangler split ghc ghci +endif -ifeq "$(INSTALLING)" "1" -TOP_PWD := $(prefix) +# ----------------------------------------------------------------------------- +# package configuration files... + +PKGCONF_OPTS = "$(TARGETPLATFORM)" \ + "$(CURRENT_DIR)" \ + "$(HaveLibGmp)" \ + "$(LibsReadline)" \ + "$(libdir)" \ + "$(GHC_LIB_DIR)" \ + "$(GHC_RUNTIME_DIR)" \ + "$(GHC_UTILS_DIR)" \ + "$(GHC_INCLUDE_DIR)" \ + "$(FPTOOLS_TOP_ABS)" + +ghc_407_at_least = $(shell expr "$(GhcMinVersion)" \>= 7) +ifeq "$(ghc_407_at_least)" "1" +ifneq "$(mingw32_TARGET_OS)" "1" +SRC_HC_OPTS += -fglasgow-exts -cpp -package concurrent -package posix -package text else -TOP_PWD := $(FPTOOLS_TOP_ABS) +SRC_HC_OPTS += -fglasgow-exts -cpp -package concurrent -package text endif - -SCRIPT_SUBST_VARS := \ - INSTALLING \ - ProjectName ProjectVersion ProjectVersionInt ProjectPatchLevel \ - HscMajorVersion HscMinorVersion CcMajorVersion CcMinorVersion \ - CURRENT_DIR 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 EnableWin32DLLs \ - CP RM CONTEXT_DIFF LibGmp \ - $(WAY_NAMES) $(WAY_OPTS) - -# -# 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. -# - -ifeq "$(BIN_DIST)" "1" -SCRIPT_PREFIX_FILES=prefix.txt else -SCRIPT_SUBST_VARS += libdir libexecdir datadir bindir TMPDIR TOP_PWD +SRC_HC_OPTS += -fglasgow-exts -cpp -syslib concurrent -syslib posix -syslib misc endif -all :: $(DYN_LOADABLE_BITS) +SRC_HC_OPTS += -DWANT_PRETTY -# -# 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) +all :: package.conf package.conf.inplace -# -# 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) +HS_OBJS = Package.o PackageSrc.o Utils.o +HS_PROG = pkgconf -# -# 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.inplace : $(HS_PROG) + ./$(HS_PROG) in-place $(PKGCONF_OPTS) >$@ -# -# Clean up -# -CLEAN_FILES += $(SCRIPT_OBJS) $(SCRIPT_LINK) $(DYN_LOADABLE_BITS) ghc-[0-9].* +package.conf : pkgconf + ./$(HS_PROG) install $(PKGCONF_OPTS) >$@ -# -# Source distribution -# -SRC_DEST_FILES=$(patsubst %.prl,%.lprl,$(DYN_LOADABLE_BITS)) ghc.lprl ordering-passes test_mangler - -include $(TOP)/mk/target.mk - -ghc.prl : $(TOP)/mk/version.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 INSTALLING=0 $(SCRIPT_PROG) - -# -# Another hack (hmm..I can see a pattern developing here :-) -# In ghc/driver, we create a symlink from ghc- to -# ghc, but we don't want this included in a source distribution. -# We `solve' this by removing `ghc' from the dist tree here. -dist :: - @echo "Patching dist tree: removing $(SRC_DIST_DIR)/ghc symlink" - $(RM) $(SRC_DIST_DIR)/ghc - -# -# Option vars for the special ways (that the driver has special pleading for). -# -# ToDo: rename -DPROFILING to -D__SCC_PROFILING (or somesuch) -# -DTICKY-TICKY TO __TICKY_TICKY__ -# -# (this is to make the naming consistent with other `standard' hscpp #defines ) - -# 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= +Package.o : ../utils/ghc-pkg/Package.hs -# Way `mp': -WAY_mp_NAME=parallel -WAY_mp_HC_OPTS+=-fstack-check -fparallel -D__PARALLEL_HASKELL__ -optc-DPAR +override datadir = $(libdir) +INSTALL_DATAS += package.conf ghc-usage.txt +INSTALL_PROGS += pkgconf post-install-script -# -# Way `mg': -# Q: is passing -D__GRANSIM__ and -DGRAN to hscpp needed? No, just -D__GRANSIM__ -WAY_mg_NAME=GranSim -WAY_mg_HC_OPTS+=-fstack-check -fconcurrent -fgransim -D__GRANSIM__ -D__CONCURRENT_HASKELL__ -optc-DCONCURRENT -optc-DGRAN +CLEAN_FILES += pkgconf package.conf.inplace package.conf -# -# 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 +include $(TOP)/mk/target.mk