#-----------------------------------------------------------------------------
-# $Id: Makefile,v 1.3 1997/03/14 07:59:40 simonpj Exp $
+#
TOP=..
CURRENT_DIR=ghc/driver
include $(TOP)/mk/boilerplate.mk
-
-#
-# The ways setup doesn't apply to the driver
#
-WAYS=
+# The driver needs to get at the version
+include $(TOP)/mk/version.mk
INSTALLING=0
DYN_LOADABLE_BITS = \
ghc-asm.prl \
- ghc-recomp.prl \
ghc-iface.prl \
ghc-consist.prl \
ghc-split.prl
-SCRIPT_PROG = ghc
+SCRIPT_PROG = ghc-$(ProjectVersion)
+SCRIPT_LINK = ghc
SCRIPT_OBJS = ghc.prl
-INTERP = $(PERL)
+INTERP=perl
#
# The driver needs to know the options and names for
SCRIPT_SUBST_VARS := \
INSTALLING \
- PROJECTNAME PROJECTVERSION PROJECTPATCHLEVEL \
- CURRENT_DIR TMPDIR HOSTPLATFORM TARGETPLATFORM \
+ 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 \
- CP RM PERL CONTEXT_DIFF \
+ CP RM CONTEXT_DIFF LibGmp \
$(WAY_NAMES) $(WAY_OPTS)
#
ifeq "$(BIN_DIST)" "1"
SCRIPT_PREFIX_FILES=prefix.txt
else
-SCRIPT_SUBST_VARS += TOP_PWD INSTLIBDIR_GHC INSTDATADIR_GHC PERL
+SCRIPT_SUBST_VARS += libdir libexecdir datadir bindir TMPDIR TOP_PWD
endif
all :: $(DYN_LOADABLE_BITS)
#
# ToDo: allow different install name for driver?
#
-INSTALL_PROGS += $(SCRIPT_PROG)
-INSTALL_LIBS += $(DYN_LOADABLE_BITS)
+INSTALL_SCRIPTS += $(SCRIPT_PROG)
+INSTALL_LIBS += $(DYN_LOADABLE_BITS)
#
# Before really installing the driver, we have to
#
# Clean up
#
-CLEAN_FILES += $(SCRIPT_OBJS) $(DYN_LOADABLE_BITS)
+CLEAN_FILES += $(SCRIPT_OBJS) $(SCRIPT_LINK) $(DYN_LOADABLE_BITS) ghc-[0-9].*
#
# Source distribution
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 $(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-<whatever-version> 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
+# 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_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
+WAY_mp_HC_OPTS+=-fstack-check -fparallel -D__PARALLEL_HASKELL__ -optc-DPAR
#
# Way `mg':
-# Q: is passing -D__GRANSIM__ and -DGRAN to hscpp needed?
+# 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__ -DGRAN -optcpp-D__GRANSIM__ -optc-DGRAN -optc-D__CONCURRENT_HASKELL__ -optc-DCONCURRENT
+WAY_mg_HC_OPTS+=-fstack-check -fconcurrent -fgransim -D__GRANSIM__ -D__CONCURRENT_HASKELL__ -optc-DCONCURRENT -optc-DGRAN
#
# Ways for different garbage collectors