]> gitweb.factorcode.org Git - factor.git/blobdiff - GNUmakefile
Support Link Time Optimization (off by default)
[factor.git] / GNUmakefile
index ef5707d054b1736afd9fa633eb3195d52279bcde..577a38b2a9a325660c32ddfc2770da55462ab603 100644 (file)
@@ -1,16 +1,23 @@
 ifdef CONFIG
-       VERSION = 0.99
+       VERSION = 0.100
        GIT_LABEL = $(shell echo `git describe --all`-`git rev-parse HEAD`)
        BUNDLE = Factor.app
        DEBUG ?= 0
        REPRODUCIBLE ?= 0
 
+       SHELL_CC = $(shell printenv CC)
+       ifeq ($(SHELL_CC),)
+               CC := $(shell which clang cc 2>/dev/null | head -n 1)
+       else
+               CC = $(SHELL_CC)
+       endif
+
        # gmake's default CXX is g++, we prefer c++
        SHELL_CXX = $(shell printenv CXX)
        ifeq ($(SHELL_CXX),)
-               CXX=c++
+               CXX := $(shell which clang++ c++ 2>/dev/null | head -n 1)
        else
-               CXX=$(SHELL_CXX)
+               CXX = $(SHELL_CXX)
        endif
 
        XCODE_PATH ?= /Applications/Xcode.app
@@ -38,6 +45,7 @@ ifdef CONFIG
                CFLAGS += -g -DFACTOR_DEBUG
        else
                CFLAGS += -O3
+               CFLAGS += $(CC_OPT)
        endif
 
        ifneq ($(REPRODUCIBLE), 0)
@@ -162,13 +170,14 @@ help:
        @echo "linux-x86-64"
        @echo "linux-ppc-32"
        @echo "linux-ppc-64"
+       @echo "linux-arm-32"
        @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 "macosx-arm-64"
        @echo "windows-x86-32"
        @echo "windows-x86-64"
        @echo ""
@@ -177,6 +186,7 @@ help:
        @echo "DEBUG=1  compile VM with debugging information"
        @echo "REPRODUCIBLE=1  compile VM without timestamp"
        @echo "SITE_CFLAGS=...  additional optimization flags"
+       @echo "LTO=1  compile VM with Link Time Optimization"
        @echo "X11=1  force link with X11 libraries instead of Cocoa (only on Mac OS X)"
 
 ALL = factor factor-ffi-test factor-lib
@@ -196,8 +206,8 @@ 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
+macosx-arm-64:
+       $(MAKE) $(ALL) macosx.app CONFIG=vm/Config.macosx.arm.64
 
 linux-arm-32:
        $(MAKE) $(ALL) CONFIG=vm/Config.linux.arm.32
@@ -252,7 +262,7 @@ $(FFI_TEST_LIBRARY): vm/ffi_test.o
        $(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
+       $(TOOLCHAIN_PREFIX)$(WINDRES) --preprocessor=cat vm/factor.rs vm/resources.o
 
 vm/ffi_test.o: vm/ffi_test.c
        $(TOOLCHAIN_PREFIX)$(CC) -c $(CFLAGS) $(FFI_TEST_CFLAGS) -std=c99 -o $@ $<
@@ -276,6 +286,7 @@ endif
 clean:
        rm -f vm/*.gch
        rm -f vm/*.o
+       rm -f factor
        rm -f factor.dll
        rm -f factor.lib
        rm -f factor.dll.lib