-
Notifications
You must be signed in to change notification settings - Fork 520
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Fix linking with system library (libsqlite3)
Add FindSQLite3 from CMake v3.14 in cmake subdir custom CMake modules like FindSQLiteCpp Add this cmake subdir to CMAKE_MODULE_PATH Add a Travis CI build configuration using the libsqlite3-dev packagee from the Linux/Ubuntu distribution
- Loading branch information
Showing
3 changed files
with
91 additions
and
21 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,66 @@ | ||
# Distributed under the OSI-approved BSD 3-Clause License. See accompanying | ||
# file Copyright.txt or https://cmake.org/licensing for details. | ||
|
||
#[=======================================================================[.rst: | ||
FindSQLite3 | ||
----------- | ||
Find the SQLite libraries, v3 | ||
IMPORTED targets | ||
^^^^^^^^^^^^^^^^ | ||
This module defines the following :prop_tgt:`IMPORTED` target: | ||
``SQLite::SQLite3`` | ||
Result variables | ||
^^^^^^^^^^^^^^^^ | ||
This module will set the following variables if found: | ||
``SQLite3_INCLUDE_DIRS`` | ||
where to find sqlite3.h, etc. | ||
``SQLite3_LIBRARIES`` | ||
the libraries to link against to use SQLite3. | ||
``SQLite3_VERSION`` | ||
version of the SQLite3 library found | ||
``SQLite3_FOUND`` | ||
TRUE if found | ||
#]=======================================================================] | ||
|
||
# Look for the necessary header | ||
find_path(SQLite3_INCLUDE_DIR NAMES sqlite3.h) | ||
mark_as_advanced(SQLite3_INCLUDE_DIR) | ||
|
||
# Look for the necessary library | ||
find_library(SQLite3_LIBRARY NAMES sqlite3 sqlite) | ||
mark_as_advanced(SQLite3_LIBRARY) | ||
|
||
# Extract version information from the header file | ||
if(SQLite3_INCLUDE_DIR) | ||
file(STRINGS ${SQLite3_INCLUDE_DIR}/sqlite3.h _ver_line | ||
REGEX "^#define SQLITE_VERSION *\"[0-9]+\\.[0-9]+\\.[0-9]+\"" | ||
LIMIT_COUNT 1) | ||
string(REGEX MATCH "[0-9]+\\.[0-9]+\\.[0-9]+" | ||
SQLite3_VERSION "${_ver_line}") | ||
unset(_ver_line) | ||
endif() | ||
|
||
include(${CMAKE_ROOT}/Modules/FindPackageHandleStandardArgs.cmake) | ||
find_package_handle_standard_args(SQLite3 | ||
REQUIRED_VARS SQLite3_INCLUDE_DIR SQLite3_LIBRARY | ||
VERSION_VAR SQLite3_VERSION) | ||
|
||
# Create the imported target | ||
if(SQLite3_FOUND) | ||
set(SQLite3_INCLUDE_DIRS ${SQLite3_INCLUDE_DIR}) | ||
set(SQLite3_LIBRARIES ${SQLite3_LIBRARY}) | ||
if(NOT TARGET SQLite::SQLite3) | ||
add_library(SQLite::SQLite3 UNKNOWN IMPORTED) | ||
set_target_properties(SQLite::SQLite3 PROPERTIES | ||
IMPORTED_LOCATION "${SQLite3_LIBRARY}" | ||
INTERFACE_INCLUDE_DIRECTORIES "${SQLite3_INCLUDE_DIR}") | ||
endif() | ||
endif() |