X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=Makefile;h=5179b7c772bedb678dc3f4b928e821d9d0fb08c5;hb=f04f95f83ac336d999aa55b9fa08f7b4589dd20b;hp=917f0a201b0922b826a7e7c6a0ec29ebe6e6e246;hpb=1437af4263b9b9bdb4e3b9521e12210ffff191f8;p=ghc-base.git diff --git a/Makefile b/Makefile index 917f0a2..5179b7c 100644 --- a/Makefile +++ b/Makefile @@ -1,6 +1,3 @@ -# ----------------------------------------------------------------------------- -# $Id: Makefile,v 1.28 2002/05/27 14:30:49 simonmar Exp $ - TOP=.. include $(TOP)/mk/boilerplate.mk @@ -11,26 +8,26 @@ 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 \ + System/Process \ + System/Directory \ Text \ Text/Html \ Text/PrettyPrint \ @@ -40,15 +37,10 @@ ALL_DIRS = \ Text/Read PACKAGE = base +VERSION = 1.0 -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 +SRC_HC_OPTS += -fglasgow-exts -cpp -Iinclude -"\#include" HsBase.h +SRC_HSC2HS_OPTS += -Iinclude -I$(FPTOOLS_TOP)/ghc/includes # ----------------------------------------------------------------------------- # Per-module flags @@ -59,67 +51,93 @@ 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 +# ----------------------------------------------------------------------------- +ifneq "$(BootingFromHc)" "YES" +STUBOBJS += \ + Control/Concurrent_stub.$(way_)o + +CLEAN_FILES += $(STUBOBJS) \ + Control/Concurrent_stub.[ch] +endif + #----------------------------------------------------------------------------- # 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_STD_GHCI_LIB_RULE=YES GHCI_LIBOBJS = $(HS_OBJS) -INSTALL_LIBS += HSbase1.o HSbase2.o +INSTALL_LIBS += HSbase1.o HSbase2.o HSbase3.o -endif # TARGETPLATFORM = i386-unknown-mingw32 +endif # OBJECT_FILEFORMAT = PEi # ----------------------------------------------------------------------------- # Doc building with Haddock EXCLUDED_HADDOCK_SRCS = \ - Data/Generics.hs \ + GHC/PrimopWrappers.hs \ GHC/PArr.hs -HS_PPS = $(addsuffix .raw-hs, $(basename $(filter-out $(EXCLUDED_HADDOCK_SRCS), $(HS_SRCS)))) - -HADDOCK = $(FPTOOLS_TOP)/haddock/src/haddock-inplace +SRC_HADDOCK_OPTS += -t "Haskell Hierarchical Libraries ($(PACKAGE) package)" \ + --no-implicit-prelude -# Urgh, hack needed to ensure that the value of HS_SRCS is computed in time for -# the docs rule below. -PRE_SRCS := $(ALL_SRCS) - -.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 >$@ +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 -%.raw-hs : %.hs - $(GHC_INPLACE) $(HC_OPTS) -D__HADDOCK__ -E -cpp $< -o $<.tmp && sed -e 's/^#.*//' <$<.tmp >$@ +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 "$(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) $(STUBOBJS)) @touch HSbase.o -endif # TARGETPLATFORM = i386-unknown-mingw32 +endif # OBJECT_FILEFORMAT = PEi