X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=ghc%2Flib%2Fcompat%2FMakefile;h=7637c941157afa77d175cf2c3653f85c50e98f76;hb=28a464a75e14cece5db40f2765a29348273ff2d2;hp=664ad3c117a7e2ca81541365d9686a936146adc1;hpb=fdfdac786a147e5a653109ae9ad5e34d3406d105;p=ghc-hetmet.git diff --git a/ghc/lib/compat/Makefile b/ghc/lib/compat/Makefile index 664ad3c..7637c94 100644 --- a/ghc/lib/compat/Makefile +++ b/ghc/lib/compat/Makefile @@ -6,17 +6,29 @@ ALL_DIRS = \ Compat \ Distribution \ Distribution/Compat \ + Language/Haskell \ System \ System/Directory \ cbits +SplitObjs=NO LIBRARY = libghccompat.a -# Just to silence warnings -MKDEPENDC_OPTS += -I$(GHC_INCLUDE_DIR) +# We don't want this installed +NO_INSTALL_LIBRARY = YES + +# Avoid building the GHCi lib, since we don't need it +GhcWithInterpreter = NO # Needed so that the libraries can #include relative to this directory. -SRC_HC_OPTS += -I. +INCLUDE_DIRS=-I. -Iinclude + +SRC_HC_OPTS += $(INCLUDE_DIRS) +SRC_CC_OPTS += $(INCLUDE_DIRS) +MKDEPENDC_OPTS += $(INCLUDE_DIRS) + +# Just to silence warnings +MKDEPENDC_OPTS += -I$(GHC_INCLUDE_DIR) UseGhcForCc = YES @@ -31,32 +43,39 @@ UseGhcForCc = YES # compiling with (e.g. 6.2.1). Hence the filter-out. SRC_HC_OPTS += $(filter-out -D%, $(GhcHcOpts)) +# 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 all provided in GHC 6.3+ +# These modules are provided in GHC 6.3+ EXCLUDED_SRCS += \ - System/Directory/Internals.hs \ - Distribution/Compat/ReadP.hs \ - Distribution/Extension.hs \ - Distribution/GetOpt.hs \ - Distribution/InstalledPackageInfo.hs \ - Distribution/License.hs \ - Distribution/Package.hs \ - Distribution/ParseUtils.hs \ - Distribution/Setup.hs \ - Distribution/Version.hs + System/Directory/Internals.hs + +SRC_MKDEPENDHS_OPTS += \ + -optdep--exclude-module=System.Directory.Internals + +# GHC 6.3+ has Cabal, but we're replacing it: +SRC_HC_OPTS += -ignore-package Cabal endif -# Some explicit dependencies +# 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/Extension.$(way_)o : $(FPTOOLS_TOP)/libraries/Cabal/Distribution/Extension.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/Setup.$(way_)o : $(FPTOOLS_TOP)/libraries/Cabal/Distribution/Setup.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 +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 # Make the #includes in the stubs independent of the current location SRC_HC_OPTS += -I$(FPTOOLS_TOP)/libraries