X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=Makefile;h=8cc4bf39f540a3298b4cc0214d227c93e43aaa8b;hb=9a53a070bb647bd7796596e27a6348ae3ba6eed7;hp=00f0d21c26d60d36e8345984e7c6b1dc57cff34d;hpb=ac0b77fdbb49a053bed31c2753f5b24e7db4f78c;p=ghc-base.git diff --git a/Makefile b/Makefile index 00f0d21..8cc4bf3 100644 --- a/Makefile +++ b/Makefile @@ -1,16 +1,12 @@ # ----------------------------------------------------------------------------- -# $Id: Makefile,v 1.4 2001/07/31 16:41:32 simonmar Exp $ +# $Id: Makefile,v 1.36 2002/07/02 13:13:36 simonmar Exp $ TOP=.. include $(TOP)/mk/boilerplate.mk # ----------------------------------------------------------------------------- -ifeq "$(way)" "" -SUBDIRS = cbits -else -SUBDIRS= -endif +SUBDIRS = cbits include ALL_DIRS = \ Control \ @@ -19,8 +15,10 @@ ALL_DIRS = \ Control/Monad/ST \ Data \ Data/Array \ + Data/STRef \ Database \ Debug \ + Debug/QuickCheck \ FileFormat \ Foreign \ Foreign/C \ @@ -31,21 +29,94 @@ 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 < $< > $@ + +boot :: GHC/PrimopWrappers.hs -PKG=core +EXTRA_SRCS += GHC/PrimopWrappers.hs +CLEAN_FILES += GHC/PrimopWrappers.hs -# dependencies between .hsc files -GHC/IO.hs : GHC/Handle.hs +#----------------------------------------------------------------------------- +# 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 [due to a bug in the GNU +# linker.] -GHC/Prim.$(way_)hi : GHC/Prim.hi-boot - cp $< $@ +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 HSbase3.o -lib : GHC/Prim.$(way_)hi +endif # OBJECT_FILEFORMAT = PEi + + +# ----------------------------------------------------------------------------- +# Doc building with Haddock + +EXCLUDED_HADDOCK_SRCS = \ + Data/Generics.hs \ + GHC/PArr.hs + +SRC_HADDOCK_OPTS += -t "Haskell Core Libraries (base package)" \ + --no-implicit-prelude -p prologue.txt # ----------------------------------------------------------------------------- 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)) + @touch HSbase.o +endif # OBJECT_FILEFORMAT = PEi +