-# ----------------------------------------------------------------------------- #
-# $Id: Makefile,v 1.16 1999/11/12 16:38:31 sewardj Exp $ #
-# ----------------------------------------------------------------------------- #
+# --------------------------------------------------------------------------- #
+# $Id: Makefile,v 1.36 2000/05/12 13:49:54 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 #
LIB_DL=-ldl
endif
-ifeq "$(HaveLibReadLine)$" "YES"
-LIB_READLINE=-lreadline
+ifeq "$(HaveLibGmp)$" "YES"
+LIB_GMP=-lgmp
else
-LIB_READLINE=
+LIB_GMP=../rts/gmp/libgmp.a
endif
YACC = bison -y
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 = -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 = -I$(GHC_INTERPRETER_DIR) -I$(GHC_INCLUDE_DIR) -I$(GHC_RUNTIME_DIR) -D__HUGS__ -DCOMPILING_RTS -DNO_REGS -Wall -Wstrict-prototypes -Wno-unused -DDEBUG -Winline -g -O
-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) -lreadline \
- -lbfd -liberty $(LIB_READLINE) $(LIB_DL) -lm
-
-nHandle.$(DYN_EXT): nHandle.c
+ ../rts/StgCRun.o ../rts/PrimOps.o ../rts/Prelude.o ../rts/Storage.o \
+ ../rts/Schedule.o ../rts/libHSrts.a
+ $(CC) -o $@ $(CC_OPTS) $^ $(GHC_LIBS_NEEDED) \
+ -lbfd -liberty $(LibsReadline) $(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
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 \
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
INSTALL_LIBEXECS = hugs
-depend :: $(LOOPS) $(SRCS_UGNHS)
+depend :: parser.c $(LOOPS) $(SRCS_UGNHS)
include $(TOP)/mk/target.mk
-HUGSCPP = ../utils/hscpp/hscpp -D__HUGS__ -DUSE_REPORT_PRELUDE
-
-libs:
- $(HUGSCPP) ../lib/std/List.lhs > lib/List.lhs
- $(HUGSCPP) ../lib/std/Ix.lhs > lib/Ix.lhs
- $(HUGSCPP) ../lib/std/Complex.lhs > lib/Complex.lhs
- $(HUGSCPP) ../lib/std/Char.lhs > lib/Char.lhs
- $(HUGSCPP) ../lib/std/Ratio.lhs > lib/Ratio.lhs
- $(HUGSCPP) ../lib/std/Random.lhs > lib/Random.lhs
- $(HUGSCPP) ../lib/std/Array.lhs > lib/Array.lhs
- $(HUGSCPP) ../lib/std/Maybe.lhs > lib/Maybe.lhs
- $(HUGSCPP) ../lib/std/Monad.lhs > lib/Monad.lhs
- $(HUGSCPP) ../lib/std/Numeric.lhs > lib/Numeric.lhs
- $(HUGSCPP) ../lib/std/Directory.lhs > lib/Directory.lhs
- $(HUGSCPP) ../lib/std/System.lhs > lib/System.lhs
- $(HUGSCPP) ../lib/std/Locale.lhs > lib/Locale.lhs
- $(HUGSCPP) ../lib/std/CPUTime.lhs > lib/CPUTime.lhs
- $(HUGSCPP) ../lib/std/IO.lhs > lib/IO.lhs
+