X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=Makefile;h=c2b9108bf113b3d22f0a775acdf85a9ab7be6385;hb=4af6a1708d420733fc9110cbac58e8bfacdaf53d;hp=72b6e722aad5310f0f028b2fd6b2146691b72160;hpb=dac2284b562a8d7bc52ae9ca5c7f83a9de83c083;p=ghc-base.git diff --git a/Makefile b/Makefile index 72b6e72..c2b9108 100644 --- a/Makefile +++ b/Makefile @@ -1,5 +1,5 @@ # ----------------------------------------------------------------------------- -# $Id: Makefile,v 1.22 2002/03/25 15:49:26 sof Exp $ +# $Id: Makefile,v 1.30 2002/06/04 19:12:53 sof Exp $ TOP=.. include $(TOP)/mk/boilerplate.mk @@ -34,8 +34,11 @@ ALL_DIRS = \ Text \ Text/Html \ Text/PrettyPrint \ + Text/ParserCombinators \ + Text/ParserCombinators/Parsec \ Text/Regex \ - Text/Show + Text/Show \ + Text/Read PACKAGE = base @@ -63,6 +66,7 @@ GHC/PrimopWrappers.hs: $(GHC_COMPILER_DIR)/prelude/primops.txt boot :: GHC/PrimopWrappers.hs +EXTRA_SRCS += GHC/PrimopWrappers.hs CLEAN_FILES += GHC/PrimopWrappers.hs #----------------------------------------------------------------------------- @@ -70,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 @@ -81,18 +94,43 @@ GHCI_LIBOBJS = $(HS_OBJS) INSTALL_LIBS += HSbase1.o HSbase2.o -endif # TARGETPLATFORM = i386-unknown-mingw32 +endif # OBJECT_FILEFORMAT = PEi + + +# ----------------------------------------------------------------------------- +# Doc building with Haddock + +EXCLUDED_HADDOCK_SRCS = \ + Data/Generics.hs \ + GHC/PArr.hs +HS_PPS = $(addsuffix .raw-hs, $(basename $(filter-out $(EXCLUDED_HADDOCK_SRCS), $(HS_SRCS)))) + +HADDOCK = $(FPTOOLS_TOP)/haddock/src/haddock-inplace + +# Urgh, hack needed to ensure that the value of HS_SRCS is computed in time for +# the docs rule below. +PRE_SRCS := $(ALL_SRCS) + +.PHONY: docs +haddock-docs : $(HS_PPS) + $(HADDOCK) -t "Haskell Core Libraries" -h -s "." $(HS_PPS) + +%.raw-hs : %.lhs + $(GHC_INPLACE) $(HC_OPTS) -D__HADDOCK__ -E -cpp $< -o $<.tmp && sed -e 's/^#.*//' <$<.tmp >$@ + +%.raw-hs : %.hs + $(GHC_INPLACE) $(HC_OPTS) -D__HADDOCK__ -E -cpp $< -o $<.tmp && sed -e 's/^#.*//' <$<.tmp >$@ # ----------------------------------------------------------------------------- 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