HOST_PLATFORM := win32
WINDOWS_HOST := defined
else
-ifeq "$(OSTYPE)" "FreeBSD"
-# tocheck: temporarily using linux when on bsd
-# HOST_PLATFORM := bsd
-# BSD_HOST := defined
- HOST_PLATFORM := linux
- LINUX_HOST := defined
-else
-ifeq "$(shell uname)" "Darwin"
- HOST_PLATFORM := apple
- OSX_HOST := defined
-else
- HOST_PLATFORM := linux
- LINUX_HOST := defined
-endif
-endif
-
-UNAME_P := $(shell uname -p)
-ifeq ($(UNAME_P),x86_64)
- HOST_ARCH = X64
-else
-ifneq ($(filter %86,$(UNAME_P)),)
- HOST_ARCH = X86
-else
-ifneq ($(filter arm%,$(UNAME_P)),)
- HOST_ARCH = ARM
-endif
-endif
-endif
+ _UNAME := $(shell uname)
+ UNAME_P := $(shell uname -p)
+ ifeq "$(_UNAME)" "FreeBSD"
+ # Using Linux platform for Unix OSes for now
+ # HOST_PLATFORM := bsd
+ BSD_HOST := defined
+ HOST_PLATFORM := linux
+ LINUX_HOST := defined
+ else
+ ifeq "$(_UNAME)" "Darwin"
+ HOST_PLATFORM := apple
+ OSX_HOST := defined
+ else
+ HOST_PLATFORM := linux
+ LINUX_HOST := defined
+ endif
+ endif
+ HOST_ARCH := $(UNAME_P)
endif
# TARGET_PLATFORM
ifdef OSX_HOST
TARGET_PLATFORM := apple
else
-ifdef BSD_HOST
- TARGET_PLATFORM := bsd
-else
+#ifdef BSD_HOST
+# TARGET_PLATFORM := bsd
+#else
TARGET_PLATFORM := linux
+ifdef BSD_HOST
+ BSD_TARGET := defined
endif
+#endif
endif
endif
endif
ifeq "$(TARGET_PLATFORM)" "apple"
OSX_TARGET := defined
else
-ifeq "$(TARGET_PLATFORM)" "bsd"
- BSD_TARGET := defined
-else
+#ifeq "$(TARGET_PLATFORM)" "bsd"
+# BSD_TARGET := defined
+#else
LINUX_TARGET := defined
+#endif
endif
endif
+
+# CROSS_TARGET
+ifneq "$(TARGET_PLATFORM)" "$(HOST_PLATFORM)"
+ CROSS_TARGET := defined
+endif
+
+# TARGET_TYPE
+ifeq "$(TARGET_TYPE)" "staticlib"
+ STATIC_LIBRARY_TARGET := defined
+else
+ifeq "$(TARGET_TYPE)" "sharedlib"
+ SHARED_LIBRARY_TARGET := defined
+else
+ifeq "$(TARGET_TYPE)" "executable"
+ EXECUTABLE_TARGET := defined
+endif
+endif
+endif
+
+ifeq "$(GCC_PREFIX)" "i586-mingw32msvc-"
+export ARCH
+ARCH := x32
+endif
+
+ifeq "$(GCC_PREFIX)" "i686-w64-mingw32-"
+export ARCH
+ARCH := x32
+endif
+
+# Accept different things for ARCH but standardize on x32/x64
+# This will be used for object directories
+ifdef ARCH
+ ifeq "$(ARCH)" "32"
+ override ARCH := x32
+ endif
+ ifeq "$(ARCH)" "x86"
+ override ARCH := x32
+ endif
+ ifeq "$(ARCH)" "i386"
+ override ARCH := x32
+ endif
+ ifeq "$(ARCH)" "i686"
+ override ARCH := x32
+ endif
+ ifeq "$(ARCH)" "64"
+ override ARCH := x64
+ endif
+ ifeq "$(ARCH)" "amd64"
+ override ARCH := x64
+ endif
+ ifeq "$(ARCH)" "x86_64"
+ override ARCH := x64
+ endif
+
+ # Set ARCH_FLAGS only if ARCH is set
+ ifeq "$(ARCH)" "x64"
+ TARGET_ARCH := x86_64
+ ARCH_FLAGS := -m64
+ endif
+ ifeq "$(ARCH)" "x32"
+ TARGET_ARCH := i386
+ ARCH_FLAGS := -m32
+ endif
+
+ ARCH_SUFFIX := .$(ARCH)
+
+ ifdef LINUX_TARGET
+ TARGET_ARCH := $(TARGET_ARCH)-linux-gnu
+ endif
+
endif
# DEBUG SUFFIX
DEBUG_SUFFIX := .debug
endif
+# COMPILER SUFFIX
+COMPILER_SUFFIX = $(ARCH_SUFFIX)
ifdef COMPILER
ifneq "$(COMPILER)" "default"
-COMPILER_SUFFIX := .$(COMPILER)
+COMPILER_SUFFIX = .$(COMPILER)$(ARCH_SUFFIX)
endif
endif
# MISC STRING TOOLS
empty :=
+esc := $(empty)\7f$(empty)
space := $(empty) $(empty)
-escspace = $(subst $(space),\$(space),$(subst \$(space),$(space),$1))
-hidspace = $(subst $(space),\7f,$(subst \$(space),\7f,$1))
-shwspace = $(subst \7f,\$(space),$1)
+comma := ,
+slash := $(empty)/$(empty)
+backslash := $(empty)\$(empty)
+escspace = $(subst $(space),$(backslash)$(space),$(subst $(backslash)$(space),$(space),$(1)))
+hidspace = $(subst $(space),$(esc),$(subst $(backslash)$(space),$(esc),$(1)))
+shwspace = $(subst $(esc),$(backslash)$(space),$(1))
+unescp_all = $(subst $(esc),$(backslash),$(subst $(backslash),,$(subst $(backslash)$(backslash),$(esc),$(1))))
# PATH SEPARATOR STRING TOOLS
ifdef WINDOWS_HOST
endif
endif
ifdef WIN_PS_TOOLS
- fixps = $(subst \,/,$(1))
- psep = $(subst \\,/,$(subst /,\,$(1)))
- PS := $(strip \)
+ psep := $(backslash)
+ slash_path = $(subst $(backslash),$(slash),$(1))
+ sys_path = $(subst $(backslash)$(backslash),$(slash),$(subst $(slash),$(backslash),$(1)))
+ quote_path = "$(call sys_path,$(call unescp_all,$(1)))"
else
- fixps = $(1)
- PS := $(strip /)
- psep = $(1)
+ psep := $(slash)
+ slash_path = $(1)
+ sys_path = $(1)
+ quote_path = $(1)
endif
# PREFIXES AND EXTENSIONS
C := .c
O := .o
A := .a
-ifdef WINDOWS_TARGET
- E := .exe
-ifeq "$(TARGET_TYPE)" "staticlib"
- LP := lib
-else
- LP :=
-endif
- SO := .dll
-else
-ifdef OSX_TARGET
- E :=
- LP := lib
- SO := .dylib
-else
- E :=
- LP := lib
- SO := .so
-endif
-endif
+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)
+
+# VERSIONING
+VER := $(if $(LINUX_TARGET),$(if $(LINUX_HOST),$(if $(VERSION),.$(VERSION),),),)
# SUPER TOOLS
ifdef CCACHE
- CCACHE_COMPILE := ccache
+ CCACHE_COMPILE := ccache$(space)
ifdef DISTCC
- DISTCC_COMPILE := distcc
+ DISTCC_COMPILE := distcc$(space)
endif
else
ifdef DISTCC
- DISTCC_COMPILE := distcc
+ DISTCC_COMPILE := distcc$(space)
endif
endif
+_CPP = $(if $(findstring $(space),$(CPP)),"$(CPP)",$(CPP))
+
+_SYSROOT = $(if $(SYSROOT),$(space)--sysroot=$(SYSROOT),)
+
# SHELL COMMANDS
ifdef WINDOWS_HOST
ifndef MSYSCON
endif
ifdef WIN_SHELL_COMMANDS
echo = $(if $(1),echo $(1))
- cpq = $(if $(1),@cmd /c for %%I in ($(call psep,$(1))) do @copy /y %%I $(call psep,$(2)) > nul 2>&1)
- rmq = $(if $(1),-@del /f /q $(call psep,$(1)) > nul 2>&1)
- rmrq = $(if $(1),-@rmdir /q /s $(call psep,$(1)) > nul 2>&1)
- mkdirq = $(if $(1),-@mkdir $(call psep,$(1)) > nul 2>&1)
- rmdirq = $(if $(1),-@rmdir /q $(call psep,$(1)) > nul 2>&1)
+ touch = $(if $(1),@cmd /c "for %%I in ($(call sys_path,$(1))) do @(cd %%~pI && type nul >> %%~nxI && copy /by %%~nxI+,, > nul 2>&1 && cd %%cd%%)")
+ cpq = $(if $(1),@cmd /c "for %%I in ($(call sys_path,$(1))) do copy /by %%I $(call sys_path,$(2))" > nul 2>&1)
+ rmq = $(if $(1),-del /f /q $(call sys_path,$(1)) > nul 2>&1)
+ rmrq = $(if $(1),-rmdir /q /s $(call sys_path,$(1)) > nul 2>&1)
+ mkdirq = $(if $(1),-mkdir $(call sys_path,$(1)) > nul 2>&1)
+ rmdirq = $(if $(1),-rmdir /q $(call sys_path,$(1)) > nul 2>&1)
else
echo = $(if $(1),echo "$(1)")
- cpq = $(if $(1),@cp $(1) $(2))
- rmq = $(if $(1),-@rm -f $(1))
- rmrq = $(if $(1),-@rm -f -r $(1))
- mkdirq = $(if $(1),-@mkdir -p $(1))
- rmdirq = $(if $(1),-@rmdir $(1))
+ touch = $(if $(1),touch $(1))
+ cpq = $(if $(1),cp $(1) $(2))
+ rmq = $(if $(1),-rm -f $(1))
+ rmrq = $(if $(1),-rm -f -r $(1))
+ mkdirq = $(if $(1),-mkdir -p $(1))
+ rmdirq = $(if $(1),-rmdir $(1))
endif
# COMPILER OPTIONS
-ifeq "$(TARGET_TYPE)" "sharedlib"
- ECSLIBOPT := -dynamiclib
-else
-ifeq "$(TARGET_TYPE)" "staticlib"
- ECSLIBOPT := -staticlib
-else
- ECSLIBOPT :=
-endif
-endif
-ifdef WINDOWS_TARGET
- FVISIBILITY :=
- FPIC :=
-ifeq "$(TARGET_TYPE)" "executable"
- EXECUTABLE := $(CONSOLE)
-else
- EXECUTABLE :=
-endif
-else
- FVISIBILITY := -fvisibility=hidden
- FPIC := -fPIC
- EXECUTABLE :=
-endif
-ifdef OSX
-ifeq "$(TARGET_TYPE)" "sharedlib"
- INSTALLNAME := -install_name $(LP)$(MODULE)$(SO)
-else
- INSTALLNAME :=
-endif
-else
- INSTALLNAME :=
-endif
+ECSLIBOPT := $(if $(STATIC_LIBRARY_TARGET),-staticlib,$(if $(SHARED_LIBRARY_TARGET),-dynamiclib,))
+FVISIBILITY := $(if $(WINDOWS_TARGET),,-fvisibility=hidden)
+FPIC := $(if $(WINDOWS_TARGET),,-fPIC)
+EXECUTABLE := $(if $(WINDOWS_TARGET),$(if $(EXECUTABLE_TARGET),$(CONSOLE),),)
+INSTALLNAME := $(if $(OSX_TARGET),$(if $(STATIC_LIBRARY_TARGET),-install_name $(LP)$(MODULE)$(SO),),)
# LINKER OPTIONS
-ifdef OSX
-ifeq "$(TARGET_TYPE)" "sharedlib"
- SHAREDLIB := -dynamiclib -single_module -multiply_defined suppress
- LINKOPT :=
-else
- SHAREDLIB :=
- LINKOPT :=
-endif
-ifeq "$(TARGET_TYPE)" "sharedlib"
- STRIPOPT := -x
-else
- STRIPOPT := -u -r
-endif
-else
-ifeq "$(TARGET_TYPE)" "sharedlib"
- SHAREDLIB := -shared
-else
- SHAREDLIB :=
-endif
- LINKOPT :=
- STRIPOPT := -x --strip-unneeded --remove-section=.comment --remove-section=.note
-endif
-ifdef WINDOWS_TARGET
- SODESTDIR := obj/$(TARGET_PLATFORM)/bin/
-else
- SODESTDIR := obj/$(TARGET_PLATFORM)/lib/
-endif
+SHAREDLIB := $(if $(SHARED_LIBRARY_TARGET),$(if $(OSX_TARGET),-dynamiclib -single_module -multiply_defined suppress,-shared),)
+LINKOPT :=
+STRIPOPT := $(if $(OSX_TARGET),$(if $(SHARED_LIBRARY_TARGET),-x, -u -r), -x --strip-unneeded --remove-section=.comment --remove-section=.note)
+HOST_SODESTDIR := $(if $(WINDOWS_HOST),obj/$(HOST_PLATFORM)$(COMPILER_SUFFIX)$(DEBUG_SUFFIX)/bin/,obj/$(HOST_PLATFORM)$(COMPILER_SUFFIX)$(DEBUG_SUFFIX)/lib/)
+SODESTDIR := $(if $(WINDOWS_TARGET),obj/$(TARGET_PLATFORM)$(COMPILER_SUFFIX)$(DEBUG_SUFFIX)/bin/,obj/$(TARGET_PLATFORM)$(COMPILER_SUFFIX)$(DEBUG_SUFFIX)/lib/)
+# EXCLUDED_LIBS TOOL
_L = $(if $(filter $(1),$(EXCLUDED_LIBS)),,-l$(1))
# DEBIAN
ifdef DEBIAN_PACKAGE
-OFLAGS += $(LDFLAGS)
+CFLAGS += $(CPPFLAGS)
endif
-# COMMON LIBRARIES DETECTION
+ifdef DEBUG
+CFLAGS += -D_DEBUG
+endif
+# COMMON LIBRARIES DETECTION
ifdef WINDOWS_TARGET
-
-ifdef OPENSSL_CONF
-_OPENSSL_CONF = $(call hidspace,$(call fixps,$(OPENSSL_CONF)))
-OPENSSL_INCLUDE_DIR = $(call shwspace,$(subst /bin/openssl.cfg,/include,$(_OPENSSL_CONF)))
-OPENSSL_LIB_DIR = $(call shwspace,$(subst /bin/openssl.cfg,/lib,$(_OPENSSL_CONF)))
-OPENSSL_BIN_DIR = $(call shwspace,$(subst /bin/openssl.cfg,/bin,$(_OPENSSL_CONF)))
-else
+ ifdef OPENSSL_CONF
+ _OPENSSL_CONF = $(call hidspace,$(call slash_path,$(OPENSSL_CONF)))
+ OPENSSL_INCLUDE_DIR = $(call shwspace,$(subst /bin/openssl.cfg,/include,$(_OPENSSL_CONF)))
+ OPENSSL_LIB_DIR = $(call shwspace,$(subst /bin/openssl.cfg,/lib,$(_OPENSSL_CONF)))
+ OPENSSL_BIN_DIR = $(call shwspace,$(subst /bin/openssl.cfg,/bin,$(_OPENSSL_CONF)))
+ else
# to avoid issues with empty -L/-I
-OPENSSL_INCLUDE_DIR = .
-OPENSSL_LIB_DIR = .
-OPENSSL_BIN_DIR = .
-endif
-
-else
-
-OFLAGS += -L/usr/lib/ec
-
+ OPENSSL_INCLUDE_DIR = .
+ OPENSSL_LIB_DIR = .
+ OPENSSL_BIN_DIR = .
+ endif
endif