# -----------------------------------------------------------------------------
-# $Id: Makefile,v 1.22 2002/03/25 15:49:26 sof Exp $
+# $Id: Makefile,v 1.31 2002/06/08 13:11:27 panne Exp $
TOP=..
include $(TOP)/mk/boilerplate.mk
Text \
Text/Html \
Text/PrettyPrint \
+ Text/ParserCombinators \
+ Text/ParserCombinators/Parsec \
Text/Regex \
- Text/Show
+ Text/Show \
+ Text/Read
PACKAGE = base
boot :: GHC/PrimopWrappers.hs
+EXTRA_SRCS += GHC/PrimopWrappers.hs
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
GHCI_LIBOBJS = $(HS_OBJS)
-INSTALL_LIBS += HSbase1.o HSbase2.o
+INSTALL_LIBS += HSbase1.o HSbase2.o HSbase3.o
+
+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)
-endif # TARGETPLATFORM = i386-unknown-mingw32
+.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