X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=mk%2Fconfig.mk.in;h=eb93eb1b7d820094398e68e75c0cd055895e705e;hb=eb2fa06b787b1fbf9de11cf8a83d0f134f443268;hp=57910d4a245cd468714249d3a0185c669bbc7cb2;hpb=2d5214c090a26d17f46398b23b625adb6fc6cedb;p=ghc-hetmet.git diff --git a/mk/config.mk.in b/mk/config.mk.in index 57910d4..eb93eb1 100644 --- a/mk/config.mk.in +++ b/mk/config.mk.in @@ -38,6 +38,56 @@ # 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@ + +# Pin a suffix on executables? If so, what. (cygwin32 only). +exeext= ################################################################################# # @@ -73,6 +123,15 @@ ProjectsToInstall = glafp-utils ghc hslibs # IncludeTestDirsInBuild=NO +# +# Name variables for the main project +# +Project = Ghc +ProjectName = $($(Project)ProjectName) +ProjectNameShort = $($(Project)ProjectNameShort) +ProjectVersion = $($(Project)ProjectVersion) +ProjectPatchLevel = $($(Project)ProjectPatchLevel) + ################################################################################# # # GHC project @@ -85,40 +144,33 @@ IncludeTestDirsInBuild=NO # # Name variables for ghc: # -GhcProjectName =The Glorious Glasgow Haskell Compilation System -GhcProjectNameShort =ghc -GhcProjectVersion =2.04 -GhcProjectPatchLevel =0 -GhcBuildeeVersion =204 -GhcBuilderVersion =29 - -# -# Name variables for the fptools, for now equal to the above -# ghc stuff -# -ProjectName =$(GhcProjectName) -ProjectNameShort =$(GhcProjectNameShort) -ProjectVersion =$(GhcProjectVersion) -ProjectPatchLevel =$(GhcProjectPatchLevel) - +GhcProjectName = The Glorious Glasgow Haskell Compilation System +GhcProjectNameShort = ghc +GhcProjectVersion = 2.09 +GhcProjectPatchLevel = 0 #--------------------------------------------------------------- # # Variables that control how the compiler itself is built # Specify the Haskell compiler to be used to compile the compiler itself -# WithGhcHc Path name of the compiler to use -# Ghc2_0 Whether this compiler is GHC 2.0 or later -# (which affects gruesome details about -# how mutually recursive modules are handled) -# WithGhcHcType What "type" of compiler is being used -# Valid options: +# +# WithGhcHc Path name of the compiler to use +# +# Ghc2_0 Whether this compiler is GHC 2.0 or later +# (which affects gruesome details about +# how mutually recursive modules are handled) +# +# WithGhcHcType What "type" of compiler is being used +# Valid options: # HC_CHALMERS_HBC # HC_GLASGOW_GHC # HC_ROJEMO_NHC # HC_UNSPECIFIED + WithGhcHc = ghc-0.29 Ghc2_0=NO + # Unused, we think # WithGhcHcType=HC_GLASGOW_GHC @@ -129,9 +181,16 @@ GhcCompilerWays= # Extra option flags to pass to the compiler that compiles the compiler # (Ones that are essential are wired into ghc/compiler/Makefile) # Typical ones: -# -O compiler an optimised compiler +# -H25m allocate a bigger heap (default is 6m) +# +# -O compile an optimised compiler +# NB! If you add -O you'll almost certainly need to increase +# the amount of heap space too (to 15m or more) +# # -DDEBUG include consistency/assertion checks in the compiled compiler -# -fshow-import-specs show import specialisations +# +# -dcore-lint check the types after every pass of the compiler; +# a pretty strong internal check GhcHcOpts= # GhcWithHscBuiltViaC - build GHC compiler proper (\`hsc') from .hc files? @@ -153,10 +212,7 @@ GhcWithRegisterised=YES # # Target platforms supported: # i386, alpha & sparc -GhcWithNativeCodeGen=YES - -# Build the compiler with the deforester included? -GhcWithDeforester=NO +GhcWithNativeCodeGen=$(shell if (test x$(findstring $(HostArch_CPP),i386 alpha sparc) = x); then echo NO; else echo YES; fi) # # Building various ways? @@ -179,8 +235,29 @@ GhcLibWays=p # Option flags to pass to GHC when it's compiling prelude modules # Typically these are things like -O or -dcore-lint # The ones that are *essential* are wired into ghc/lib/Makefile -GhcLibHcOpts= -split-objs -odir $(basename $*) +# +# -O is pretty desirable, otherwise no inlining of prelude +# things (incl "+") happens when compiling with this compiler + +# +# Splitting profiled code produces awfully large archives under ELF, so +# we turn it off here. +# +# ToDo: track down the source of this. +# +ifneq "$(strip $(way))" "p" +GhcLibHcOpts= -O -split-objs -odir $* +else +GhcLibHcOpts= -O +endif + +# what to include in a binary distribution +GhcMainDir = ghc +GhcBinDistDirs = ghc hslibs +GhcBinDistDocs = docs ghc/docs/users_guide +GhcBinDistPrlScripts = ghc stat2resid hstags mkdependHS +GhcBinDistLibPrlScripts = hscpp ################################################################################# # @@ -222,7 +299,28 @@ HsLibHcOpts=$(GhcLibHcOpts) # ################################################################################# +# +# Name variables for happy: +# +HappyProjectName = Happy +HappyProjectNameShort = happy +HappyProjectVersion = 1.5 +HappyProjectPatchLevel = 0 +# The compiler you'd like to use to compile Happy +WithHappyHc = $(WithGhcHc) + +# HappyHcOpts gives the flags to pass to the Haskell compiler used +# to compile the Happy sources with. +# +HappyHcOpts = + +# what to include in a binary distribution + +HappyMainDir = happy +HappyBinDistDirs = happy +HappyBinDistDocs = happy/doc +HappyBinDistShScripts = happy ################################################################################# # @@ -232,8 +330,6 @@ HsLibHcOpts=$(GhcLibHcOpts) # ################################################################################# - - ################################################################################# # # green-card project @@ -372,54 +468,6 @@ endif ################################################################################# # -# 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@ - -# 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@ - -################################################################################# -# # Utilities programs: where to find them # ################################################################################# @@ -451,6 +499,7 @@ MKDEPENDC_PREFIX = $(GLAFP_UTILS)/mkdependC/ LTX_PREFIX = $(GLAFP_UTILS)/ltx/ RUNTEST_PREFIX = $(GLAFP_UTILS)/runstdtest/ VERBATIM_PREFIX = $(GLAFP_UTILS)/verbatim/ +SGMLVERB_PREFIX = $(GLAFP_UTILS)/sgmlverb/ ETAGS_PREFIX = $(GLAFP_UTILS)/etags/ MSUB_PREFIX = $(GLAFP_UTILS)/msub/ LNDIR_PREFIX = $(GLAFP_UTILS)/lndir/ @@ -464,6 +513,7 @@ 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/ @@ -572,6 +622,12 @@ REAL_SHELL=$(SHELL) SIZE = size STRIP = strip TAR = @TarCmd@ + +# +# Under cygwin32, we have to deal with .exe suffixes +# +EXE_SUFFIX=@ExeSuffix@ + # # This is special to literate/, ToDo: add literate-specific # configure setup to literate/. @@ -587,6 +643,12 @@ TROFF = troff UNAME = uname YACC = @YaccCmd@ +#----------------------------------------------------------------------------- +# SGML stuff (currently not configured - we assume you have it) + +SGML2LATEX = sgml2latex +SGML2HTML = sgml2html +SGML2TXT = sgml2txt #----------------------------------------------------------------------------- # FPtools support software @@ -600,9 +662,13 @@ LNDIR = $(LNDIR_PREFIX)lndir MSUB = $(MSUB_PREFIX)msub ETAGS = $(ETAGS_PREFIX)etags VERBATIM = $(VERBATIM_PREFIX)verbatim +SGMLVERB = $(SGMLVERB_PREFIX)sgmlverb +SGML2LATEX = sgml2latex RUNTEST = $(RUNTEST_PREFIX)runstdtest HAPPY = @HappyCmd@ +HAPPY_VERSION = @HappyVersion@ LX = @LxCmd@ +GREENCARD = @GreencardCmd@ ifeq "$(HAPPY)" "" HAPPY = $(HAPPY_PREFIX)happy