opencv/cmake/templates/OpenCV.mk.in

108 lines
3.4 KiB
Makefile
Raw Normal View History

# In order to compile your application under cygwin
# you might need to define NDK_USE_CYGPATH=1 before calling the ndk-build
2011-06-28 16:48:23 +08:00
USER_LOCAL_PATH:=$(LOCAL_PATH)
USER_LOCAL_C_INCLUDES:=$(LOCAL_C_INCLUDES)
USER_LOCAL_CFLAGS:=$(LOCAL_CFLAGS)
USER_LOCAL_STATIC_LIBRARIES:=$(LOCAL_STATIC_LIBRARIES)
USER_LOCAL_SHARED_LIBRARIES:=$(LOCAL_SHARED_LIBRARIES)
USER_LOCAL_LDLIBS:=$(LOCAL_LDLIBS)
LOCAL_PATH:=$(subst ?,,$(firstword ?$(subst \, ,$(subst /, ,$(call my-dir)))))
2011-06-28 16:48:23 +08:00
OPENCV_TARGET_ARCH_ABI:=$(TARGET_ARCH_ABI)
2011-06-28 16:48:23 +08:00
OPENCV_THIS_DIR:=$(patsubst $(LOCAL_PATH)\\%,%,$(patsubst $(LOCAL_PATH)/%,%,$(call my-dir)))
2012-03-24 01:03:05 +08:00
OPENCV_MK_DIR:=$(dir $(lastword $(MAKEFILE_LIST)))
OPENCV_LIBS_DIR:=@OPENCV_LIBS_DIR_CONFIGCMAKE@
OPENCV_3RDPARTY_LIBS_DIR:=@OPENCV_3RDPARTY_LIBS_DIR_CONFIGCMAKE@
OPENCV_BASEDIR:=@OPENCV_BASE_INCLUDE_DIR_CONFIGCMAKE@
2012-10-17 07:18:30 +08:00
OPENCV_LOCAL_C_INCLUDES:=@OPENCV_INCLUDE_DIRS_CONFIGCMAKE@
OPENCV_MODULES:=@OPENCV_MODULES_CONFIGMAKE@
OPENCV_SUB_MK:=$(call my-dir)/OpenCV-$(TARGET_ARCH_ABI).mk
2012-03-24 01:03:05 +08:00
ifeq ($(OPENCV_LIB_TYPE),)
2012-10-17 07:18:30 +08:00
OPENCV_LIB_TYPE:=@OPENCV_LIBTYPE_CONFIGMAKE@
2012-03-24 01:03:05 +08:00
endif
ifeq ($(OPENCV_LIB_TYPE),SHARED)
2012-10-17 07:18:30 +08:00
OPENCV_LIBS:=@OPENCV_LIBS_CONFIGMAKE@
OPENCV_LIB_TYPE:=@OPENCV_LIBTYPE_CONFIGMAKE@
2012-03-24 01:03:05 +08:00
else
2012-10-17 07:18:30 +08:00
OPENCV_LIBS:=$(OPENCV_MODULES)
OPENCV_LIB_TYPE:=@OPENCV_STATIC_LIBTYPE_CONFIGMAKE@
2012-03-24 01:03:05 +08:00
endif
ifeq ($(OPENCV_LIB_TYPE),SHARED)
2012-10-17 07:18:30 +08:00
OPENCV_3RDPARTY_COMPONENTS:=
OPENCV_EXTRA_COMPONENTS:=
2012-03-24 01:03:05 +08:00
else
include $(OPENCV_SUB_MK)
2012-03-24 01:03:05 +08:00
endif
ifeq ($(OPENCV_LIB_TYPE),SHARED)
2012-10-17 07:18:30 +08:00
OPENCV_LIB_SUFFIX:=so
else
2012-10-17 07:18:30 +08:00
OPENCV_LIB_SUFFIX:=a
OPENCV_INSTALL_MODULES:=on
endif
define add_opencv_module
2012-10-17 07:18:30 +08:00
include $(CLEAR_VARS)
LOCAL_MODULE:=opencv_$1
LOCAL_SRC_FILES:=$(OPENCV_LIBS_DIR)/libopencv_$1.$(OPENCV_LIB_SUFFIX)
include $(PREBUILT_$(OPENCV_LIB_TYPE)_LIBRARY)
endef
define add_opencv_3rdparty_component
2012-10-17 07:18:30 +08:00
include $(CLEAR_VARS)
LOCAL_MODULE:=$1
LOCAL_SRC_FILES:=$(OPENCV_3RDPARTY_LIBS_DIR)/lib$1.a
include $(PREBUILT_STATIC_LIBRARY)
endef
ifeq ($(OPENCV_MK_$(OPENCV_TARGET_ARCH_ABI)_ALREADY_INCLUDED),)
ifeq ($(OPENCV_INSTALL_MODULES),on)
$(foreach module,$(OPENCV_LIBS),$(eval $(call add_opencv_module,$(module))))
endif
$(foreach module,$(OPENCV_3RDPARTY_COMPONENTS),$(eval $(call add_opencv_3rdparty_component,$(module))))
ifneq ($(OPENCV_BASEDIR),)
OPENCV_LOCAL_C_INCLUDES += $(foreach mod, $(OPENCV_MODULES), $(OPENCV_BASEDIR)/modules/$(mod)/include)
endif
#turn off module installation to prevent their redefinition
OPENCV_MK_$(OPENCV_TARGET_ARCH_ABI)_ALREADY_INCLUDED:=on
endif
2012-03-24 01:03:05 +08:00
ifeq ($(OPENCV_LOCAL_CFLAGS),)
2012-10-17 07:18:30 +08:00
OPENCV_LOCAL_CFLAGS := -fPIC -DANDROID -fsigned-char
2011-06-28 16:48:23 +08:00
endif
include $(CLEAR_VARS)
LOCAL_C_INCLUDES:=$(USER_LOCAL_C_INCLUDES)
LOCAL_CFLAGS:=$(USER_LOCAL_CFLAGS)
LOCAL_STATIC_LIBRARIES:=$(USER_LOCAL_STATIC_LIBRARIES)
LOCAL_SHARED_LIBRARIES:=$(USER_LOCAL_SHARED_LIBRARIES)
LOCAL_LDLIBS:=$(USER_LOCAL_LDLIBS)
2012-03-24 01:03:05 +08:00
LOCAL_C_INCLUDES += $(OPENCV_LOCAL_C_INCLUDES)
LOCAL_CFLAGS += $(OPENCV_LOCAL_CFLAGS)
ifeq ($(OPENCV_INSTALL_MODULES),on)
2012-10-17 07:18:30 +08:00
LOCAL_$(OPENCV_LIB_TYPE)_LIBRARIES += $(foreach mod, $(OPENCV_LIBS), opencv_$(mod))
2012-03-24 01:03:05 +08:00
else
2012-10-17 07:18:30 +08:00
LOCAL_LDLIBS += -L$(call host-path,$(LOCAL_PATH)/$(OPENCV_LIBS_DIR)) $(foreach lib, $(OPENCV_LIBS), -lopencv_$(lib))
2012-03-24 01:03:05 +08:00
endif
ifeq ($(OPENCV_LIB_TYPE),STATIC)
2012-10-17 07:18:30 +08:00
LOCAL_STATIC_LIBRARIES += $(OPENCV_3RDPARTY_COMPONENTS)
2012-03-24 01:03:05 +08:00
endif
LOCAL_LDLIBS += $(foreach lib,$(OPENCV_EXTRA_COMPONENTS), -l$(lib))
2011-06-28 16:48:23 +08:00
#restore the LOCAL_PATH
2011-06-28 16:48:23 +08:00
LOCAL_PATH:=$(USER_LOCAL_PATH)