#-----------------------------------------------------------------------------
+# $Id: Makefile,v 1.36 2000/06/25 17:20:20 panne 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)
+ifeq "$(GhcWithHscBuiltViaC)" "YES"
+HC=$(GHC_INPLACE)
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)
-
-#
-# 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 TOP_PWD
-endif
-
-all :: $(DYN_LOADABLE_BITS)
-
-#
-# 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)
-
-#
-# 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)
-
-#
-# depend setup: other directories need the driver script to compute
-# their dependencies, so `depend' is simply an alias for `all' here.
-depend :: all
-
-#
-# Clean up
-#
-CLEAN_FILES += $(SCRIPT_OBJS) $(DYN_LOADABLE_BITS)
-
-#
-# Source distribution
-#
-SRC_DEST_FILES=$(patsubst %.prl,%.lprl,$(DYN_LOADABLE_BITS)) ghc.lprl ordering-passes test_mangler
+SRC_HC_OPTS += -fglasgow-exts -cpp -syslib concurrent -syslib posix -syslib text
+
+HS_PROG = ghc-$(ProjectVersion)
+HS_SRCS = Config.hs Package.hs Main.hs
+MKDEPENDHS_SRCS = Config.hs Main.hs PackageSrc.hs
+LINK = ghc
+
+SUBDIRS = mangler split stats
+
+# -----------------------------------------------------------------------------
+# Create driver configuration
+
+boot :: Config.hs
+
+Config.hs : $(FPTOOLS_TOP)/mk/config.mk Makefile
+ @$(RM) -f Config.hs
+ @echo -n "Creating Config.hs ... "
+ @echo "module Config where" >>Config.hs
+ @echo "_ProjectName = \"$(ProjectName)\"" >> Config.hs
+ @echo "_ProjectVersion = \"$(ProjectVersion)\"" >> Config.hs
+ @echo "_ProjectVersionInt = \"$(ProjectVersionInt)\"" >> Config.hs
+ @echo "_ProjectPatchLevel = \"$(ProjectPatchLevel)\"" >> Config.hs
+ @echo "_HOSTPLATFORM = \"$(HOSTPLATFORM)\"" >> Config.hs
+ @echo "_TARGETPLATFORM = \"$(TARGETPLATFORM)\"" >> Config.hs
+ @echo "_CURRENT_DIR = \"$(CURRENT_DIR)\"" >> Config.hs
+ @echo "_GHC_LIB_DIR = \"$(GHC_LIB_DIR)\"" >> Config.hs
+ @echo "_GHC_RUNTIME_DIR = \"$(GHC_RUNTIME_DIR)\"" >> Config.hs
+ @echo "_GHC_UTILS_DIR = \"$(GHC_UTILS_DIR)\"" >> Config.hs
+ @echo "_GHC_INCLUDE_DIR = \"$(GHC_INCLUDE_DIR)\"" >> Config.hs
+ @echo "_GHC_DRIVER_DIR = \"$(GHC_DRIVER_DIR)\"" >> Config.hs
+ @echo "_GCC = \"$(WhatGccIsCalled)\"" >> Config.hs
+ @echo "_GhcWithNativeCodeGen = \"$(GhcWithNativeCodeGen)\"" >> Config.hs
+ @echo "_LeadingUnderscore = \"$(LeadingUnderscore)\"" >> Config.hs
+ @echo "_GHC_MKDEPENDHS = \"$(GHC_MKDEPENDHS)\"" >> Config.hs
+ @echo "_GHC_UNLIT = \"$(GHC_UNLIT)\"" >> Config.hs
+ @echo "_GHC_HSCPP = \"$(GHC_HSCPP)\"" >> Config.hs
+ @echo "_GHC_HSC = \"$(GHC_HSC)\"" >> Config.hs
+ @echo "_GHC_MANGLER = \"$(GHC_MANGLER)\"" >> Config.hs
+ @echo "_GHC_SPLIT = \"$(GHC_SPLIT)\"" >> Config.hs
+ @echo "_GHC_STATS = \"$(GHC_STATS)\"" >> Config.hs
+ @echo "_GHC_SYSMAN = \"$(GHC_SYSMAN)\"" >> Config.hs
+ @echo "_EnableWin32DLLs = \"$(EnableWin32DLLs)\"" >> Config.hs
+ @echo "_CP = \"$(CP)\"" >> Config.hs
+ @echo "_RM = \"$(RM)\"" >> Config.hs
+ @echo "_CONTEXT_DIFF = \"$(CONTEXT_DIFF)\"" >> Config.hs
+ @echo "_HaveLibGmp = \"$(HaveLibGmp)\"" >> Config.hs
+ @echo "_GhcWithRegisterised = \"$(GhcWithRegisterised)\"" >> Config.hs
+ @echo "_USER_WAY_NAMES = \"$(USER_WAY_NAMES)\"" >> Config.hs
+ @echo "_USER_WAY_OPTS = \"$(USER_WAY_OPTS)\"" >> Config.hs
+ @echo "_libdir = \"$(libdir)\"" >> Config.hs
+ @echo "_libexecdir = \"$(libexecdir)\"" >> Config.hs
+ @echo "_datadir = \"$(datadir)\"" >> Config.hs
+ @echo "_bindir = \"$(bindir)\"" >> Config.hs
+ @echo "_TMPDIR = \"$(TMPDIR)\"" >> Config.hs
+ @echo "_FPTOOLS_TOP_ABS = \"$(FPTOOLS_TOP_ABS)\"" >> Config.hs
+ @echo done.
+
+CLEAN_FILES += Config.hs
+
+# -----------------------------------------------------------------------------
+# create ghc-inplace, a convenient way to run ghc from the build tree...
+
+all :: ghc-inplace
+
+ghc-inplace : ghc
+ @$(RM) $@
+ echo '#!/bin/sh' >>$@
+ echo exec $(FPTOOLS_TOP_ABS)/ghc/driver/ghc -B$(FPTOOLS_TOP_ABS) '"$$@"' >>$@
+ chmod 755 $@
+
+CLEAN_FILES += ghc-inplace
+
+# -----------------------------------------------------------------------------
+# package configuration files...
+
+all :: package.conf package.conf.inplace
+
+pkgconf : Config.o Package.o PackageSrc.o
+ $(HC) $(HC_OPTS) $(LD_OPTS) Config.o Package.o PackageSrc.o -o pkgconf
+
+package.conf.inplace : pkgconf
+ ./pkgconf in-place >$@
+
+package.conf : pkgconf
+ ./pkgconf install >$@
+
+INSTALL_DATAS += package.conf
+
+CLEAN_FILES += pkgconf package.conf.inplace package.conf
+
+# -----------------------------------------------------------------------------
+# installation...
+
+INSTALL_PROGS = ghc-$(ProjectVersion)
+
+override datadir=$(libdir)
+INSTALL_DATAS += ghc-usage.txt
+
+# -----------------------------------------------------------------------------
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).
-#
-# 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=
-
-# Way `mc': concurrent
-WAY_mc_NAME=concurrent
-WAY_mc_HC_OPTS+=-fstack-check -fconcurrent -D__CONCURRENT_HASKELL__ -optc-DCONCURRENT
+# we need the driver for generating dependencies...
+boot :: all
-# Way `mr':
-WAY_mr_NAME=profiled concurrent
-WAY_mr_HC_OPTS+=-fstack-check -fconcurrent -fscc-profiling -D__CONCURRENT_HASKELL__ -DPROFILING -optc-DCONCURRENT -optc-DPROFILING
+# -----------------------------------------------------------------------------
+# Create link to from ghc-x.xx to ghc...
-# Way `mt':
-WAY_mt_NAME=ticky-ticky concurrent
-WAY_mt_HC_OPTS+=-fstack-check -fconcurrent -fticky-ticky -D__CONCURRENT_HASKELL__ -DTICKY-TICKY -optc-DCONCURRENT -optc-DTICKY_TICKY
+all :: $(LINK)
-# Way `mp':
-WAY_mp_NAME=parallel
-WAY_mp_HC_OPTS+=-fstack-check -fconcurrent -D__PARALLEL_HASKELL__ -optc-DPAR -optc-DCONCURRENT
+$(LINK) : $(HS_PROG)
+ @if ( $(PERL) -e '$$fn="$(LINK)"; exit ((! -f $$fn || -l $$fn) ? 0 : 1);' ); then \
+ echo "Creating a symbolic link from $(HS_PROG) to $(LINK)"; \
+ $(RM) $(LINK); \
+ $(LN_S) $(HS_PROG) $(LINK); \
+ else \
+ echo "Creating a symbolic link from $(HS_PROG) to $(LINK) failed: \`$(LINK)' already exists"; \
+ echo "Perhaps remove \`$(LINK)' manually?"; \
+ exit 1; \
+ fi;
-#
-# 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
-
-#
-# 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
+CLEAN_FILES += $(LINK)
-WAY_du_NAME=dual-mode GC
-WAY_du_HC_OPTS+=-optc-DGCdu
+install ::
+ @if ( $(PERL) -e '$$fn="$(bindir)/$(LINK)"; exit ((! -f $$fn || -l $$fn) ? 0 : 1);' ); then \
+ echo "Creating a symbol link from $(HS_PROG) to $(LINK) in $(bindir)"; \
+ $(RM) $(bindir)/$(LINK); \
+ $(LN_S) $(HS_PROG) $(bindir)/$(LINK); \
+ else \
+ echo "Creating a symbol link from $(HS_PROG) to $(LINK) in $(bindir) failed: \`$(bindir)/$(LINK)' already exists"; \
+ echo "Perhaps remove \`$(bindir)/$(LINK)' manually?"; \
+ exit 1; \
+ fi;