From: sof Date: Tue, 4 Jun 2002 19:12:53 +0000 (+0000) Subject: [project @ 2002-06-04 19:12:53 by sof] X-Git-Tag: nhc98-1-18-release~988 X-Git-Url: http://git.megacz.com/?a=commitdiff_plain;h=5ac77b655828b1c52af10345a0ebb0cf0c3d4507;p=haskell-directory.git [project @ 2002-06-04 19:12:53 by sof] PEi(x86) backends: The addition of Parsec to libraries/ put us over the limit for splitting HSbase into two parts (at least I couldn't find a good paritioning), we now need three. Fun and games. --- diff --git a/Makefile b/Makefile index 5157ef1..c2b9108 100644 --- a/Makefile +++ b/Makefile @@ -1,5 +1,5 @@ # ----------------------------------------------------------------------------- -# $Id: Makefile,v 1.29 2002/05/31 12:22:33 panne Exp $ +# $Id: Makefile,v 1.30 2002/06/04 19:12:53 sof Exp $ TOP=.. include $(TOP)/mk/boilerplate.mk @@ -74,9 +74,18 @@ CLEAN_FILES += GHC/PrimopWrappers.hs # # The procedure differs from that in fptools/mk/target.mk in one way: # (*) on Win32 we must split it into two, because a single .o file can't -# have more than 65536 relocations in it. +# have more than 65536 relocations in it [due to a bug in the GNU +# linker.] +OBJECT_FILEFORMAT=unknown ifeq "$(TARGETPLATFORM)" "i386-unknown-mingw32" +OBJECT_FILEFORMAT=PEi +endif +ifeq "$(TARGETPLATFORM)" "i386-unknown-cygwin32" +OBJECT_FILEFORMAT=PEi +endif + +ifeq "$(OBJECT_FILEFORMAT)" "PEi" # Turn off standard rule which creates HSbase.o from LIBOBJS. DONT_WANT_STD_GHCI_LIB_RULE=YES @@ -85,7 +94,7 @@ GHCI_LIBOBJS = $(HS_OBJS) INSTALL_LIBS += HSbase1.o HSbase2.o -endif # TARGETPLATFORM = i386-unknown-mingw32 +endif # OBJECT_FILEFORMAT = PEi # ----------------------------------------------------------------------------- @@ -117,10 +126,11 @@ haddock-docs : $(HS_PPS) include $(TOP)/mk/target.mk -ifeq "$(TARGETPLATFORM)" "i386-unknown-mingw32" +ifeq "$(OBJECT_FILEFORMAT)" "PEi" HSbase.o : $(GHCI_LIBOBJS) $(LD) -r $(LD_X) -o HSbase1.o $(filter GHC/%, $(GHCI_LIBOBJS)) - $(LD) -r $(LD_X) -o HSbase2.o $(filter-out GHC/%, $(GHCI_LIBOBJS)) + $(LD) -r $(LD_X) -o HSbase2.o $(filter Text/%, $(GHCI_LIBOBJS)) + $(LD) -r $(LD_X) -o HSbase3.o $(filter-out GHC/% Text/%, $(GHCI_LIBOBJS)) @touch HSbase.o -endif # TARGETPLATFORM = i386-unknown-mingw32 +endif # OBJECT_FILEFORMAT = PEi