X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=Makefile;h=47276f3f99b552fd46ffbc87c6fd52da8d478630;hb=412d4667d79c9c7b42b611b80b5a6c748727c3f1;hp=26e1dd2b051e4a0db9de6447834e3c6bb51a8a0c;hpb=3d39b8130899c46c9c96b941fddb4e4784e860dc;p=ghc-base.git diff --git a/Makefile b/Makefile index 26e1dd2..47276f3 100644 --- a/Makefile +++ b/Makefile @@ -1,5 +1,5 @@ # ----------------------------------------------------------------------------- -# $Id: Makefile,v 1.5 2001/08/17 12:50:34 simonmar Exp $ +# $Id: Makefile,v 1.16 2002/02/13 11:51:40 simonmar Exp $ TOP=.. include $(TOP)/mk/boilerplate.mk @@ -28,21 +28,82 @@ ALL_DIRS = \ Network \ NHC \ System \ + System/Console \ + System/Mem \ System/IO \ Text \ + Text/Html \ Text/PrettyPrint \ Text/Regex \ Text/Show -PKG=core +PACKAGE = base -# dependencies between .hsc files -GHC/IO.hs : GHC/Handle.hs +ifneq "$(HavePosixRegex)" "YES" +EXCLUDED_SRCS += Text/Regex/Posix.hsc Text/Regex.hs +endif -GHC/Prim.$(way_)hi : GHC/Prim.hi-boot +SRC_HC_OPTS += -fglasgow-exts -cpp -Iinclude +SRC_HSC2HS_OPTS += -Iinclude + +# ----------------------------------------------------------------------------- +# Per-module flags + +# ESSENTIAL, for getting reasonable performance from the I/O library: +GHC/IOBase_HC_OPTS = -funbox-strict-fields + +Data/Array/Storable_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 + +CLEAN_FILES += GHC/PrimopWrappers.hs + +# ----------------------------------------------------------------------------- +# GHC/Prim.hi-boot + +GHC/Prim.$(way_)hi : GHC/Prim.hi-boot cp $< $@ -lib : GHC/Prim.$(way_)hi +ALL_PRIMS = GHC/Prim.hi $(foreach way, $(WAYS), GHC/Prim.$(way)_hi) + +lib : $(ALL_PRIMS) + +boot :: $(ALL_PRIMS) + +CLEAN_FILES += $(ALL_PRIMS) + +SRC_CPP_OPTS += -I$(GHC_INCLUDE_DIR) -traditional + +#----------------------------------------------------------------------------- +# 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. + +ifeq "$(TARGETPLATFORM)" "i386-unknown-mingw32" + +# Turn off standard rule which creates HSbase.o from LIBOBJS. +DONT_WANT_BASE_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 + +endif # TARGETPLATFORM = i386-unknown-mingw32 + # -----------------------------------------------------------------------------