]> gitweb.factorcode.org Git - factor.git/blobdiff - GNUmakefile
websites: remove .page nav style
[factor.git] / GNUmakefile
old mode 100755 (executable)
new mode 100644 (file)
index 27f1d17..bad078a
@@ -1,22 +1,49 @@
 ifdef CONFIG
-       CC = gcc
-       CPP = g++
+       VERSION = 0.99
+       GIT_LABEL = $(shell echo `git describe --all`-`git rev-parse HEAD`)
+       BUNDLE = Factor.app
+       DEBUG ?= 0
+       REPRODUCIBLE ?= 0
 
-       VERSION = 0.94
+       # gmake's default CXX is g++, we prefer c++
+       SHELL_CXX = $(shell printenv CXX)
+       ifeq ($(SHELL_CXX),)
+               CXX=c++
+       else
+               CXX=$(SHELL_CXX)
+       endif
 
-       BUNDLE = Factor.app
-       LIBPATH = -L/usr/X11R6/lib
+       XCODE_PATH ?= /Applications/Xcode.app
+       MACOSX_32_SDK ?= MacOSX10.11.sdk
 
        include $(CONFIG)
 
-       CFLAGS = -Wall $(SITE_CFLAGS)
+       CFLAGS += -Wall \
+               -Wextra \
+               -pedantic \
+               -DFACTOR_VERSION="$(VERSION)" \
+               -DFACTOR_GIT_LABEL="$(GIT_LABEL)" \
+               $(SITE_CFLAGS)
+
+       CXXFLAGS += -std=c++11
 
-       ifdef DEBUG
+       # SANITIZER=address ./build.sh compile
+       # address,thread,undefined,leak
+       ifdef SANITIZER
+               CFLAGS += -fsanitize=$(SANITIZER)
+               CXXFLAGS += -fsanitize=$(SANITIZER)
+       endif
+
+       ifneq ($(DEBUG), 0)
                CFLAGS += -g -DFACTOR_DEBUG
        else
                CFLAGS += -O3
        endif
 
+       ifneq ($(REPRODUCIBLE), 0)
+               CFLAGS += -DFACTOR_REPRODUCIBLE
+       endif
+
        ENGINE = $(DLL_PREFIX)factor$(DLL_SUFFIX)$(DLL_EXTENSION)
        EXECUTABLE = factor$(EXE_SUFFIX)$(EXE_EXTENSION)
        CONSOLE_EXECUTABLE = factor$(EXE_SUFFIX)$(CONSOLE_EXTENSION)
@@ -26,7 +53,6 @@ ifdef CONFIG
                vm/alien.o \
                vm/arrays.o \
                vm/bignum.o \
-               vm/booleans.o \
                vm/byte_arrays.o \
                vm/callbacks.o \
                vm/callstack.o \
@@ -41,10 +67,8 @@ ifdef CONFIG
                vm/entry_points.o \
                vm/errors.o \
                vm/factor.o \
-               vm/free_list.o \
                vm/full_collector.o \
                vm/gc.o \
-               vm/gc_info.o \
                vm/image.o \
                vm/inline_cache.o \
                vm/instruction_operands.o \
@@ -69,6 +93,7 @@ ifdef CONFIG
 
        MASTER_HEADERS = $(PLAF_MASTER_HEADERS) \
                vm/assert.hpp \
+               vm/debug.hpp \
                vm/layouts.hpp \
                vm/platform.hpp \
                vm/primitives.hpp \
@@ -89,27 +114,18 @@ ifdef CONFIG
                vm/mark_bits.hpp \
                vm/free_list.hpp \
                vm/fixup.hpp \
-               vm/tuples.hpp \
-               vm/free_list_allocator.hpp \
                vm/write_barrier.hpp \
                vm/object_start_map.hpp \
-               vm/nursery_space.hpp \
                vm/aging_space.hpp \
                vm/tenured_space.hpp \
                vm/data_heap.hpp \
                vm/code_heap.hpp \
                vm/gc.hpp \
-               vm/debug.hpp \
-               vm/strings.hpp \
-               vm/words.hpp \
                vm/float_bits.hpp \
                vm/io.hpp \
                vm/image.hpp \
-               vm/alien.hpp \
                vm/callbacks.hpp \
                vm/dispatch.hpp \
