X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=Makefile;h=640c9e781a64dc89859d176b6320fe7ea7de3368;hb=4f453c800990ecb470be1421318908b027dd700d;hp=054ca7e77bf315c15d7b9e544a3253fc5116d6e3;hpb=a8bdaac970946d71a66c4f45588915465822a0cc;p=ghc-base.git diff --git a/Makefile b/Makefile index 054ca7e..640c9e7 100644 --- a/Makefile +++ b/Makefile @@ -1,6 +1,3 @@ -# ----------------------------------------------------------------------------- -# $Id: Makefile,v 1.19 2002/03/04 17:02:43 simonmar Exp $ - TOP=.. include $(TOP)/mk/boilerplate.mk @@ -11,39 +8,40 @@ SUBDIRS = cbits include ALL_DIRS = \ Control \ Control/Concurrent \ + Control/Parallel \ Control/Monad \ Control/Monad/ST \ Data \ + Data/Generics \ Data/Array \ - Database \ + Data/Array/IO \ + Data/STRef \ Debug \ - Debug/QuickCheck \ - FileFormat \ Foreign \ Foreign/C \ Foreign/Marshal \ GHC \ - Hugs \ - Language \ - Network \ - NHC \ System \ System/Console \ System/Mem \ System/IO \ + System/Posix \ Text \ Text/Html \ Text/PrettyPrint \ + Text/ParserCombinators \ Text/Regex \ - Text/Show + Text/Show \ + Text/Read PACKAGE = base -SRC_HC_OPTS += -fglasgow-exts -cpp -Iinclude -SRC_HSC2HS_OPTS += -Iinclude +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 +# If there is no system-supplied POSIX regex library, use our own ifneq "$(HavePosixRegex)" "YES" +# Make sure we can get hold of regex.h SRC_HC_OPTS += -Icbits/regex SRC_HSC2HS_OPTS += -Icbits/regex endif @@ -57,56 +55,79 @@ SRC_HC_OPTS += -funbox-strict-fields # ----------------------------------------------------------------------------- # PrimOpWrappers +# These two lines are required for pre-processing ghc/compiler/prelude/primops.txt +SRC_CPP_OPTS += -I$(GHC_INCLUDE_DIR) +SRC_CPP_OPTS += ${GhcCppOpts} + +ifeq "$(BootingFromHc)" "YES" +GHC/PrimopWrappers.hs: + touch GHC/PrimopWrappers.hs +else GHC/PrimopWrappers.hs: $(GHC_COMPILER_DIR)/prelude/primops.txt - rm -f $@ + @$(RM) $@ $(GHC_GENPRIMOP) --make-haskell-wrappers < $< > $@ +endif boot :: GHC/PrimopWrappers.hs +EXTRA_SRCS += GHC/PrimopWrappers.hs CLEAN_FILES += GHC/PrimopWrappers.hs # ----------------------------------------------------------------------------- -# GHC/Prim.hi-boot -GHC/Prim.$(way_)hi : GHC/Prim.hi-boot - -$(GHC_INPLACE) --compile-iface $< - -ALL_PRIMS = GHC/Prim.hi $(foreach way, $(WAYS), GHC/Prim.$(way)_hi) -INSTALL_DATAS_WITH_DIRS += GHC/Prim.$(way_)hi - -lib : $(ALL_PRIMS) - -boot :: $(ALL_PRIMS) - -CLEAN_FILES += $(ALL_PRIMS) - -SRC_CPP_OPTS += -I$(GHC_INCLUDE_DIR) -traditional +STUBOBJS += \ + Control/Concurrent_stub.$(way_)o + +CLEAN_FILES += $(STUBOBJS) \ + Control/Concurrent_stub.[ch] #----------------------------------------------------------------------------- # 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. +# 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_BASE_GHCI_LIB_RULE=YES +DONT_WANT_STD_GHCI_LIB_RULE=YES GHCI_LIBOBJS = $(HS_OBJS) -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 +INSTALL_LIBS += HSbase1.o HSbase2.o HSbase3.o + +endif # OBJECT_FILEFORMAT = PEi -INSTALL_LIBS += HSbase1.o HSbase2.o -endif # TARGETPLATFORM = i386-unknown-mingw32 +# ----------------------------------------------------------------------------- +# Doc building with Haddock + +EXCLUDED_HADDOCK_SRCS = \ + GHC/PrimopWrappers.hs \ + GHC/PArr.hs +SRC_HADDOCK_OPTS += -t "Haskell Hierarchical Libraries ($(PACKAGE) package)" \ + --no-implicit-prelude # ----------------------------------------------------------------------------- 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) $(STUBOBJS)) + @touch HSbase.o +endif # OBJECT_FILEFORMAT = PEi +