[project @ 2005-04-07 23:36:48 by sof]
[ghc-base.git] / Makefile
index ebc5f2e..5179b7c 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -1,6 +1,3 @@
-# -----------------------------------------------------------------------------
-# $Id: Makefile,v 1.47 2003/07/31 17:45:22 ross Exp $
-
 TOP=..
 include $(TOP)/mk/boilerplate.mk
 
@@ -11,6 +8,7 @@ SUBDIRS = cbits include
 ALL_DIRS = \
        Control \
        Control/Concurrent \
+       Control/Parallel \
        Control/Monad \
        Control/Monad/ST \
        Data \
@@ -19,7 +17,6 @@ ALL_DIRS = \
        Data/Array/IO \
        Data/STRef \
        Debug \
-       Debug/QuickCheck \
        Foreign \
        Foreign/C \
        Foreign/Marshal \
@@ -29,6 +26,8 @@ ALL_DIRS = \
        System/Mem \
        System/IO \
        System/Posix \
+       System/Process \
+       System/Directory \
        Text \
        Text/Html \
        Text/PrettyPrint \
@@ -38,16 +37,11 @@ ALL_DIRS = \
        Text/Read
 
 PACKAGE = base
+VERSION = 1.0
 
-SRC_HC_OPTS += -fglasgow-exts -cpp -Iinclude -\#include HsBase.h
+SRC_HC_OPTS += -fglasgow-exts -cpp -Iinclude -"\#include" HsBase.h
 SRC_HSC2HS_OPTS += -Iinclude -I$(FPTOOLS_TOP)/ghc/includes
 
-# 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
 
@@ -75,6 +69,15 @@ boot :: GHC/PrimopWrappers.hs
 EXTRA_SRCS  += GHC/PrimopWrappers.hs
 CLEAN_FILES += GHC/PrimopWrappers.hs
 
+# -----------------------------------------------------------------------------
+ifneq "$(BootingFromHc)" "YES"
+STUBOBJS += \
+   Control/Concurrent_stub.$(way_)o
+   
+CLEAN_FILES += $(STUBOBJS) \
+   Control/Concurrent_stub.[ch]
+endif
+
 #-----------------------------------------------------------------------------
 #      Building the library for GHCi
 #
@@ -110,18 +113,31 @@ EXCLUDED_HADDOCK_SRCS = \
        GHC/PrimopWrappers.hs \
        GHC/PArr.hs
 
-SRC_HADDOCK_OPTS += -t "Haskell Core Libraries (base package)" \
-       --no-implicit-prelude -p prologue.txt
+SRC_HADDOCK_OPTS += -t "Haskell Hierarchical Libraries ($(PACKAGE) package)" \
+       --no-implicit-prelude
+
+# -----------------------------------------------------------------------------
+
+GHC/ForeignPtr.o Data/Array/IO/Internals.o Data/Array/Base.o \
+  Data/Generics/Instances.o Data/Complex.o Data/Array.o Data/STRef.o \
+  Data/Dynamic.o Data/Typeable.o Data/PackedString.o System/Mem/Weak.o \
+  System/Mem/StableName.o System/Posix/Types.o Control/Monad/ST.o \
+  Control/Exception.o Foreign/C/Types.o Foreign/ForeignPtr.o: include/Typeable.h
+
+System/Posix/Types.o Foreign/C/Types.o: include/CTypes.h
 
 # -----------------------------------------------------------------------------
 
+DIST_CLEAN_FILES += base.buildinfo config.cache config.status 
+LATE_DIST_CLEAN_FILES += config.mk
+
 include $(TOP)/mk/target.mk
 
 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     Text/%, $(GHCI_LIBOBJS))
-       $(LD) -r $(LD_X) -o HSbase3.o $(filter-out GHC/% Text/%, $(GHCI_LIBOBJS))
+       $(LD) -r $(LD_X) -o HSbase3.o $(filter-out GHC/% Text/%, $(GHCI_LIBOBJS) $(STUBOBJS))
        @touch HSbase.o
 endif # OBJECT_FILEFORMAT = PEi