X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=ghc%2Fcompiler%2FMakefile;h=a89de686032cc544c4ac0665f58064cc455a5438;hb=438596897ebbe25a07e1c82085cfbc5bdb00f09e;hp=73be2dedbdb3c531ff0f3c485b6a6e1299229306;hpb=965b595c1ade5561b0ce7a43a7bb6479b358fefd;p=ghc-hetmet.git diff --git a/ghc/compiler/Makefile b/ghc/compiler/Makefile index 73be2de..a89de68 100644 --- a/ghc/compiler/Makefile +++ b/ghc/compiler/Makefile @@ -1,5 +1,5 @@ # ----------------------------------------------------------------------------- -# $Id: Makefile,v 1.42 1998/06/04 11:36:51 sof Exp $ +# $Id: Makefile,v 1.46 1998/12/02 13:17:15 simonm Exp $ TOP = .. include $(TOP)/mk/boilerplate.mk @@ -60,14 +60,21 @@ endif HS_SRCS = $(SRCS_UGNHS) \ - $(foreach dir,$(DIRS),$(wildcard $(dir)/*.lhs)) \ - rename/ParseIface.hs + $(foreach dir,$(DIRS),$(wildcard $(dir)/*.lhs)) + +ifneq "$(GhcWithHscBuiltViaC)" "YES" +HS_SRCS += rename/ParseIface.hs +endif # NB: it's no good to include *.hs in the top-line wildcard, because the .hs files # in parser/ may not have been created at that point. HCS = $(patsubst %.lhs, %.hc, $(patsubst %.hs, %.hc, $(HS_SRCS))) +# ParseIface.hs ain't part of HS_SRCS when this is on.. +ifeq "$(GhcWithHscBuiltViaC)" "YES" +HCS += rename/ParseIface.hc +endif HS_OBJS = \ $(patsubst %.hc, %.o, $(HCS)) \ @@ -91,15 +98,14 @@ C_SRCS += $(SRCS_UGNC) LIBOBJS = \ $(SRCS_UGN_OBJS) parser/hslexer.o parser/hsparser.tab.o \ parser/id.o parser/infix.o parser/syntax.o parser/type2context.o \ - parser/util.o + parser/util.o parser/ctypes.o -# # stuff you get for free in a source distribution # -SRC_DIST_FILES += rename/ParseIface.hs \ - parser/U_tree.c parser/tree.h parser/tree.c \ - parser/hsparser.tab.c parser/hsparser.tab.h \ - parser/hslexer.c +# SRC_DIST_FILES += rename/ParseIface.hs \ +# parser/U_tree.c parser/tree.h parser/tree.c \ +# parser/hsparser.tab.c parser/hsparser.tab.h \ +# parser/hslexer.c # ----------------------------------------------------------------------------- # Haskell compilations @@ -137,8 +143,15 @@ absCSyn/PprAbsC_HC_OPTS = -H10m basicTypes/IdInfo_HC_OPTS = -K2m hsSyn/HsExpr_HC_OPTS = -K2m -main/Main_HC_OPTS = -fvia-C -DPROJECTVERSION=$(GhcProjectVersion) -main/MkIface_HC_OPTS = -DPROJECTVERSION=$(GhcProjectVersionInt) +main/Main_HC_OPTS = -fvia-C +main/Constants_HC_OPTS = -DHscIfaceFileVersion=$(HscIfaceFileVersion) + +ifneq "$(GhcWithHscBuiltViaC)" "YES" +ifeq "$(GhcReportCompiles)" "YES" +main/Main_HC_OPTS += -syslib misc -DREPORT_TO_MOTHERLODE +endif +endif + main/CmdLineOpts_HC_OPTS = -fvia-C nativeGen/PprMach_HC_OPTS = -K2m nativeGen/MachMisc_HC_OPTS = -K2m -fvia-C @@ -157,7 +170,7 @@ parser/U_qid_HC_OPTS = -fvia-C '-\#include"hspincl.h"' parser/U_tree_HC_OPTS = -H12m -fvia-C '-\#include"hspincl.h"' parser/U_ttype_HC_OPTS = -fvia-C '-\#include"hspincl.h"' prelude/PrimOp_HC_OPTS = -H12m -K3m -reader/Lex_HC_OPTS = -K2m -H16m -fvia-C -DPROJECTVERSION=$(GhcProjectVersionInt) +reader/Lex_HC_OPTS = -K2m -H16m -fvia-C # Heap was 6m with 2.10 reader/ReadPrefix_HC_OPTS = -fvia-C '-\#include"hspincl.h"' -H10m @@ -167,8 +180,8 @@ rename/ParseIface_HAPPY_OPTS += -g ifeq "$(TARGETPLATFORM)" "hppa1.1-hp-hpux9" rename/RnMonad_HC_OPTS = -fvia-C -O2 -O2-for-C -else endif + rename/RnEnv_HC_OPTS = -fvia-C rename/RnSource_HC_OPTS = -H12m rename/RnIfaces_HC_OPTS = -H8m -fvia-C @@ -176,13 +189,19 @@ rename/RnExpr_HC_OPTS = -H10m rename/RnNames_HC_OPTS = -H12m rename/RnMonad_HC_OPTS = -fvia-C specialise/Specialise_HC_OPTS = -Onot -H12m +simplCore/Simplify_HC_OPTS = -H15m typecheck/TcGenDeriv_HC_OPTS = -H10m +# tmp, -- SDM +specialise/Specialise_HC_OPTS += -fno-prune-tydecls + # Was 10m for 2.10 typecheck/TcHsSyn_HC_OPTS = -H15m + # Was 10m for 2.10 typecheck/TcExpr_HC_OPTS = -H15m +typecheck/TcBinds_HC_OPTS = -H10m typecheck/TcEnv_HC_OPTS = -H10m utils/Argv_HC_OPTS = -fvia-C @@ -192,6 +211,11 @@ utils/StringBuffer_HC_OPTS = -fvia-C -fno-prune-tydecls utils/Digraph_HC_OPTS = -fglasgow-exts -fvia-C utils/DirUtils_HC_OPTS = -fvia-C +ifeq "$(alpha_HOST_ARCH)" "1" +# "stbu" bug in alpha native code generator... +basicTypes/Unique_HC_OPTS = -fvia-C +endif + # flags for PrimPacked: # # -monly-3-regs @@ -232,7 +256,7 @@ SRC_FLEX_OPTS += -s parser/hschooks.o : parser/hschooks.c @$(RM) $@ - $(HC) -c -o $@ $(HCFLAGS) parser/hschooks.c + $(HC) -c -o $@ -I$(GHC_INCLUDE_DIR) $(HC_OPTS) parser/hschooks.c # Interface-file parser uses Happy @@ -259,6 +283,12 @@ CLEAN_FILES += hsp SRC_LD_OPTS += -no-link-chk +ifneq "$(GhcWithHscBuiltViaC)" "YES" +ifeq "$(GhcReportCompiles)" "YES" +SRC_LD_OPTS += -syslib misc -syslib exts +endif +endif + #----------------------------------------------------------------------------- # install @@ -274,7 +304,11 @@ INSTALL_LIBEXECS += hsc hsp # # Before doing `make depend', need to build all derived Haskell source files # -depend :: $(LOOPS) $(SRCS_UGNHS) rename/ParseIface.hs +depend :: $(LOOPS) $(SRCS_UGNHS) + +ifneq "$(GhcWithHscBuiltViaC)" "YES" +depend :: rename/ParseIface.hs +endif #----------------------------------------------------------------------------- # clean