gc: delegated mallocs in GarbageAlloc to hs-boehmgc (Mate.GC.Boehm.mallocBytes);
[mate.git] / Makefile
index 289fe3fe39708daee2d41d31055865d1c4b86928..b0a440ddfc97cbb1c05324873435cbe51931f14e 100644 (file)
--- a/Makefile
+++ b/Makefile
-JAVAC = javac
-JAVA_FILES := $(wildcard tests/*.java)
+SHELL := bash
+
+JAVAC := javac
+JAVA_FILES := $(wildcard jmate/lang/*.java jmate/io/*.java java/lang/*.java java/io/*.java)
 CLASS_FILES := $(JAVA_FILES:.java=.class)
+TEST_JAVA_FILES := $(wildcard tests/*.java)
+TEST_CLASS_FILES := $(TEST_JAVA_FILES:.java=.test)
+HS_FILES := $(wildcard Mate/*.hs)
+HS_BOOT := $(wildcard Mate/*.hs-boot)
+BUILD := build
+B_RELEASE := $(BUILD)/release
+B_STATIC := $(BUILD)/static
+B_DEBUG := $(BUILD)/debug
+PACKAGES_ := bytestring harpy hs-java plugins
+PACKAGES := $(addprefix -package ,$(PACKAGES_))
+
+
+# use `cpphs'
+GHC_CPP := -cpp -pgmP cpphs -optP --cpp
+
+GHC_OPT  = -I. -O0 -Wall -fno-warn-unused-do-bind -fwarn-tabs
+# see *.gdb target. also useful for profiling (-p at call)
+GHC_OPT += -rtsopts # -prof -auto-all
+GHC_OPT += $(GHC_CPP)
+
+# dunno anymore? some linker stuff regarding GHCi
+GHC_LD := -optl-Xlinker -optl-x
+
+
+.PHONY: all tests clean ghci hlint
+
+all: mate
+
+%: %.class mate
+       ./mate $(basename $<)
+
 
-all: mate $(CLASS_FILES)
-       ./mate tests/Test.class
+tests: mate $(TEST_JAVA_FILES:.java=.class) $(TEST_CLASS_FILES)
 
+CALLF = $(basename $@).call
+testcase = ./tools/openjdktest.sh "$(1) $(basename $@)"
+%.test: %.class mate
+       @if [ -f $(CALLF) ]; \
+               then $(call testcase,`cat $(CALLF)`); \
+               else $(call testcase, ); fi
+
+COMPILEF = $(basename $@).compile
 %.class: %.java
-       javac $<
+       @if [ -f $(COMPILEF) ]; \
+               then $(SHELL) $(COMPILEF); \
+               else $(JAVAC) $(JAVA_FILES) $<; fi
+       @echo "JAVAC $<"
+
+ffi/native.o: ffi/native.c
+       ghc -Wall -O2 -c $< -o $@
+
+GHCCALL = ghc --make $(GHC_OPT) Mate.hs ffi/trap.c -o $@ $(GHC_LD) -outputdir
+mate: Mate.hs ffi/trap.c $(HS_FILES) $(HS_BOOT) ffi/native.o $(CLASS_FILES)
+       @mkdir -p $(B_RELEASE)
+       $(GHCCALL) $(B_RELEASE) -dynamic
+
+mate.static: Mate.hs ffi/trap.c $(HS_FILES) $(HS_BOOT) ffi/native.o $(CLASS_FILES)
+       @mkdir -p $(B_STATIC)
+       $(GHCCALL) $(B_STATIC) -static
+
+%.dbg: %.class mate.dbg
+       ./mate.dbg $(basename $<)
 
-mate: Mate.hs ./src/Utilities.hs trap.c
-       ghc --make -Wall -O2 $^ -o $@
+%.gdb: %.class mate.dbg
+       gdb -x .gdbcmds -q --args mate.dbg $(basename $<) +RTS -V0 --install-signal-handlers=no
+
+ifeq (${DBGFLAGS},)
+DEBUGFLAGS = -DDBG_JIT -DDBG_MP
+else
+DEBUGFLAGS = ${DBGFLAGS}
+endif
+mate.dbg: Mate.hs ffi/trap.c $(HS_FILES) $(HS_BOOT) ffi/native.o $(CLASS_FILES)
+       @mkdir -p $(B_DEBUG)/{ffi,Mate,}
+       gcc -Wall $(DEBUGFLAGS) -O0 -c ffi/trap.c -o $(B_DEBUG)/ffi/trap.o
+       ghc --make $(DEBUGFLAGS) $(GHC_OPT) Mate.hs $(B_DEBUG)/ffi/trap.o -o $@ $(GHC_LD) -outputdir $(B_DEBUG)
 
 clean:
-       rm -f *.hi *.o mate src/*.class
+       rm -rf $(BUILD) mate mate.static mate.dbg ffi/native.o \
+               tests/*.class Mate/*_stub.* \
+               jmate/lang/*.class jmate/io/*.class java/io/*.class \
+               java/lang/{Integer,Character,String,System}.class
+
+ghci: mate.static
+       ghci -I. $(PACKAGES) -outputdir $(B_STATIC) Mate.hs $(GHC_CPP)
+
+tags: mate.static
+       @# @-fforce-recomp, see
+       @# http://stackoverflow.com/questions/7137414/how-do-i-force-interpretation-in-hint
+       @# @-fobject-code: force to generate native code (necessary for ffi stuff)
+       ghc -I. -fforce-recomp -fobject-code $(PACKAGES) Mate.hs -outputdir $(B_STATIC) -e :ctags $(GHC_CPP)
+
+hlint:
+       @# hlint isn't able to evaluate CPP comments correctly *sigh*
+       @cp debug.h debug_tmp.h
+       @# so we remove them "by hand", for hlint
+       @gcc -E -x c -fpreprocessed -dD -E debug_tmp.h | grep -v 'debug_tmp.h' > debug.h
+       @# ignore error code from hlint
+       -hlint Mate.hs Mate/
+       @mv debug_tmp.h debug.h