-               vm/entry_points.hpp \
-               vm/safepoints.hpp \
                vm/vm.hpp \
                vm/allot.hpp \
                vm/tagged.hpp \
@@ -118,14 +134,7 @@ ifdef CONFIG
                vm/generic_arrays.hpp \
                vm/callstack.hpp \
                vm/slot_visitor.hpp \
-               vm/collector.hpp \
-               vm/copying_collector.hpp \
-               vm/nursery_collector.hpp \
-               vm/aging_collector.hpp \
                vm/to_tenured_collector.hpp \
-               vm/code_block_visitor.hpp \
-               vm/compaction.hpp \
-               vm/full_collector.hpp \
                vm/arrays.hpp \
                vm/math.hpp \
                vm/byte_arrays.hpp \
@@ -144,7 +153,7 @@ ifdef CONFIG
 endif
 
 default:
-       $(MAKE) `./build-support/factor.sh make-target`
+       $(MAKE) `./build.sh make-target`
 
 help:
        @echo "Run '$(MAKE)' with one of the following parameters:"
@@ -153,22 +162,31 @@ help:
        @echo "linux-x86-64"
        @echo "linux-ppc-32"
        @echo "linux-ppc-64"
-       @echo "linux-arm"
+       @echo "linux-arm-64"
+       @echo "freebsd-x86-32"
+       @echo "freebsd-x86-64"
        @echo "macosx-x86-32"
        @echo "macosx-x86-64"
        @echo "macosx-x86-fat"
+       @echo "macosx-arm64"
        @echo "windows-x86-32"
        @echo "windows-x86-64"
        @echo ""
        @echo "Additional modifiers:"
        @echo ""
        @echo "DEBUG=1  compile VM with debugging information"
+       @echo "REPRODUCIBLE=1  compile VM without timestamp"
        @echo "SITE_CFLAGS=...  additional optimization flags"
-       @echo "NO_UI=1  don't link with X11 libraries (ignored on Mac OS X)"
        @echo "X11=1  force link with X11 libraries instead of Cocoa (only on Mac OS X)"
 
 ALL = factor factor-ffi-test factor-lib
 
+freebsd-x86-32:
+       $(MAKE) $(ALL) CONFIG=vm/Config.freebsd.x86.32
+
+freebsd-x86-64:
+       $(MAKE) $(ALL) CONFIG=vm/Config.freebsd.x86.64
+
 macosx-x86-32:
        $(MAKE) $(ALL) macosx.app CONFIG=vm/Config.macosx.x86.32
 
@@ -178,6 +196,15 @@ macosx-x86-64:
 macosx-x86-fat:
        $(MAKE) $(ALL) macosx.app CONFIG=vm/Config.macosx.x86.fat
 
+macosx-arm64:
+       $(MAKE) $(ALL) macosx.app CONFIG=vm/Config.macosx.arm64
+
+linux-arm-32:
+       $(MAKE) $(ALL) CONFIG=vm/Config.linux.arm.32
+
+linux-arm-64:
+       $(MAKE) $(ALL) CONFIG=vm/Config.linux.arm.64
+
 linux-x86-32:
        $(MAKE) $(ALL) CONFIG=vm/Config.linux.x86.32
 
@@ -190,9 +217,6 @@ linux-ppc-32:
 linux-ppc-64:
        $(MAKE) $(ALL) CONFIG=vm/Config.linux.ppc.64
 
-linux-arm:
-       $(MAKE) $(ALL) CONFIG=vm/Config.linux.arm
-
 windows-x86-32:
        $(MAKE) $(ALL) CONFIG=vm/Config.windows.x86.32
        $(MAKE) factor-console CONFIG=vm/Config.windows.x86.32
@@ -207,7 +231,7 @@ macosx.app: factor
        mkdir -p $(BUNDLE)/Contents/MacOS
        mkdir -p $(BUNDLE)/Contents/Frameworks
        mv $(EXECUTABLE) $(BUNDLE)/Contents/MacOS/factor
-       ln -s Factor.app/Contents/MacOS/factor ./factor
+       ln -s $(BUNDLE)/Contents/MacOS/factor ./factor
 
 $(ENGINE): $(DLL_OBJS)
        $(TOOLCHAIN_PREFIX)$(LINKER) $(ENGINE) $(DLL_OBJS)
