[project @ 2002-05-31 12:22:33 by panne]
[ghc-base.git] / Makefile
index 5e0d134..5157ef1 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -1,14 +1,12 @@
 # -----------------------------------------------------------------------------
-# $Id: Makefile,v 1.2 2001/07/03 11:37:49 simonmar Exp $
+# $Id: Makefile,v 1.29 2002/05/31 12:22:33 panne Exp $
 
-TOP=../..
+TOP=..
 include $(TOP)/mk/boilerplate.mk
 
-ifeq "$(way)" ""
-SUBDIRS = cbits
-else
-SUBDIRS=
-endif
+# -----------------------------------------------------------------------------
+
+SUBDIRS = cbits include
 
 ALL_DIRS = \
        Control \
@@ -19,6 +17,7 @@ ALL_DIRS = \
        Data/Array \
        Database \
        Debug \
+       Debug/QuickCheck \
        FileFormat \
        Foreign \
        Foreign/C \
@@ -29,46 +28,99 @@ ALL_DIRS = \
        Network \
        NHC \
        System \
+       System/Console \
+       System/Mem \
        System/IO \
        Text \
-       Text/Show
+       Text/Html \
+       Text/PrettyPrint \
+       Text/ParserCombinators \
+       Text/ParserCombinators/Parsec \
+       Text/Regex \
+       Text/Show \
+       Text/Read
+
+PACKAGE = base
+
+SRC_HC_OPTS += -fglasgow-exts -cpp -Iinclude
+SRC_HSC2HS_OPTS += -Iinclude
+
+# Make sure we can get hold of regex.h
+ifneq "$(HavePosixRegex)" "YES"
+SRC_HC_OPTS     += -Icbits/regex
+SRC_HSC2HS_OPTS += -Icbits/regex
+endif
+
+# -----------------------------------------------------------------------------
+# Per-module flags
+
+# ESSENTIAL, for getting reasonable performance from the I/O library:
+SRC_HC_OPTS += -funbox-strict-fields
+
+# -----------------------------------------------------------------------------
+# PrimOpWrappers
+
+GHC/PrimopWrappers.hs: $(GHC_COMPILER_DIR)/prelude/primops.txt
+       rm -f $@
+       $(GHC_GENPRIMOP) --make-haskell-wrappers < $< > $@
 
-PRE_SRCS += $(wildcard $(patsubst %, %/*.hsc, $(ALL_DIRS)))
-SRC_HSC2HS_OPTS += -Iinclude -I.
+boot :: GHC/PrimopWrappers.hs
 
-ALL_HS_SRCS = $(wildcard $(patsubst %, %/*.hs, . $(ALL_DIRS)))
-ALL_LHS_SRCS += $(wildcard GHC/*.lhs)
-ALL_HS_OBJS = $(patsubst %.hs, %.o, $(ALL_HS_SRCS)) \
-       $(patsubst %.lhs, %.o, $(ALL_LHS_SRCS))
-ALL_HS_HIS = $(patsubst %.o, %.hi, $(ALL_HS_OBJS))
+EXTRA_SRCS  += GHC/PrimopWrappers.hs
+CLEAN_FILES += GHC/PrimopWrappers.hs
 
-srcs : $(HS_SRCS) GHC/Prim.$(way_)hi
+#-----------------------------------------------------------------------------
+#      Building the library for GHCi
+#
+# 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.
 
-# dependencies between .hsc files
-GHC/IO.hs : GHC/Handle.hs
+ifeq "$(TARGETPLATFORM)" "i386-unknown-mingw32"
 
-GHC/Prim.$(way_)hi : GHC/Prim.hi-boot
-       cp $< $@
+# Turn off standard rule which creates HSbase.o from LIBOBJS.
+DONT_WANT_STD_GHCI_LIB_RULE=YES
 
-SRC_HC_OPTS += -cpp -fglasgow-exts -fvia-C -I$(FPTOOLS_TOP)/ghc/includes -Iinclude -package-name core -H128m $(GhcLibHcOpts)
+GHCI_LIBOBJS = $(HS_OBJS)
 
-LIBNAME = libHScore$(_way).a
+INSTALL_LIBS += HSbase1.o HSbase2.o
 
-CLEAN_FILES += $(ALL_HS_OBJS) $(ALL_HS_HIS)
+endif # TARGETPLATFORM = i386-unknown-mingw32
 
-all :: $(LIBNAME)
 
-$(ALL_HS_OBJS) : srcs
-       $(GHC_INPLACE) $(HC_OPTS) --make $(ALL_HS_SRCS) $(ALL_LHS_SRCS)
+# -----------------------------------------------------------------------------
+# 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)
 
-$(LIBNAME) : $(ALL_HS_OBJS)
-       $(RM) $@
-       $(AR) $(AR_OPTS) $@ $(ALL_HS_OBJS)
-       $(RANLIB) $@
+.PHONY: docs
+haddock-docs : $(HS_PPS)
+       $(HADDOCK) -t "Haskell Core Libraries" -h -s "." $(HS_PPS)
 
-%.o : %.hs
-       $(GHC_INPLACE) $(HC_OPTS) --make $<
-%.o : %.lhs
-       $(GHC_INPLACE) $(HC_OPTS) --make $<
+%.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"
+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))
+       @touch HSbase.o
+endif # TARGETPLATFORM = i386-unknown-mingw32
+