[project @ 2000-04-13 23:03:12 by sewardj]
[ghc-hetmet.git] / ghc / interpreter / Makefile
index 5760fde..6199e64 100644 (file)
@@ -1,13 +1,11 @@
 
-# ----------------------------------------------------------------------------- #
-# $Id: Makefile,v 1.13 1999/10/29 13:41:23 sewardj Exp $                        #
-# ----------------------------------------------------------------------------- #
+# --------------------------------------------------------------------------- #
+# $Id: Makefile,v 1.30 2000/04/03 17:27:10 sewardj Exp $                      #
+# --------------------------------------------------------------------------- #
 
-TOP = ../..
+TOP = ..
 include $(TOP)/mk/boilerplate.mk
-
-GHC_DIR = $(TOP)/ghc
-RTS_DIR = $(TOP)/ghc/rts
+SUBDIRS = lib
 
 # --------------------------------------------------------------------- #
 # interpreter and relevant .a/.so files                                 #
@@ -15,10 +13,22 @@ RTS_DIR = $(TOP)/ghc/rts
 
 ifeq "$(TARGETPLATFORM)" "i386-unknown-cygwin32"
 DYN_EXT=.dll
-MNO_CYGWIN=
+LIB_DL=
 else
 DYN_EXT=.so
-MNO_CYGWIN=
+LIB_DL=-ldl
+endif
+
+ifeq "$(HaveLibReadline)$" "YES"
+LIB_READLINE=-lreadline -ltermcap
+else
+LIB_READLINE=
+endif
+
+ifeq "$(HaveLibGmp)$" "YES"
+LIB_GMP=-lgmp
+else
+LIB_GMP=../rts/gmp/libgmp.a
 endif
 
 YACC = bison -y
@@ -27,28 +37,33 @@ YACC = bison -y
        mv y.tab.c $@
        rm -f input.o
 
-
 HS_SRCS =
 
 Y_SRCS = parser.y
 C_SRCS = link.c type.c static.c storage.c derive.c input.c compiler.c subst.c \
-     translate.c codegen.c lift.c free.c stgSubst.c optimise.c output.c   \
-     hugs.c dynamic.c stg.c sainteger.c interface.c
+     translate.c codegen.c lift.c free.c stgSubst.c output.c   \
+     hugs.c dynamic.c stg.c sainteger.c object.c interface.c
 
-SRC_CC_OPTS = $(MNO_CYGWIN) -g -O -I$(GHC_DIR)/interpreter -I$(GHC_DIR)/includes -I$(GHC_DIR)/rts -D__HUGS__ -DCOMPILING_RTS -Wall -Wstrict-prototypes -Wno-unused -DDEBUG -DDEBUG_EXTRA -Winline
+SRC_CC_OPTS = -g  -I$(GHC_INTERPRETER_DIR) -I$(GHC_INCLUDE_DIR) -I$(GHC_RUNTIME_DIR) -D__HUGS__ -DCOMPILING_RTS -Wall -Wstrict-prototypes -Wno-unused -DDEBUG -Winline
 
-GHC_LIBS_NEEDED = $(TOP)/ghc/rts/libHSrts.a
+GHC_LIBS_NEEDED = $(GHC_RUNTIME_DIR)/libHSrts.a
 
-all :: parser.c $(GHC_LIBS_NEEDED) nHandle.$(DYN_EXT) hugs
+all :: parser.c $(GHC_LIBS_NEEDED) nHandle$(DYN_EXT) hugs
 
 ### EXTREMELY hacky
-hugs: $(C_OBJS) ../rts/Sanity.o ../rts/Assembler.o ../rts/Disassembler.o \
+hugs: $(C_OBJS) ../rts/Sanity.o ../rts/Assembler.o ../rts/Disassembler.o   \
       ../rts/Evaluator.o ../rts/ForeignCall.o ../rts/GC.o ../rts/Printer.o \
-      ../rts/StgCRun.o
-       $(CC) -o $@ $(CC_OPTS) $^ $(GHC_LIBS_NEEDED) -lbfd -liberty -lm
+      ../rts/StgCRun.o ../rts/PrimOps.o ../rts/Prelude.o ../rts/libHSrts.a
+       $(CC) -o $@ $(CC_OPTS) $^ $(GHC_LIBS_NEEDED) \
+                -lbfd -liberty $(LIB_READLINE) $(LIB_DL) \
+                $(LIB_GMP) -lm
 
+foobar:
+       rm -f ../rts/libHSrts.a  ../rts/libHSrts_u.a
+       rm -f ../rts/StgCRun.o ../rts/StgCRun.u_o
+       make all
 
-nHandle.$(DYN_EXT): nHandle.c
+nHandle$(DYN_EXT): nHandle.c
 ifeq "$(TARGETPLATFORM)" "i386-unknown-cygwin32"
        gcc -mno-cygwin -O -Wall -o nHandle.o -c nHandle.c
        dllwrap -mno-cygwin --target=i386-mingw32 -o nHandle.dll \
@@ -57,11 +72,16 @@ else
        gcc -O -Wall -shared -fPIC -o nHandle.so nHandle.c
 endif
 
-$(TOP)/ghc/rts/libHSrts.a:
-       (cd $(TOP)/ghc/rts ; make clean ; make EXTRA_CC_OPTS=-I$(GHC_DIR)/interpreter)
+$(GHC_RUNTIME_DIR)/libHSrts.a:
+       (cd $(GHC_RUNTIME_DIR) ; make clean ; make EXTRA_CC_OPTS=-I$(GHC_INTERPRETER_DIR))
 
 cleanish:
        /bin/rm *.o
+rtsclean:
+       (cd $(GHC_RUNTIME_DIR) ; make clean)
+
+binaries:
+       tar cvzf stghugs.tar.gz hugs$(exeext) nHandle$(DYN_EXT) lib/*lhs lib/Prelude.hs
 
 snapshot:
        /bin/rm -f snapshot.tar