X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=compiler%2FMakefile;h=4c0386e0dc9a0f0b29af3ddb45ba8d12f27ab673;hb=64d22486ac2005a74769873da2ff39fc89ebd084;hp=60c70fd9a93d0a67ecf2131e121f641039b48cbd;hpb=b4af1a0ff3d43e70e54629e89ffff62d49de1746;p=ghc-hetmet.git diff --git a/compiler/Makefile b/compiler/Makefile index 60c70fd..4c0386e 100644 --- a/compiler/Makefile +++ b/compiler/Makefile @@ -346,6 +346,10 @@ endif @echo "#define HOST_VENDOR \"$(TargetVendor_CPP)\"" >> $@ @echo "#define TARGET_VENDOR \"$(TargetVendor_CPP)\"" >> $@ @echo >> $@ +ifeq "$(GhcWithTablesNextToCode)" "YES" + @echo "#define TABLES_NEXT_TO_CODE 1" >> $@ +endif + @echo >> $@ @echo "#endif /* __PLATFORM_H__ */" >> $@ @echo "Done." @@ -720,7 +724,7 @@ all :: $(odir)/ghc-inplace ghc-inplace ifeq "$(TARGETPLATFORM)" "i386-unknown-mingw32" # MSys (...and cygwin with a mingw toolchain) -SCRIPT_SHELL = $(shell cd /bin; pwd -W 2>/dev/null | echo "/bin")/sh +SCRIPT_SHELL = $(shell cd /bin; pwd -W 2>/dev/null || echo "/bin")/sh else # Cygwin and Unix SCRIPT_SHELL = /bin/sh @@ -830,6 +834,7 @@ HIERARCHICAL_LIB = NO VERSION = $(ProjectVersion) PKG_DEPENDS += base haskell98 PACKAGE_CPP_OPTS += -DPKG_DEPENDS='$(PKG_DEPENDS)' +PACKAGE_CPP_OPTS += -DSTAGE='"$(stage)"' # Omit Main from the library, the client will want to plug their own Main in LIBOBJS = $(filter-out $(odir)/main/Main.o $(odir)/parser/hschooks.o, $(OBJS)) @@ -861,7 +866,16 @@ NO_HADDOCK_DOCS = YES all :: $(GHC_PROG) +# The stage 2 and stage 3 package.conf.in files are different, because they +# point to either the stage2/ or stage3/ dirs in import-dirs. Hence before +# linking the ghc binary we must install the correct version of the package +# configuration. Yeuch... maybe one day this will all be done more cleanly. +STAMP_PKG_CONF = $(GHC_DRIVER_DIR)/stamp-pkg-conf-$(PACKAGE) + $(GHC_PROG) : libHS$(PACKAGE)$(_way).a main/Main.hs + $(RM) package.conf.inplace + $(RM) $(STAMP_PKG_CONF) + $(MAKE) $(STAMP_PKG_CONF) $(MAKE) -f Makefile.ghcbin $(MFLAGS) HS_PROG=$(GHC_PROG) $@ # Propagate standard targets to Makefile.ghcbin