зеркало из https://github.com/nextcloud/desktop.git
Merge pull request #3124 from nextcloud/bugfix/cmake-require-sqlite-only-on-unix
CMake: Require sqlite3 only on Unix
This commit is contained in:
Коммит
a74d9ec516
|
@ -52,18 +52,8 @@ if (SQLite3_FIND_VERSION AND _SQLITE3_VERSION)
|
||||||
set(SQLite3_VERSION _SQLITE3_VERSION)
|
set(SQLite3_VERSION _SQLITE3_VERSION)
|
||||||
endif (SQLite3_FIND_VERSION AND _SQLITE3_VERSION)
|
endif (SQLite3_FIND_VERSION AND _SQLITE3_VERSION)
|
||||||
|
|
||||||
if (APPLE OR WIN32)
|
include(FindPackageHandleStandardArgs)
|
||||||
set(USE_OUR_OWN_SQLITE3 TRUE)
|
find_package_handle_standard_args(SQLite3 DEFAULT_MSG SQLITE3_LIBRARIES SQLITE3_INCLUDE_DIRS)
|
||||||
set(SQLITE3_INCLUDE_DIR ${CMAKE_SOURCE_DIR}/src/3rdparty/sqlite3)
|
|
||||||
set(SQLITE3_LIBRARIES "")
|
|
||||||
set(SQLITE3_SOURCE ${SQLITE3_INCLUDE_DIR}/sqlite3.c)
|
|
||||||
MESSAGE(STATUS "Using own sqlite3 from " ${SQLITE3_INCLUDE_DIR})
|
|
||||||
else()
|
|
||||||
include(FindPackageHandleStandardArgs)
|
|
||||||
find_package_handle_standard_args(SQLite3 DEFAULT_MSG SQLITE3_LIBRARIES SQLITE3_INCLUDE_DIRS)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# show the SQLITE3_INCLUDE_DIRS and SQLITE3_LIBRARIES variables only in the advanced view
|
# show the SQLITE3_INCLUDE_DIRS and SQLITE3_LIBRARIES variables only in the advanced view
|
||||||
mark_as_advanced(SQLITE3_INCLUDE_DIRS SQLITE3_LIBRARIES)
|
mark_as_advanced(SQLITE3_INCLUDE_DIRS SQLITE3_LIBRARIES)
|
||||||
|
|
|
@ -19,7 +19,11 @@ include(DefineOptions.cmake)
|
||||||
|
|
||||||
include(DefineInstallationPaths)
|
include(DefineInstallationPaths)
|
||||||
|
|
||||||
find_package(SQLite3 3.8.0 REQUIRED)
|
if (APPLE OR WIN32)
|
||||||
|
set(USE_OUR_OWN_SQLITE3 TRUE)
|
||||||
|
else()
|
||||||
|
find_package(SQLite3 3.8.0 REQUIRED)
|
||||||
|
endif()
|
||||||
|
|
||||||
include(ConfigureChecks.cmake)
|
include(ConfigureChecks.cmake)
|
||||||
include(../common/common.cmake)
|
include(../common/common.cmake)
|
||||||
|
@ -52,10 +56,6 @@ else()
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if (USE_OUR_OWN_SQLITE3)
|
|
||||||
list(APPEND csync_SRCS ${SQLITE3_SOURCE})
|
|
||||||
endif()
|
|
||||||
|
|
||||||
configure_file(csync_version.h.in ${CMAKE_CURRENT_BINARY_DIR}/csync_version.h)
|
configure_file(csync_version.h.in ${CMAKE_CURRENT_BINARY_DIR}/csync_version.h)
|
||||||
|
|
||||||
add_library("${csync_NAME}" SHARED ${common_SOURCES} ${csync_SRCS})
|
add_library("${csync_NAME}" SHARED ${common_SOURCES} ${csync_SRCS})
|
||||||
|
@ -65,12 +65,14 @@ target_include_directories(
|
||||||
PUBLIC ${CMAKE_CURRENT_BINARY_DIR} ${CMAKE_CURRENT_SOURCE_DIR} ${CMAKE_CURRENT_SOURCE_DIR}/std
|
PUBLIC ${CMAKE_CURRENT_BINARY_DIR} ${CMAKE_CURRENT_SOURCE_DIR} ${CMAKE_CURRENT_SOURCE_DIR}/std
|
||||||
)
|
)
|
||||||
|
|
||||||
find_package(SQLite3 3.9.0 REQUIRED)
|
if(USE_OUR_OWN_SQLITE3)
|
||||||
if (USE_OUR_OWN_SQLITE3)
|
message(STATUS "Using own sqlite3 version")
|
||||||
# make sure that the path for the local sqlite3 is before the system one
|
add_library(sqlite3 STATIC "${CMAKE_SOURCE_DIR}/src/3rdparty/sqlite3/sqlite3.c")
|
||||||
target_include_directories("${csync_NAME}" BEFORE PUBLIC ${SQLITE3_INCLUDE_DIR})
|
target_include_directories(sqlite3 PUBLIC "${CMAKE_SOURCE_DIR}/src/3rdparty/sqlite3")
|
||||||
|
target_link_libraries("${csync_NAME}" PUBLIC sqlite3)
|
||||||
else()
|
else()
|
||||||
target_include_directories("${csync_NAME}" PUBLIC ${SQLITE3_INCLUDE_DIR})
|
target_include_directories("${csync_NAME}" PUBLIC ${SQLITE3_INCLUDE_DIR})
|
||||||
|
target_link_libraries("${csync_NAME}" PUBLIC ${SQLITE3_LIBRARIES})
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
|
||||||
|
@ -80,13 +82,13 @@ generate_export_header("${csync_NAME}"
|
||||||
)
|
)
|
||||||
|
|
||||||
target_link_libraries("${csync_NAME}"
|
target_link_libraries("${csync_NAME}"
|
||||||
|
PUBLIC
|
||||||
${CSYNC_REQUIRED_LIBRARIES}
|
${CSYNC_REQUIRED_LIBRARIES}
|
||||||
${SQLITE3_LIBRARIES}
|
|
||||||
Qt5::Core Qt5::Concurrent
|
Qt5::Core Qt5::Concurrent
|
||||||
)
|
)
|
||||||
|
|
||||||
if(ZLIB_FOUND)
|
if(ZLIB_FOUND)
|
||||||
target_link_libraries("${csync_NAME}" ZLIB::ZLIB)
|
target_link_libraries("${csync_NAME}" PUBLIC ZLIB::ZLIB)
|
||||||
endif(ZLIB_FOUND)
|
endif(ZLIB_FOUND)
|
||||||
|
|
||||||
|
|
||||||
|
@ -94,7 +96,7 @@ endif(ZLIB_FOUND)
|
||||||
if (APPLE)
|
if (APPLE)
|
||||||
find_library(FOUNDATION_LIBRARY NAMES Foundation)
|
find_library(FOUNDATION_LIBRARY NAMES Foundation)
|
||||||
find_library(CORESERVICES_LIBRARY NAMES CoreServices)
|
find_library(CORESERVICES_LIBRARY NAMES CoreServices)
|
||||||
target_link_libraries("${csync_NAME}" ${FOUNDATION_LIBRARY} ${CORESERVICES_LIBRARY})
|
target_link_libraries("${csync_NAME}" PUBLIC ${FOUNDATION_LIBRARY} ${CORESERVICES_LIBRARY})
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
set_target_properties(
|
set_target_properties(
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
include(DefinePlatformDefaults)
|
include(DefinePlatformDefaults)
|
||||||
find_package(SQLite3 3.8.0 REQUIRED)
|
|
||||||
|
|
||||||
include(nextcloud_add_test.cmake)
|
include(nextcloud_add_test.cmake)
|
||||||
|
|
||||||
|
|
Загрузка…
Ссылка в новой задаче