X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=compat%2FMakefile;h=fb28e2c4952d3db1a5c321079c370042555a69c2;hb=eae65ca88fc09342e295874fb253f83775c61051;hp=b4e18c9bbc00a45c6cc71a5cdbb221fb3f18e7b7;hpb=0065d5ab628975892cea1ec7303f968c3338cbe1;p=ghc-hetmet.git diff --git a/compat/Makefile b/compat/Makefile index b4e18c9..fb28e2c 100644 --- a/compat/Makefile +++ b/compat/Makefile @@ -4,11 +4,7 @@ include $(TOP)/mk/boilerplate.mk ALL_DIRS = \ Data \ Compat \ - Distribution \ - Distribution/Compat \ - Language/Haskell \ - System \ - System/Directory \ + Trace/Hpc \ cbits SplitObjs=NO @@ -20,6 +16,12 @@ NO_INSTALL_LIBRARY = YES # Avoid building the GHCi lib, since we don't need it GhcWithInterpreter = NO +# There are lots of warnings in here due to things like modules being +# imported that, in some versions of GHC, aren't used. Thus we don't +# give any warnings in here, and therefore validating with -Werror won't +# make the build fail. +SRC_HC_OPTS += -w + # Needed so that the libraries can #include relative to this directory. INCLUDE_DIRS=-I. -Iinclude @@ -41,38 +43,28 @@ UseGhcForCc = YES # In this particular case, it turned out that -DDEBUG made Cabal # import HUnit, which might not be installed for the compiler we are # compiling with (e.g. 6.2.1). Hence the filter-out. -SRC_HC_OPTS += $(filter-out -D%, $(GhcHcOpts)) +SRC_HC_OPTS += $(filter-out -D%, $(GhcHcOpts) $(GhcStage1HcOpts)) # GHC 6.4 didn't have WCsubst.c, but 6.4.1 did, and we need to know # this in cbits/unicode.c The patchlevel isn't normally exposed as a # CPP symbol, so we have to do it by hand: SRC_CC_OPTS += -D__GHC_PATCHLEVEL__=$(GhcPatchLevel) -ifeq "$(ghc_ge_603)" "YES" -# These modules are provided in GHC 6.3+ -EXCLUDED_SRCS += \ - System/Directory/Internals.hs - -SRC_MKDEPENDHS_OPTS += \ - -optdep--exclude-module=System.Directory.Internals +# This module shouldn't be compiled itself, only #included into other files +EXCLUDED_SRCS += System/FilePath/Internal.hs -# GHC 6.3+ has Cabal, but we're replacing it: -SRC_HC_OPTS += -ignore-package Cabal +ifeq "$(ghc_ge_607)" "YES" +SRC_HC_OPTS += -package directory +SRC_HC_OPTS += -package pretty endif # Some explicit dependencies, needed because ghc -M can't discover the # true dependencies of these stub files. -System/Directory/Internals.$(way_)o : $(FPTOOLS_TOP)/libraries/base/System/Directory/Internals.hs -Distribution/Compat/FilePath.$(way_) : $(FPTOOLS_TOP)/libraries/Cabal/Distribution/Compat/FilePath.hs -Distribution/Compat/ReadP.$(way_) : $(FPTOOLS_TOP)/libraries/Cabal/Distribution/Compat/ReadP.hs -Distribution/GetOpt.$(way_)o : $(FPTOOLS_TOP)/libraries/Cabal/Distribution/GetOpt.hs -Distribution/InstalledPackageInfo.$(way_)o : $(FPTOOLS_TOP)/libraries/Cabal/Distribution/InstalledPackageInfo.hs -Distribution/License.$(way_)o : $(FPTOOLS_TOP)/libraries/Cabal/Distribution/License.hs -Distribution/Package.$(way_)o : $(FPTOOLS_TOP)/libraries/Cabal/Distribution/Package.hs -Distribution/ParseUtils.$(way_)o : $(FPTOOLS_TOP)/libraries/Cabal/Distribution/ParseUtils.hs -Distribution/Compiler.$(way_)o : $(FPTOOLS_TOP)/libraries/Cabal/Distribution/Compiler.hs -Distribution/Version.$(way_)o : $(FPTOOLS_TOP)/libraries/Cabal/Distribution/Version.hs -Language/Haskell/Extension.$(way_)o : $(FPTOOLS_TOP)/libraries/Cabal/Language/Haskell/Extension.hs +System/Directory/Internals.$(way_)o : $(FPTOOLS_TOP)/libraries/directory/System/Directory/Internals.hs +Trace/Hpc/Mix.$(way_)o : $(FPTOOLS_TOP)/libraries/hpc/Trace/Hpc/Mix.hs +Trace/Hpc/Util.$(way_)o : $(FPTOOLS_TOP)/libraries/hpc/Trace/Hpc/Util.hs +Trace/Hpc/Tix.$(way_)o : $(FPTOOLS_TOP)/libraries/hpc/Trace/Hpc/Tix.hs + cbits/unicode.o : $(FPTOOLS_TOP)/libraries/base/cbits/WCsubst.c $(FPTOOLS_TOP)/libraries/base/include/WCsubst.h SRC_CC_OPTS += -I$(FPTOOLS_TOP)/libraries/base/cbits -I$(FPTOOLS_TOP)/libraries/base/include @@ -80,7 +72,13 @@ SRC_CC_OPTS += -I$(FPTOOLS_TOP)/libraries/base/cbits -I$(FPTOOLS_TOP)/libraries/ # Make the #includes in the stubs independent of the current location SRC_HC_OPTS += -I$(FPTOOLS_TOP)/libraries -SRC_HC_OPTS += -fglasgow-exts -no-recomp +SRC_HC_OPTS += -fglasgow-exts + +ifeq "$(ghc_ge_609)" "YES" +SRC_HC_OPTS += -fforce-recomp +else +SRC_HC_OPTS += -no-recomp +endif ifeq "$(HOSTPLATFORM)" "i386-unknown-mingw32" Compat/Directory_HC_OPTS += -\#include shlobj.h