X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=mk%2Fconfig.mk.in;h=a07022560c9e063d8768fcd2aa601e7c7fdc8cdd;hb=27d13cb655147c28eeed0f06cac6fc40c5d778aa;hp=0e2896a2fb489493c736b8607699b694ffa748be;hpb=5a5747202b4fb5c42bdc1ebcacb9f9b7bf87cdc7;p=ghc-hetmet.git diff --git a/mk/config.mk.in b/mk/config.mk.in index 0e2896a..a070225 100644 --- a/mk/config.mk.in +++ b/mk/config.mk.in @@ -97,29 +97,31 @@ exeext=@exeext@ # ################################################################################ -# -# What parts to build: An fptools build tree does not have to be built -# all in one go. By setting the list of ProjectsToBuild in build.mk you can -# control which projects are built. -# -# Caution: the projects are built in the order given here, so if some -# projects use others you must list them in the correct order. -# -# Generally: * glafp-utils should be first -# * happy next -# * ghc next -# then it's up to you +# BootingFromHc - build GHC and the libraries from .hc files? +BootingFromHc = @BootingFromHc@ -ifeq "$(GhcWithHscBuiltViaC)" "YES" -# need hslibs/lang first if we're bootstrapping -ProjectsToBuild = glafp-utils hslibs ghc +# BootingFromUnregisterisedHc - treat .hc files as containing unregisterised +# rather than registerised code, i.e., disable the mangler? +BootingFromUnregisterisedHc = @BootingFromUnregisterisedHc@ + +# build the libs first if we're bootstrapping from .hc files +ifeq "$(BootingFromHc)" "YES" +AllProjects = glafp-utils hslibs ghc green-card happy hdirect hood nofib else -ProjectsToBuild = glafp-utils ghc hslibs +AllProjects = glafp-utils ghc hslibs green-card happy hdirect hood nofib endif + # -# Make a distinction between building and installing +# (OPTIONAL) set ProjectsToBuild to a list of projects to be built. If this +# list is empty, then all projects present in the source tree will be built. # -ProjectsToInstall = glafp-utils ghc hslibs +ProjectsToBuild = + +# +# set ProjectsDontInstall to a list of projects which are normally built but +# not installed. +# +ProjectsDontInstall = glafp-utils nofib # # Should the various project tests directories be built? @@ -141,22 +143,8 @@ IncludeTestDirsInBuild=NO # #--------------------------------------------------------------- -# Specify the Haskell compiler to be used to compile the compiler itself -# -# WithGhcHc Path name of the compiler to use -# -# WithGhcHcType What "type" of compiler is being used -# Valid options: -# HC_CHALMERS_HBC -# HC_GLASGOW_GHC -# HC_ROJEMO_NHC -# HC_UNSPECIFIED - -WithGhcHc = @WithHc@ - -# Variable which is set to the version number of the $(WithGhcHc) we're using. -# Not currently used, but might come in handy sometime soon. -#WithGhcHcVersion = $(shell echo `if ( $(WithGhcHc) --version 2>/dev/null >/dev/null ) then $(WithGhcHc) --version 2>&1 | @SedCmd@ -e 's/^.*version [^0-9]*\([.0-9]*\).*/\1/;s/\.//'; else echo unknown; fi; ` ) +# The compiler used to build GHC is $(GHC). To change the actual compiler +# used, re-configure with --with-ghc=. # Extra ways in which to build the compiler (for example, you might want to # build a profiled compiler so you can see where it spends its time) @@ -173,21 +161,49 @@ GhcCompilerWays= # # -dcore-lint check the types after every pass of the compiler; # a pretty strong internal check -GhcHcOpts=-O - -# GhcWithHscBuiltViaC - build GHC compiler proper (\`hsc') from .hc files? -GhcWithHscBuiltViaC=@BootingFromHc@ +GhcHcOpts=-O -Rghc-timing -# Build a registerised version of hsc and runtime -# (unregisterised used for Hugs at the moment) -GhcWithRegisterised=YES +# Build a compiler that will build *unregisterised* libraries and +# binaries by default. Unregisterised code is supposed to compile and +# run without any support for architecture-specific assembly mangling, +# register assignment or tail-calls, and is therefore a good way to get +# started when porting GHC to new architectures. +# +# If this is set to NO, you can still use the unregisterised way +# (way 'u') to get unregisterised code, but the default way will be +# registerised. +# +# NOTE: this is not the same as building the compiler itself +# unregisterised. That's done by either (a) bootstrapping with a +# compiler that was built with GhcUnregisterized=YES, or (b) +# bootstrapping with a compiler that has way 'u' libraries, and the +# flag '-unreg' is added to GhcHcOpts above. +# +GhcUnregisterised=NO # Build a compiler with a native code generator backend # (as well as a C backend) # # Target platforms supported: # i386, alpha & sparc -GhcWithNativeCodeGen=$(shell if (test x$(findstring $(HostArch_CPP),i386 alpha sparc) = x); then echo NO; else echo YES; fi) +ifneq "$(findstring $(HostArch_CPP), i386 alpha sparc)" "" +GhcWithNativeCodeGen=YES +else +GhcWithNativeCodeGen=NO +endif + +HaveLibDL = @HaveLibDL@ + +# Include GHCi in the compiler. Default to NO for the time being. + +ifneq "$(findstring $(HostOS_CPP), mingw32 linux solaris2 freebsd netbsd openbsd)" "" +GhcWithInterpreter=YES +ifeq "$(HaveLibDL)" "YES" +SRC_HC_OPTS += -ldl +endif +else +GhcWithInterpreter=NO +endif # # Building various ways? @@ -195,11 +211,6 @@ GhcWithNativeCodeGen=$(shell if (test x$(findstring $(HostArch_CPP),i386 alpha s BuildingParallel=$(subst mp,YES,$(filter mp,$(WAYS))) BuildingGranSim=$(subst mg,YES,$(filter mg,$(WAYS))) -# Include compiler support for letting the compiler (optionally) report -# your compilation to a central server for generation of fun stats. -# -GhcReportCompiles=NO - #------------------------------------------------------------------------------ # Options for GHC's Prelude @@ -207,7 +218,7 @@ GhcReportCompiles=NO # In addition to the normal sequential way, the default is to also build # profiled prelude libraries. # When booting from .hc files, turn this off. -ifeq "$(GhcWithHscBuiltViaC)" "YES" +ifeq "$(BootingFromHc)" "YES" GhcLibWays= else GhcLibWays=p @@ -221,17 +232,35 @@ endif # -O is pretty desirable, otherwise no inlining of prelude # things (incl "+") happens when compiling with this compiler -GhcLibHcOpts=-O +GhcLibHcOpts=-O -Rghc-timing # Win32 only: Enable the RTS and libraries to be built as DLLs -# Don't split object files for libs if we're building DLLs -EnableWin32DLLs=@EnableWin32DLLs@ -ifeq "$(EnableWin32DLLs)" "YES" -SplitObjs=NO -else +DLLized=@EnableWin32DLLs@ + +# Win32 only: are we building a compiler that tries to reduce external +# dependencies? i.e., one that doesn't assume that the user has got +# the cygwin toolchain installed on his/her Win32 box. +# +# GHC is still dependent on GNU tools in the backend (gcc to further process +# .c/.hc/.s/.o files + 'perl' to mangle and split), but using this +# option a GHC distribution can be put together which includes a minimal +# set of these open source tools. +# +MinimalUnixDeps=@MinimalUnixDeps@ + +# Don't split object files for libs if we're building DLLs, or booting from +# .hc files. SplitObjs=YES -endif +ifeq "$(DLLized)" "YES" +SplitObjs=NO +endif +ifeq "$(BootingFromHc)" "YES" +SplitObjs=NO +endif +ifeq "$(GhcUnregisterised)" "YES" +SplitObjs=NO +endif # Strip local symbols from libraries? This can make the libraries smaller, # but makes debugging somewhat more difficult. Doesn't work with all ld's. @@ -247,11 +276,14 @@ StripLibraries=NO # For a debugging RTS: # GhcRtsHcOpts = -optc-DDEBUG -# GhcRtsCcOpts = -optc-g +# GhcRtsCcOpts = -g # For an optimised RTS: GhcRtsHcOpts=-O2 -GhcRtsCcOpts=-O2 -optc-fomit-frame-pointer +GhcRtsCcOpts=-O2 -fomit-frame-pointer + +# Include the front panel code? Needs GTK+. +GhcRtsWithFrontPanel = NO ################################################################################ # @@ -268,10 +300,10 @@ GhcRtsCcOpts=-O2 -optc-fomit-frame-pointer HsLibsFor = ghc # hslibs for GHC also uses the following variables (defined above): -# GhcLibWays, GhcLibHcOpts, GhcLibToolsHcOpts, EnableWin32DLLs, StripLibraries +# GhcLibWays, GhcLibHcOpts, GhcLibToolsHcOpts, DLLized, StripLibraries -# Haskell compiler options for tools in hslibs -GhcLibToolsHcOpts=-O +# Haskell compiler options for tools in fptools +FptoolsHcOpts=-O # Build the Haskell Readline bindings? # @@ -285,6 +317,16 @@ LibsReadline=@LibsReadline@ # ReadlineIncludePath= +# Math library +LIBM=@LIBM@ + +# Build the Haskell OpenGL/GLUT binding? +# +GhcLibsWithHOpenGL=@GhcLibsWithHOpenGL@ + +X_CFLAGS=@X_CFLAGS@ +X_LIBS=@X_LIBS@ + ################################################################################ # # happy project @@ -361,20 +403,32 @@ NoFibHcOpts = -O ################################################################################ # Directory used by GHC (and possibly other tools) for storing -# temporary files. If your /tmp isn't big enough, either override +# temporary files. If your TMPDIR isn't big enough, either override # this in build.mk or set your environment variable "TMPDIR" to point # to somewhere with more space. (TMPDIR=. is a good choice). # DEFAULT_TMPDIR isn't called TMPDIR because GNU make tends to -# override the environment variable with the value of the make -# variable when executing sub-processes, so setting the TMPDIR env var -# would have no effect in the build tree. +# override an environment variable with the value of the make variable +# of the same name (if it exists) when executing sub-processes, so +# setting the TMPDIR env var would have no effect in the build tree. DEFAULT_TMPDIR = /tmp +ifeq "$(TARGETPLATFORM)" "i386-unknown-cygwin32" +DEFAULT_TMPDIR = C:/TEMP +endif +ifeq "$(TARGETPLATFORM)" "i386-unknown-mingw32" +DEFAULT_TMPDIR = C:/TEMP +endif # FPTOOLS_TOP: the top of the fptools hierarchy, absolute path. +ifeq "$(findstring $(TARGETPLATFORM), i386-unknown-cygwin32 i386-unknown-mingw32)" "" FPTOOLS_TOP_ABS = @hardtop@ +else +FPTOOLS_TOP_ABS = $(subst \,/,$(shell cygpath -w @hardtop@)) +endif +# Keep the Unix-style path to use with Unix tools (e.g. in ghc-inplace script) +FPTOOLS_TOP_ABS_UNIX = @hardtop@ # # Installation directories, we don't use half of these, @@ -385,6 +439,7 @@ prefix = @prefix@ exec_prefix = @exec_prefix@ bindir = @bindir@ datadir = @datadir@ + #sysconfdir = @datadir@ #sharedstatedir = @sharedstatedir@ #localstatedir = @localstatedir@ @@ -393,10 +448,16 @@ includedir = @includedir@ oldincludedir = @oldincludedir@ mandir = @mandir@ -#UNUSED, see below: libexecdir = @libexecdir@ #UNUSED:infodir = @infodir@ #UNUSED:srcdir = @srcdir@ +# +# override libdir and datadir to put project-specific stuff in +# a subdirectory with the version number included. +# +libdir := $(if $(ProjectNameShort),$(libdir)/$(ProjectNameShort)-$(ProjectVersion),$(libdir)) +datadir := $(if $(ProjectNameShort),$(datadir)/$(ProjectNameShort)-$(ProjectVersion),$(datadir)) + # # Default values for most of the above are only set if # they weren't configured to anything in particular @@ -433,7 +494,7 @@ endif ifeq "$(strip $(mandir))" "" mandir = $(prefix)/man endif - + ################################################################################ # @@ -451,6 +512,21 @@ endif # # SRC_HC_OPTS += -O +# These flags make flex 8-bit +SRC_FLEX_OPTS += -8 + +SRC_INSTALL_BIN_OPTS += -s + +# lint gets all CPP's flags too +SRC_LINT_OPTS += -axz -DLINT $(SRC_CPP_OPTS) +WAY$(_way)_LINT_OPTS += WAY$(_way)_CPP_OPTS + +# Default fptools options for dllwrap. +SRC_BLD_DLL_OPTS += -mno-cygwin --target=i386-mingw32 + +# Flags for CPP when running GreenCard on .pgc files +GC_CPP_OPTS += -P -E -x c -traditional -D__GLASGOW_HASKELL__ + ################################################################################ # @@ -497,10 +573,9 @@ HAPPY_PREFIX = $(FPTOOLS_TOP)/happy/src/ GREENCARD_PREFIX = $(FPTOOLS_TOP)/green-card/src/ UNLIT_PREFIX = $(FPTOOLS_TOP)/ghc/utils/unlit/ -STAT2RESID_PREFIX = $(FPTOOLS_TOP)/ghc/utils/stat2resid/ HP2PS_PREFIX = $(FPTOOLS_TOP)/ghc/utils/hp2ps/ HSTAGS_PREFIX = $(FPTOOLS_TOP)/ghc/utils/hstags/ - +HSC2HS_PREFIX = $(FPTOOLS_TOP)/ghc/utils/hsc2hs/ #----------------------------------------------------------------------------- # Haskell compilers and mkdependHS @@ -510,8 +585,11 @@ HSTAGS_PREFIX = $(FPTOOLS_TOP)/ghc/utils/hstags/ # # $(HC) is a generic Haskell 98 compiler, set to $(GHC) by default. # $(MKDEPENDHS) is the Haskell dependency generator (ghc -M). +# +# NOTE: Don't override $(GHC) in build.mk, use configure --with-ghc instead +# (because the version numbers have to be calculated). -GHC = @GHC@ +GHC = @WithGhc@ GhcVersion = @GhcVersion@ GhcMajVersion = @GhcMajVersion@ GhcMinVersion = @GhcMinVersion@ @@ -521,18 +599,21 @@ HBC = @HBC@ NHC = @NHC@ HC = @WithHc@ -MKDEPENDHS = $(HC) +MKDEPENDHS = $(GHC) # Sometimes we want to invoke ghc from the build tree in different # projects (eg. it's handy to have a nofib & a ghc build in the same # tree). We can refer to "this ghc" as $(GHC_INPLACE): -GHC_INPLACE = $(FPTOOLS_TOP)/ghc/driver/ghc-inplace +GHC_INPLACE = $(FPTOOLS_TOP)/ghc/compiler/ghc-inplace #----------------------------------------------------------------------------- # C compiler # -# +# NB. Don't override $(WhatGccIsCalled) using build.mk, re-configure using +# the flag --with-gcc= instead. The reason is that the configure script +# needs to know which gcc you're using in order to perform its tests. + HaveGcc = @HaveGcc@ UseGcc = YES WhatGccIsCalled = @WhatGccIsCalled@ @@ -544,6 +625,9 @@ else endif endif +# default C compiler flags +SRC_CC_OPTS = @SRC_CC_OPTS@ + #----------------------------------------------------------------------------- # GMP Library (version 2.0.x or above) # @@ -557,6 +641,12 @@ LibGmp = @LibGmp@ HaveRegex = @HaveRegex@ #----------------------------------------------------------------------------- +# GTK+ + +GTK_CONFIG = @GTK_CONFIG@ +GTK_VERSION = @GTK_VERSION@ + +#----------------------------------------------------------------------------- # Flex FLEX = @LEX@ @@ -580,7 +670,11 @@ CONTEXT_DIFF = @ContextDiffCmd@ CP = cp CPP = @CPP@ CTAGS = $(ETAGS) -RAWCPP = $(CPP) -undef -traditional +# +# RAWCPP_FLAGS are the flags to give to cpp (viz, gcc -E) to persuade it to +# behave plausibly on Haskell sources. +# +RAWCPP_FLAGS = -undef -traditional FIND = @FindCmd@ INSTALL = @INSTALL@ # @@ -590,6 +684,8 @@ INSTALL = @INSTALL@ # INSTALL := $(subst .././install-sh,$(FPTOOLS_TOP_ABS)/install-sh,$(INSTALL)) LATEX = latex +HEVEA = hevea +HACHA = hacha LN_S = @LN_S@ MANMACROS = -man MSMACROS = -ms @@ -668,6 +764,7 @@ SRC_SGML2DVI_OPTS = -d $(SGMLSTYLESHEET) SRC_SGML2HTML_OPTS = -d $(SGMLSTYLESHEET) SRC_SGML2PS_OPTS = -d $(SGMLSTYLESHEET) SRC_SGML2RTF_OPTS = -d $(SGMLSTYLESHEET) +SRC_SGML2PDF_OPTS = -d $(SGMLSTYLESHEET) DOCBOOK_CATALOG = @Catalog@ @@ -697,7 +794,7 @@ HAPPY_VERSION = @HappyVersion@ # # Options to pass to Happy when we're going to compile the output with GHC # -GHC_HAPPY_OPTS = $(shell if expr $(HAPPY_VERSION) \< "1.8" >/dev/null; then echo -g; else echo -agc; fi) +GHC_HAPPY_OPTS = $(shell if ( test `echo $(HAPPY_VERSION) | sed -e "s/\(.*\)\..*/\1/g"` "-gt" "1" || test `echo $(HAPPY_VERSION) | sed -e "s/.*\.\(.*\)/\1/g"` "-ge" "9" ); then echo -agc; else echo -g; fi) # # Stuff from fptools/literate @@ -713,10 +810,9 @@ LIT2TEXT = $(LITERATE_PREFIX)lit2text # Stuff from fptools/ghc/utils # UNLIT = $(UNLIT_PREFIX)unlit$(EXE_SUFFIX) -STAT2RESID = $(STAT2RESID_PREFIX)stat2resid HP2PS = $(HP2PS_PREFIX)hp2ps$(EXE_SUFFIX) -HSCPP = $(HSCPP_PREFIX)hscpp HSTAGS = $(HSTAGS_PREFIX)hstags +HSC2HS = $(HSC2HS_PREFIX)hsc2hs-inplace # # Options for the compiling different `ways'. Various projects within @@ -789,10 +885,6 @@ WAY_mp_HC_OPTS=-parallel WAY_mg_NAME=GranSim WAY_mg_HC_OPTS=-gransim -# Way `dll': -WAY_dll_NAME=Win32 DLLs -WAY_dll_HC_OPTS=-dll - # # Add user-way configurations here: #