X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;ds=sidebyside;f=Makefile;h=9fac0faffc22176d7b65cce2f9aa462063a1c2c1;hb=3aeed5d77b08945f63d800aa41ec3122627c73a9;hp=47276f3f99b552fd46ffbc87c6fd52da8d478630;hpb=0b26bbe1ee1ffccacbb81c8e85dfa0047f99cee4;p=haskell-directory.git diff --git a/Makefile b/Makefile index 47276f3..9fac0fa 100644 --- a/Makefile +++ b/Makefile @@ -1,5 +1,5 @@ # ----------------------------------------------------------------------------- -# $Id: Makefile,v 1.16 2002/02/13 11:51:40 simonmar Exp $ +# $Id: Makefile,v 1.25 2002/04/26 13:26:39 simonmar Exp $ TOP=.. include $(TOP)/mk/boilerplate.mk @@ -34,25 +34,27 @@ ALL_DIRS = \ Text \ Text/Html \ Text/PrettyPrint \ + Text/ParserCombinators \ Text/Regex \ - Text/Show + Text/Show \ + Text/Read PACKAGE = base -ifneq "$(HavePosixRegex)" "YES" -EXCLUDED_SRCS += Text/Regex/Posix.hsc Text/Regex.hs -endif - 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: -GHC/IOBase_HC_OPTS = -funbox-strict-fields - -Data/Array/Storable_HC_OPTS = -funbox-strict-fields +SRC_HC_OPTS += -funbox-strict-fields # ----------------------------------------------------------------------------- # PrimOpWrappers @@ -65,22 +67,6 @@ boot :: GHC/PrimopWrappers.hs CLEAN_FILES += GHC/PrimopWrappers.hs -# ----------------------------------------------------------------------------- -# GHC/Prim.hi-boot - -GHC/Prim.$(way_)hi : GHC/Prim.hi-boot - cp $< $@ - -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 # @@ -91,21 +77,49 @@ SRC_CPP_OPTS += -I$(GHC_INCLUDE_DIR) -traditional ifeq "$(TARGETPLATFORM)" "i386-unknown-mingw32" # 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 endif # TARGETPLATFORM = i386-unknown-mingw32 # ----------------------------------------------------------------------------- +# Doc building with Haddock + +EXCLUDED_HADDOCK_SRCS = \ + GHC/Err.lhs \ + Data/Generics.hs \ + GHC/PArr.hs + +HS_PPS = $(addsuffix .raw-hs, $(basename $(filter-out $(EXCLUDED_HADDOCK_SRCS), $(HS_SRCS)))) + +HADDOCK = $(FPTOOLS_TOP)/haddock/src/haddock-inplace + +# 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 >$@ + +%.raw-hs : %.hs + $(GHC_INPLACE) $(HC_OPTS) -E -cpp $< -o $<.tmp && sed -e 's/^#.*//' <$<.tmp >$@ + +# ----------------------------------------------------------------------------- include $(TOP)/mk/target.mk +ifeq "$(TARGETPLATFORM)" "i386-unknown-mingw32" +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 +endif # TARGETPLATFORM = i386-unknown-mingw32 +