@@ -215,35 +239,35 @@ $(ENGINE): $(DLL_OBJS)
 factor-lib: $(ENGINE)
 
 factor: $(EXE_OBJS) $(DLL_OBJS)
-       $(TOOLCHAIN_PREFIX)$(CPP) $(LIBPATH) -L. $(DLL_OBJS) \
-               $(CFLAGS) -o $(EXECUTABLE) $(LIBS) $(EXE_OBJS)
+       $(TOOLCHAIN_PREFIX)$(CXX) -L. $(DLL_OBJS) \
+               $(CFLAGS) $(CXXFLAGS) -o $(EXECUTABLE) $(LIBS) $(EXE_OBJS)
 
 factor-console: $(EXE_OBJS) $(DLL_OBJS)
-       $(TOOLCHAIN_PREFIX)$(CPP) $(LIBPATH) -L. $(DLL_OBJS) \
-               $(CFLAGS) $(CFLAGS_CONSOLE) -o $(CONSOLE_EXECUTABLE) $(LIBS) $(EXE_OBJS)
+       $(TOOLCHAIN_PREFIX)$(CXX) -L. $(DLL_OBJS) \
+               $(CFLAGS) $(CXXFLAGS) $(CFLAGS_CONSOLE) -o $(CONSOLE_EXECUTABLE) $(LIBS) $(EXE_OBJS)
 
 factor-ffi-test: $(FFI_TEST_LIBRARY)
 
 $(FFI_TEST_LIBRARY): vm/ffi_test.o
-       $(TOOLCHAIN_PREFIX)$(CC) $(LIBPATH) $(CFLAGS) $(FFI_TEST_CFLAGS) $(SHARED_FLAG) -o $(FFI_TEST_LIBRARY) $(TEST_OBJS)
+       $(TOOLCHAIN_PREFIX)$(CC) $(CFLAGS) $(FFI_TEST_CFLAGS) $(SHARED_FLAG) -o $(FFI_TEST_LIBRARY) $(TEST_OBJS)
 
 vm/resources.o:
        $(TOOLCHAIN_PREFIX)$(WINDRES) vm/factor.rs vm/resources.o
 
 vm/ffi_test.o: vm/ffi_test.c
-       $(TOOLCHAIN_PREFIX)$(CC) -c $(CFLAGS) $(FFI_TEST_CFLAGS) -o $@ $<
+       $(TOOLCHAIN_PREFIX)$(CC) -c $(CFLAGS) $(FFI_TEST_CFLAGS) -std=c99 -o $@ $<
 
 vm/master.hpp.gch: vm/master.hpp $(MASTER_HEADERS)
-       $(TOOLCHAIN_PREFIX)$(CPP) -c -x c++-header $(CFLAGS) -o $@ $<
+       $(TOOLCHAIN_PREFIX)$(CXX) -c -x c++-header $(CFLAGS) $(CXXFLAGS) -o $@ $<
 
 %.o: %.cpp vm/master.hpp.gch
-       $(TOOLCHAIN_PREFIX)$(CPP) -c $(CFLAGS) -o $@ $<
+       $(TOOLCHAIN_PREFIX)$(CXX) -c $(CFLAGS) $(CXXFLAGS) -o $@ $<
 
 %.o: %.S
-       $(TOOLCHAIN_PREFIX)$(CC) -c $(CFLAGS) -o $@ $<
+       $(TOOLCHAIN_PREFIX)$(CC) -c $(CFLAGS) $(CXXFLAGS) -o $@ $<
 
 %.o: %.mm vm/master.hpp.gch
-       $(TOOLCHAIN_PREFIX)$(CPP) -c $(CFLAGS) -o $@ $<
+       $(TOOLCHAIN_PREFIX)$(CXX) -c $(CFLAGS) $(CXXFLAGS) -o $@ $<
 
 .SUFFIXES: .mm
 
@@ -260,3 +284,4 @@ clean:
        rm -f Factor.app/Contents/Frameworks/libfactor.dylib
 
 .PHONY: factor factor-lib factor-console factor-ffi-test tags clean macosx.app
+.PHONY: linux-x86-32 linux-x86-64 linux-ppc-32 linux-ppc-64 linux-arm-64 freebsd-x86-32 freebsd-x86-64 macosx-x86-32 macosx-x86-64 macosx-x86-fat macosx-arm64 windows-x86-32 windows-x86-64