X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=ghc%2Futils%2Fhsc2hs%2FMakefile;h=f107167940eb34727d83829eb4dfbb955d8faca6;hb=153b9cb9b11e05c4edb1b6bc0a7b972660e41f70;hp=1342000304985e2f9812c6308e6ad218c1df8148;hpb=7a80ff0bd4e771b012f4cae609f840ef30f76ae2;p=ghc-hetmet.git diff --git a/ghc/utils/hsc2hs/Makefile b/ghc/utils/hsc2hs/Makefile index 1342000..f107167 100644 --- a/ghc/utils/hsc2hs/Makefile +++ b/ghc/utils/hsc2hs/Makefile @@ -1,5 +1,6 @@ # ----------------------------------------------------------------------------- -# $Id: Makefile,v 1.4 2001/01/12 18:49:25 qrczak Exp $ +# To compile with nhc98 on unix: +# nhc98 -cpp -package base -o hsc2hs-bin Main.hs TOP=../.. include $(TOP)/mk/boilerplate.mk @@ -9,10 +10,29 @@ INCLUDE_DIR=ghc/includes INSTALLING=1 +SRC_HC_OPTS += -i$(GHC_LIB_COMPAT_DIR) +SRC_LD_OPTS += -L$(GHC_LIB_COMPAT_DIR) -lghccompat + HS_PROG = hsc2hs-bin -SRC_HC_OPTS += -syslib util -syslib text +ifeq "$(HOSTPLATFORM)" "i386-unknown-mingw32" +HS_PROG = hsc2hs$(exeext) +endif +ifeq "$(HOSTPLATFORM)" "i386-unknown-cygwinw32" +HS_PROG = hsc2hs$(exeext) +endif + +ifeq "$(ghc_ge_504)" "NO" +SRC_HC_OPTS += -package util +endif + +# Note: Somehow we should pass $(exeext) here, but the history of changes used +# for calling the C preprocessor via GHC has changed a few times, making a +# clean solution impossible. So we revert to a hack in Main.hs... +SRC_HC_OPTS += -Wall +ifneq "$(HOSTPLATFORM)" "i386-unknown-mingw32" INSTALLED_SCRIPT_PROG = hsc2hs +endif INPLACE_SCRIPT_PROG = hsc2hs-inplace ifeq "$(INSTALLING)" "1" @@ -25,35 +45,51 @@ endif ifeq "$(INSTALLING)" "1" ifeq "$(BIN_DIST)" "1" +HSC2HS_BINDIR=$$\"\"libexecdir HSC2HS_DIR=$$\"\"libdir HSC2HS_EXTRA= else +HSC2HS_BINDIR=$(libexecdir) HSC2HS_DIR=$(libdir) HSC2HS_EXTRA=--cc=$(bindir)/ghc-$(ProjectVersion) endif # BIN_DIST else -HSC2HS_DIR=$(FPTOOLS_TOP_ABS)/$(CURRENT_DIR) -HSC2HS_EXTRA="--cc=$(CC) -I$(FPTOOLS_TOP_ABS)/$(INCLUDE_DIR)" +HSC2HS_BINDIR=$(FPTOOLS_TOP_ABS)/$(CURRENT_DIR) +HSC2HS_DIR=$(FPTOOLS_TOP_ABS_PLATFORM)/$(CURRENT_DIR) + +ifeq "$(HOSTPLATFORM)" "i386-unknown-mingw32" +extra_flags=$(addprefix --cflag=,$(filter-out -O,$(SRC_CC_OPTS))) +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 $(INSTALLED_SCRIPT_PROG) : $(TOP)/mk/config.mk -SCRIPT_SUBST_VARS = HSC2HS_DIR HS_PROG HSC2HS_EXTRA +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 +# ----------------------------------------------------------------------------- # don't recurse on 'make install' # ifeq "$(INSTALLING)" "1" -all clean veryclean maintainer-clean :: +all :: $(HS_PROG) + $(MAKE) INSTALLING=0 BIN_DIST=0 $(MFLAGS) $@ + +clean distclean maintainer-clean :: $(MAKE) INSTALLING=0 BIN_DIST=0 $(MFLAGS) $@ endif