X-Git-Url: http://git.megacz.com/?p=ghc-hetmet.git;a=blobdiff_plain;f=mk%2Fconfig.mk.in;h=fb9f40fae1f87fbe062a5ed3130d36288549b573;hp=c8fa245ed7f98e48770ad00bc802940bbc0372ff;hb=9f201152779e7d931b016163e0abb3a81cf5a02e;hpb=1fb1ab5d53a09607e7f6d2450806760688396387 diff --git a/mk/config.mk.in b/mk/config.mk.in index c8fa245..fb9f40f 100644 --- a/mk/config.mk.in +++ b/mk/config.mk.in @@ -38,6 +38,54 @@ # included by boilerplate.mk (see boilerplate.mk for a list). +################################################################################# +# +# Project-wide platform variables +# +################################################################################# + +# A "platform" is the GNU cpu-type/manufacturer/operating-system target machine +# specifier. E.g. sparc-sun-solaris2 + +HOSTPLATFORM = @HostPlatform@ +TARGETPLATFORM = @TargetPlatform@ +BUILDPLATFORM = @HostPlatform@ + +# Hack alert: +# in one or two places, we need to get at the OS version (major and perhaps even minor), +# HostOS_Full is the OS name reported by AC_CANONICAL_SYSTEM. +# +HostPlatform_CPP = @HostPlatform_CPP@ +HostArch_CPP = @HostArch_CPP@ +HostOS_CPP = @HostOS_CPP@ +HostOS_Full = @HostOS_Full@ +HostVendor_CPP = @HostVendor_CPP@ + +# +# ToDo: check if these can be purged now. -- sof +# + +@HostPlatform_CPP@_HOST = 1 +@HostPlatform_CPP@_TARGET = 1 +@HostPlatform_CPP@_BUILD = 1 + +@HostArch_CPP@_HOST_ARCH = 1 +@HostArch_CPP@_TARGET_ARCH = 1 +@HostArch_CPP@_BUILD_ARCH = 1 + +@HostOS_CPP@_HOST_OS = 1 +@HostOS_CPP@_TARGET_OS = 1 +@HostOS_CPP@_BUILD_OS = 1 + +@HostVendor_CPP@_HOST_VENDOR = 1 +@HostVendor_CPP@_TARGET_VENDOR = 1 +@HostVendor_CPP@_BUILD_VENDOR = 1 + +# Leading underscores on symbol names in object files +# Valid options: YES/NO +# +LeadingUnderscore=@LeadingUnderscore@ + ################################################################################# # @@ -61,7 +109,12 @@ # * ghc&hslibs next # then it's up to you -ProjectsToBuild = glafp-utils literate ghc hslibs +ProjectsToBuild = glafp-utils literate ghc hslibs +# +# Make a distinction between building and installing, ProjectsToInstall +# does not include the literate bits.. +# +ProjectsToInstall = glafp-utils ghc hslibs # # Should the various project tests directories be built? @@ -82,9 +135,9 @@ IncludeTestDirsInBuild=NO # GhcProjectName =The Glorious Glasgow Haskell Compilation System GhcProjectNameShort =ghc -GhcProjectVersion =2.02 +GhcProjectVersion =2.05 GhcProjectPatchLevel =0 -GhcBuildeeVersion =202 +GhcBuildeeVersion =205 GhcBuilderVersion =29 # @@ -148,15 +201,23 @@ GhcWithRegisterised=YES # # Target platforms supported: # i386, alpha & sparc -GhcWithNativeCodeGen=YES +GhcWithNativeCodeGen=$(shell if (test x$(findstring $(HostArch_CPP),i386 alpha sparc) = x); then echo NO; else echo YES; fi) # Build the compiler with the deforester included? GhcWithDeforester=NO +# +# Building various ways? +# (right now, empty if not). +BuildingParallel=$(subst mp,YES,$(filter mp,$(WAYS))) +BuildingConcurrent=$(subst mc,YES,$(filter mc,$(WAYS))) +BuildingProfiling=$(subst p,YES,$(filter p,$(WAYS))) +BuildingGranSim=$(subst mg,YES,$(filter mg,$(WAYS))) +BuildingProfilingConcurrent=$(subst mr,YES,$(filter mr,$(WAYS))) #--------------------------------------------------------------- # -# Variables that control how the prelude libararies and runtime system are built +# Variables that control how the prelude libraries and runtime system are built # What extra ways to build the libraries in # In addition to the normal sequential way, the default is to also build @@ -180,7 +241,12 @@ GhcLibHcOpts= -split-objs -odir $(basename $*) # Build the Haskell Readline bindings? # -HsLibsWithReadline=YES +HsLibsWithReadline=NO +# +# Include path to readline.h +# (no path == in standard include path) +# +ReadlineIncludePath= # Build the socket libraries? # @@ -192,6 +258,9 @@ HsLibsWithSockets=YES # HsLibWays=$(GhcLibWays) +# Option flags for hslibs are by default the same as for the options +# used for the prelude libs (see above). +HsLibHcOpts=$(GhcLibHcOpts) ################################################################################# # @@ -265,37 +334,72 @@ NoFibHcOpts= # ################################################################################# -# These variables are all ":=" variables so that you can easily attach -# extra stuff to the end of them, like this: -# -# libdir := $(libdir)/ghc - -TMPDIR := /tmp +TMPDIR = /tmp # FPTOOLS_TOP: the top of the fptools hierarchy, absolute path. -FPTOOLS_TOP_ABS := @hardtop@ +FPTOOLS_TOP_ABS = @hardtop@ # # Installation directories, we don't use half of these, # but since the configure script has them on offer while # passing through, we might as well set them. -prefix := @prefix@ -exec_prefix := @exec_prefix@ -bindir := @bindir@ -sbindir := @sbindir@ -libexecdir := @libexecdir@ -datadir := @datadir@ -sysconfdir := @datadir@ -sharedstatedir := @sharedstatedir@ -localstatedir := @localstatedir@ -libdir := @libdir@ -infodir := @infodir@ -includedir := @includedir@ -oldincludedir := @oldincludedir@ -mandir := @mandir@ -srcdir := @srcdir@ +prefix = @prefix@ +exec_prefix = @exec_prefix@ +bindir = @bindir@ +#UNUSED, see below: libexecdir = @libexecdir@ +datadir = @datadir@ +#sysconfdir = @datadir@ +#sharedstatedir = @sharedstatedir@ +#localstatedir = @localstatedir@ +libdir = @libdir@ +infodir = @infodir@ +includedir = @includedir@ +oldincludedir = @oldincludedir@ +mandir = @mandir@ +#UNUSED:srcdir = @srcdir@ + +# +# Default values for most of the above are only set if +# they weren't configured to anything in particular +# via the configure script. (i.e., we make no assumption +# that the autoconf-generated script will assign defaults +# to all of the above). +# +ifeq "$(strip $(exec_prefix))" "" +exec_prefix = $(prefix) +endif +ifeq "$(strip $(bindir))" "" +bindir = $(exec_prefix)/bin +endif + +# +# NOTE: by intention, libexecdir and libdir point to +# the same place. +# => Only way to override this is to set libexecdir= on the command line. +# (NOTE: configure script setting is ignored). +libexecdir = $(libdir) + +ifeq "$(strip $(datadir))" "" +datadir = $(prefix)/share +endif +ifeq "$(strip $(libdir))" "" +libdir = $(exec_prefix)/lib +endif +ifeq "$(strip $(infodir))" "" +infodir = $(prefix)/info +endif +ifeq "$(strip $(includedir))" "" +includedir = $(prefix)/include +endif +ifeq "$(strip $(oldincludedir))" "" +oldincludedir = /usr/include +endif +ifeq "$(strip $(mandir))" "" +mandir = $(prefix)/man +endif + ################################################################################# # @@ -316,49 +420,6 @@ srcdir := @srcdir@ ################################################################################# # -# Platform -# -################################################################################# - -# A "platform" is the GNU cpu-type/manufacturer/operating-system target machine -# specifier. E.g. sparc-sun-solaris2 - -HOSTPLATFORM = @HostPlatform@ -TARGETPLATFORM = @TargetPlatform@ -BUILDPLATFORM = @HostPlatform@ - -HostPlatform_CPP = @HostPlatform_CPP@ -HostArch_CPP = @HostArch_CPP@ -HostOS_CPP = @HostOS_CPP@ -HostVendor_CPP = @HostVendor_CPP@ - -# -# ToDo: check if these can be purged now. -- sof -# - -@HostPlatform_CPP@_HOST = 1 -@HostPlatform_CPP@_TARGET = 1 -@HostPlatform_CPP@_BUILD = 1 - -@HostArch_CPP@_HOST_ARCH = 1 -@HostArch_CPP@_TARGET_ARCH = 1 -@HostArch_CPP@_BUILD_ARCH = 1 - -@HostOS_CPP@_HOST_OS = 1 -@HostOS_CPP@_TARGET_OS = 1 -@HostOS_CPP@_BUILD_OS = 1 - -@HostVendor_CPP@_HOST_VENDOR = 1 -@HostVendor_CPP@_TARGET_VENDOR = 1 -@HostVendor_CPP@_BUILD_VENDOR = 1 - -# Leading underscores on symbol names in object files -# Valid options: YES/NO -# -LeadingUnderscore=@LeadingUnderscore@ - -################################################################################# -# # Utilities programs: where to find them # ################################################################################# @@ -399,9 +460,11 @@ MKDIRHIER_PREFIX = $(GLAFP_UTILS)/mkdirhier/ LITERATE = $(FPTOOLS_TOP)/literate LITERATE_PREFIX = $(FPTOOLS_TOP)/literate/ +INFO_PREFIX = $(FPTOOLS_TOP)/literate/info-utils/ TEXI2HTML_PREFIX = $(LITERATE_PREFIX)texi2html/ HAPPY_PREFIX = $(FPTOOLS_TOP)/happy/src/ +GREENCARD_PREFIX = $(FPTOOLS_TOP)/green-card/src/ UNLIT_PREFIX = $(FPTOOLS_TOP)/ghc/utils/unlit/ UGEN_PREFIX = $(FPTOOLS_TOP)/ghc/utils/ugen/ @@ -464,6 +527,12 @@ CTAGS = $(ETAGS) RAWCPP = @RAWCPP@ GNUCPP = @GNUCPP@ INSTALL = @INSTALL@ +# +# Sigh - the autoconf macro for INSTALL will subst a relative path to the fallback +# install-sh script (if chosen). This not terribly useful to us, so we convert +# it into an abs. path. +# +INSTALL := $(subst .././install-sh,$(FPTOOLS_TOP_ABS)/install-sh,$(INSTALL)) LATEX = latex LN_S = @LN_S@ MANMACROS = -man @@ -478,6 +547,29 @@ RANLIB = @RANLIB@ RM = rm -f SED = @SedCmd@ SHELL = /bin/sh +# +# In emergency situations, REAL_SHELL is used to perform shell commands +# from within the ghc driver script, by scribbling the command line to +# a temp file and then having $(REAL_SHELL) execute it. +# +# The reason for having to do this is that overly long command lines +# cause unnecessary trouble with some shells (e.g., /bin/sh on Solaris +# 2.5.1), which is why this backdoor is provided. The situation of overly +# long command lines is either encountered while doing `make boot' in ghc/compiler, +# or when linking the compiler binary (`hsc'). +# +# We do not use SHELL to execute long commands, as `make' will more than likely +# override whatever setting you have in your environment while executing. + +# By default, REAL_SHELL is set equal SHELL, which is not really a smart move +# as it SHELL that will show up the bogosity in the first place, but setting +# it to anything else isn't really portable. +# +# ====> If long command lines cause you trouble, invoke `ghc' (via `make' or otherwise) +# with REAL_SHELL set to something else than /bin/sh, for instance, your favourite +# command shell. +# +REAL_SHELL=$(SHELL) SIZE = size STRIP = strip TAR = @TarCmd@ @@ -512,8 +604,9 @@ VERBATIM = $(VERBATIM_PREFIX)verbatim RUNTEST = $(RUNTEST_PREFIX)runstdtest HAPPY = @HappyCmd@ LX = @LxCmd@ +GREENCARD = @GreencardCmd@ -ifneq "$(HAPPY)" "" +ifeq "$(HAPPY)" "" HAPPY = $(HAPPY_PREFIX)happy endif