From 7b9f8a48fdb29133fb63dc97acf69d0be6e12d0e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?H=C3=A5vard=20Pettersson?= Date: Wed, 2 Sep 2015 22:34:10 +0200 Subject: [PATCH] Improve CMake find modules. This adds the possibility for Tox modules like AV to be optional. --- CMakeLists.txt | 18 ++++++++++++------ cmake/FindTox.cmake | 31 ++++++++++++++++++++++++++----- cmake/FindWeeChat.cmake | 4 ++-- 3 files changed, 40 insertions(+), 13 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index db14efb..306b47f 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -22,8 +22,11 @@ cmake_minimum_required(VERSION 2.8.7) project(tox-weechat C) set(CMAKE_MODULE_PATH ${CMAKE_SOURCE_DIR}/cmake ${CMAKE_MODULE_PATH}) -find_package(WeeChat) -find_package(Tox) + +find_package(WeeChat REQUIRED) +find_package(Tox REQUIRED + COMPONENTS CORE + OPTIONAL_COMPONENTS AV) set(PLUGIN_PATH "lib/weechat/plugins" CACHE PATH "Path to install the plugin binary to.") @@ -48,11 +51,14 @@ add_library(tox MODULE set(CMAKE_C_FLAGS_DEBUG "-DTWC_DEBUG") set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -std=gnu99 -Wall -Wextra -Wno-unused-parameter") -include_directories(${TOX_INCLUDE_DIR}) -include_directories(${WEECHAT_INCLUDE_DIR}) +include_directories(${Tox_INCLUDE_DIRS}) +include_directories(${WeeChat_INCLUDE_DIRS}) -target_link_libraries(tox ${TOX_LIBRARY}) -target_link_libraries(tox ${TOXAV_LIBRARY}) +target_link_libraries(tox ${Tox_LIBRARIES}) + +if(Tox_AV_FOUND) + add_definitions(-DTOXAV_ENABLED) +endif() # remove lib prefix (libtox.so -> tox.so) set_target_properties(tox PROPERTIES PREFIX "") diff --git a/cmake/FindTox.cmake b/cmake/FindTox.cmake index aead5b5..d040792 100644 --- a/cmake/FindTox.cmake +++ b/cmake/FindTox.cmake @@ -1,8 +1,29 @@ -find_path(TOX_INCLUDE_DIR tox/tox.h) -find_path(TOXAV_INCLUDE_DIR tox/toxav.h) +find_path(Tox_CORE_INCLUDE_DIR tox/tox.h) +find_library(Tox_CORE_LIBRARY toxcore) -find_library(TOX_LIBRARY toxcore) -find_library(TOXAV_LIBRARY toxav) +if(Tox_CORE_INCLUDE_DIR AND Tox_CORE_LIBRARY) + set(Tox_CORE_FOUND TRUE) +endif() + +find_path(Tox_AV_INCLUDE_DIR tox/toxav.h) +find_library(Tox_AV_LIBRARY toxav) + +if(Tox_AV_INCLUDE_DIR AND Tox_AV_LIBRARY) + set(Tox_AV_FOUND TRUE) +endif() + +set(Tox_INCLUDE_DIRS) +set(Tox_LIBRARIES) + +if(Tox_CORE_FOUND) + list(APPEND Tox_INCLUDE_DIRS ${Tox_CORE_INCLUDE_DIR}) + list(APPEND Tox_LIBRARIES ${Tox_CORE_LIBRARY}) +endif() + +if(Tox_AV_FOUND) + list(APPEND Tox_INCLUDE_DIRS ${Tox_AV_INCLUDE_DIR}) + list(APPEND Tox_LIBRARIES ${Tox_AV_LIBRARY}) +endif() include(FindPackageHandleStandardArgs) -find_package_handle_standard_args(Tox DEFAULT_MSG TOX_INCLUDE_DIR TOXAV_INCLUDE_DIR TOX_LIBRARY TOXAV_LIBRARY) +find_package_handle_standard_args(Tox HANDLE_COMPONENTS REQUIRED_VARS Tox_INCLUDE_DIRS Tox_LIBRARIES) diff --git a/cmake/FindWeeChat.cmake b/cmake/FindWeeChat.cmake index a4a644c..f785d72 100644 --- a/cmake/FindWeeChat.cmake +++ b/cmake/FindWeeChat.cmake @@ -1,4 +1,4 @@ -find_path(WEECHAT_INCLUDE_DIR weechat/weechat-plugin.h) +find_path(WeeChat_INCLUDE_DIRS weechat/weechat-plugin.h) include(FindPackageHandleStandardArgs) -find_package_handle_standard_args(WeeChat DEFAULT_MSG WEECHAT_INCLUDE_DIR) +find_package_handle_standard_args(WeeChat REQUIRED_VARS WeeChat_INCLUDE_DIRS)