X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=ghc%2Futils%2Fhsc2hs%2FMakefile;h=562803a55390a5e082b1a5b3ae205d07358de6d8;hb=387a411e5d6478249de6872c283f2df78ef83bf4;hp=5595d5b34943efb63e489a3e74d5d4d704b730de;hpb=0d84f3fa4600fbbc7cd18f27bd0ded0f3400863c;p=ghc-hetmet.git diff --git a/ghc/utils/hsc2hs/Makefile b/ghc/utils/hsc2hs/Makefile index 5595d5b..562803a 100644 --- a/ghc/utils/hsc2hs/Makefile +++ b/ghc/utils/hsc2hs/Makefile @@ -1,5 +1,5 @@ # ----------------------------------------------------------------------------- -# $Id: Makefile,v 1.20 2001/08/01 20:37:00 qrczak Exp $ +# $Id: Makefile,v 1.38 2003/06/04 15:18:30 panne Exp $ TOP=../.. include $(TOP)/mk/boilerplate.mk @@ -10,11 +10,24 @@ INCLUDE_DIR=ghc/includes INSTALLING=1 HS_PROG = hsc2hs-bin -SRC_HC_OPTS += -package util -# TODO: remove -H80M when the strictness analyser is working again. -Main_HC_OPTS = -H80M +ifeq "$(HOSTPLATFORM)" "i386-unknown-mingw32" +HS_PROG = hsc2hs$(exeext) +endif +ifeq "$(HOSTPLATFORM)" "i386-unknown-cygwinw32" +HS_PROG = hsc2hs$(exeext) +endif + +ghc_ge_504 = $(shell if (test $(GhcCanonVersion) -ge 504); then echo YES; else echo NO; fi) + +ifeq "$(ghc_ge_504)" "NO" +SRC_HC_OPTS += -package util +endif + +SRC_HC_OPTS += -cpp +ifneq "$(HOSTPLATFORM)" "i386-unknown-mingw32" INSTALLED_SCRIPT_PROG = hsc2hs +endif INPLACE_SCRIPT_PROG = hsc2hs-inplace ifeq "$(INSTALLING)" "1" @@ -37,13 +50,13 @@ HSC2HS_EXTRA=--cc=$(bindir)/ghc-$(ProjectVersion) endif # BIN_DIST else HSC2HS_BINDIR=$(FPTOOLS_TOP_ABS)/$(CURRENT_DIR) -HSC2HS_DIR=$(FPTOOLS_TOP_ABS)/$(CURRENT_DIR) -ifneq "$(TARGETPLATFORM)" "i386-unknown-mingw32" -HSC2HS_EXTRA="--cc=$(CC) --cflag=-D__GLASGOW_HASKELL__=$(ProjectVersionInt) -I$(FPTOOLS_TOP_ABS)/$(INCLUDE_DIR)" -else +HSC2HS_DIR=$(FPTOOLS_TOP_ABS_PLATFORM)/$(CURRENT_DIR) + +ifeq "$(HOSTPLATFORM)" "i386-unknown-mingw32" extra_flags=$(addprefix --cflag=,$(filter-out -O,$(SRC_CC_OPTS))) -HSC2HS_EXTRA="--cc=$(CC) $(extra_flags) --cflag=-D__GLASGOW_HASKELL__=$(ProjectVersionInt) -I$(FPTOOLS_TOP_ABS)/$(INCLUDE_DIR)" endif + +HSC2HS_EXTRA="--cc=$(CC) --ld=$(CC) $(extra_flags) --cflag=-D__GLASGOW_HASKELL__=$(ProjectVersionInt) -I$(FPTOOLS_TOP_ABS_PLATFORM)/$(INCLUDE_DIR)" endif $(SCRIPT_PROG) : Makefile @@ -54,8 +67,12 @@ SCRIPT_SUBST_VARS = HSC2HS_BINDIR HSC2HS_DIR HS_PROG HSC2HS_EXTRA SCRIPT_OBJS=hsc2hs.sh INTERP=$(SHELL) +ifneq "$(TARGETPLATFORM)" "i386-unknown-mingw32" INSTALL_SCRIPTS += $(SCRIPT_PROG) INSTALL_LIBEXECS += $(HS_PROG) +else +INSTALL_PROGS += $(HS_PROG) +endif override datadir=$(libdir) INSTALL_DATAS += template-hsc.h @@ -63,7 +80,10 @@ INSTALL_DATAS += template-hsc.h # ----------------------------------------------------------------------------- # Create driver configuration -CONFIG_HS = Config.hs +CONFIG_HS = Config.hs +CLEAN_FILES += $(CONFIG_HS) +EXTRA_SRCS += $(CONFIG_HS) + boot :: $(CONFIG_HS) $(CONFIG_HS) : $(FPTOOLS_TOP)/mk/config.mk Makefile @@ -72,20 +92,23 @@ $(CONFIG_HS) : $(FPTOOLS_TOP)/mk/config.mk Makefile @echo "module Config where" >>$(CONFIG_HS) @echo "cDEFAULT_TMPDIR = \"$(DEFAULT_TMPDIR)\"" >> $(CONFIG_HS) @echo "cGCC = \"$(WhatGccIsCalled)\"" >> $(CONFIG_HS) + @echo "progNameSuffix = \"$(exeext)\"" >> $(CONFIG_HS) +ifneq "$(HOSTPLATFORM)" "i386-unknown-mingw32" + @echo "pathSep = '/'" >> $(CONFIG_HS) +else + @echo "pathSep = (toEnum 92 :: Char)" >> $(CONFIG_HS) +endif @echo done. -CLEAN_FILES += $(CONFIG_HS) - +# ----------------------------------------------------------------------------- # don't recurse on 'make install' # ifeq "$(INSTALLING)" "1" -all clean distclean maintainer-clean :: +all :: $(HS_PROG) $(MAKE) INSTALLING=0 BIN_DIST=0 $(MFLAGS) $@ -endif -# hsc2hs-inplace is needed to boot in ghc/lib/std... -ifneq "$(BootingFromHc)" "YES" -boot :: all +clean distclean maintainer-clean :: + $(MAKE) INSTALLING=0 BIN_DIST=0 $(MFLAGS) $@ endif include $(TOP)/mk/target.mk