X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=ghc%2Fcompiler%2FMakefile;h=d0fd9c945b2c65b91522f18b4828fd62cffe7fa3;hb=0a7a9665973188f0c4f169ae30e0c9302564c870;hp=73be2dedbdb3c531ff0f3c485b6a6e1299229306;hpb=965b595c1ade5561b0ce7a43a7bb6479b358fefd;p=ghc-hetmet.git diff --git a/ghc/compiler/Makefile b/ghc/compiler/Makefile index 73be2de..d0fd9c9 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.52 1999/01/27 17:37:18 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)) \ @@ -87,19 +94,30 @@ SRCS_UGN_OBJS = $(patsubst %.c, %.o, $(SRCS_UGNC)) # generate correct dependencies for them. # C_SRCS += $(SRCS_UGNC) +# +# Add misc .c helper code (used by the frontend.) +# +C_SRCS += parser/ctypes.c parser/hschooks.c parser/hsclink.c \ + parser/id.c parser/infix.c parser/main.c parser/printtree.c \ + parser/syntax.c parser/type2context.c parser/util.c + +# +# Big Fudge to get around inherent problem that Makefile setup +# has got with 'mkdependC'. +# +SRC_MKDEPENDC_OPTS += -D__GLASGOW_HASKELL__=$(ProjectVersionInt) 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,38 +155,48 @@ 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/CmdLineOpts_HC_OPTS = -fvia-C +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 -K6m nativeGen/PprMach_HC_OPTS = -K2m nativeGen/MachMisc_HC_OPTS = -K2m -fvia-C nativeGen/MachCode_HC_OPTS = -H10m parser/UgenAll_HC_OPTS = -fvia-C '-\#include"hspincl.h"' parser/UgenUtil_HC_OPTS = -fvia-C '-\#include"hspincl.h"' -parser/U_constr_HC_OPTS = -fvia-C '-\#include"hspincl.h"' parser/U_binding_HC_OPTS = -fvia-C '-\#include"hspincl.h"' -parser/U_pbinding_HC_OPTS = -fvia-C '-\#include"hspincl.h"' +parser/U_constr_HC_OPTS = -fvia-C '-\#include"hspincl.h"' +parser/U_either_HC_OPTS = -fvia-C '-\#include"hspincl.h"' parser/U_entidt_HC_OPTS = -fvia-C '-\#include"hspincl.h"' +parser/U_gdexp_HC_OPTS = -fvia-C '-\#include"hspincl.h"' +parser/U_grhsb_HC_OPTS = -fvia-C '-\#include"hspincl.h"' parser/U_list_HC_OPTS = -fvia-C '-\#include"hspincl.h"' parser/U_literal_HC_OPTS = -fvia-C '-\#include"hspincl.h"' +parser/U_match_HC_OPTS = -fvia-C '-\#include"hspincl.h"' parser/U_maybe_HC_OPTS = -fvia-C '-\#include"hspincl.h"' -parser/U_either_HC_OPTS = -fvia-C '-\#include"hspincl.h"' 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 -rename/ParseIface_HC_OPTS += -Onot -H30m -fno-warn-incomplete-patterns +rename/ParseIface_HC_OPTS += -Onot -H45m -fno-warn-incomplete-patterns 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 +204,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 +226,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 +271,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 +298,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 +319,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