X-Git-Url: http://ecere.com/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=default.cf;h=8c9aa81d1e44bbcc522aa02e2759faa3463d9c50;hb=3a522310042b2e74f8704794c07d04c5d39952e1;hp=728f1b9d3509538d230d4deafe0371e16f007872;hpb=d87d323355cf9375a828d003081bdd5944332567;p=sdk diff --git a/default.cf b/default.cf index 728f1b9..8c9aa81 100644 --- a/default.cf +++ b/default.cf @@ -1,26 +1,76 @@ -EC_BINS := $(_CF_DIR)$(if $(USE_BOOTSTRAP),compiler/bootstrap/obj/bin.$(HOST_PLATFORM)$(COMPILER_SUFFIX)$(DEBUG)/,obj/$(HOST_PLATFORM)$(COMPILER_SUFFIX)$(DEBUG)/bin/) +EC_BINS := $(_CF_DIR)$(if $(USE_BOOTSTRAP),compiler/bootstrap/obj/bin.$(HOST_PLATFORM)$(COMPILER_SUFFIX)$(DEBUG_SUFFIX)/,obj/$(HOST_PLATFORM)$(COMPILER_SUFFIX)$(DEBUG_SUFFIX)/bin/) + +ifdef WINDOWS_HOST + # Auto-Select MinGW-w64 when asking for 64 bit + ifeq ($(ARCH),x64) + GCC_PREFIX=x86_64-w64-mingw32- + endif +endif + +# PREFIXES AND EXTENSIONS +EC := .ec +S := .sym +I := .imp +B := .bowl +C := .c +ifndef O +O := .o +endif +A := .a +E := $(if $(WINDOWS_TARGET),.exe,) +SO := $(if $(WINDOWS_TARGET),.dll,$(if $(OSX_TARGET),.dylib,.so)) +LP := $(if $(WINDOWS_TARGET),$(if $(STATIC_LIBRARY_TARGET),lib,),lib) +HOST_E := $(if $(WINDOWS_HOST),.exe,) +HOST_SO := $(if $(WINDOWS_HOST),.dll,$(if $(OSX_HOST),.dylib,.so)) +HOST_LP := $(if $(WINDOWS_HOST),$(if $(STATIC_LIBRARY_TARGET),lib,),lib) +.SUFFIXES: .c .ec .sym .imp .bowl $(O) $(A) # TOOLCHAIN -export CC = $(CCACHE_COMPILE)$(DISTCC_COMPILE)$(GCC_PREFIX)gcc$(_SYSROOT) +ifdef TRAVIS +export CPP = $(CC) +else +export CC = $(CCACHE_COMPILE)$(DISTCC_COMPILE)$(GCC_PREFIX)gcc$(_SYSROOT)$(if $(GCC_CC_FLAGS),$(space)$(GCC_CC_FLAGS),) export CPP = $(CCACHE_COMPILE)$(DISTCC_COMPILE)$(GCC_PREFIX)gcc$(_SYSROOT) +endif export AS = $(GCC_PREFIX)as export LD = $(GCC_PREFIX)ld export AR = $(GCC_PREFIX)ar export STRIP = $(GCC_PREFIX)strip -export ECP := $(call psep,$(EC_BINS)ecp$(HOST_E)) -export ECC := $(call psep,$(EC_BINS)ecc$(HOST_E))$(if $(CROSS_TARGET), -t $(TARGET_PLATFORM),) -export ECS := $(call psep,$(EC_BINS)ecs$(HOST_E))$(if $(CROSS_TARGET), -t $(TARGET_PLATFORM),) -export EAR := $(call psep,$(_CF_DIR)obj/$(HOST_PLATFORM)$(COMPILER_SUFFIX)$(DEBUG_SUFFIX)/bin/ear$(HOST_E)) +export ECP := $(call sys_path,$(EC_BINS)ecp$(HOST_E))$(if $(GCC_FLAGS),$(space)$(GCC_FLAGS),) +export ECC := $(call sys_path,$(EC_BINS)ecc$(HOST_E))$(if $(CROSS_TARGET), -t $(TARGET_PLATFORM),)$(if $(GCC_FLAGS),$(space)$(GCC_FLAGS),) +export ECS := $(call sys_path,$(EC_BINS)ecs$(HOST_E))$(if $(CROSS_TARGET), -t $(TARGET_PLATFORM),)$(if $(OUTPUT_POT), -outputpot,)$(if $(DISABLED_POOLING), -disabled-pooling,) +export EAR := $(call sys_path,$(_CF_DIR)obj/$(HOST_PLATFORM)$(COMPILER_SUFFIX)$(DEBUG_SUFFIX)/bin/ear$(HOST_E)) +ifdef WINDOWS_TARGET +WINDRES := $(GCC_PREFIX)windres + ifdef ARCH + ifeq ($(ARCH),x32) +WINDRES_FLAGS := -F pe-i386 + else + ifeq ($(ARCH),x64) +WINDRES_FLAGS := -F pe-x86-64 + endif + endif + endif +endif UPX := upx ifndef ARCH TARGET_ARCH :=$(shell $(CC) -dumpmachine) - ifdef WINDOWS_HOST + ifdef WINDOWS_TARGET ifneq ($(filter x86_64%,$(TARGET_ARCH)),) TARGET_ARCH := x86_64 else TARGET_ARCH := i386 endif + else + ifdef LINUX_TARGET + ifneq ($(filter x86_64-pc-linux-gnu,$(TARGET_ARCH)),) # Fix for PREFIXLIBDIR / DEB_HOST_MULTIARCH with Clang on Debian + TARGET_ARCH := x86_64-linux-gnu + endif + ifneq ($(filter i586-linux-gnu,$(TARGET_ARCH)),) + TARGET_ARCH := i386-linux-gnu + endif + endif endif endif @@ -59,3 +109,11 @@ endif CFLAGS += -fmessage-length=0 EARFLAGS = q + +ifdef DISABLE_GL +CFLAGS += -DECERE_NOGL +endif + +ifndef ENABLE_SSL +CFLAGS += -DECERE_NOSSL +endif