sqlite数据库cmakelist.txt编译

1、下载官方源码

源码地址

wget https://sqlite.org/2026/sqlite-autoconf-3510200.tar.gz

tar -xvf sqlite-autoconf-3510200.tar.gz

cd sqlite-autoconf-3510200

2、创建CMakeLists.txt

gedit CMakeLists.txt

cpp 复制代码
cmake_minimum_required(VERSION 3.10)
project(sqlite3 C)

# ---------------- Options ----------------
option(SQLITE_BUILD_STATIC "Build static sqlite3 library" ON)
option(SQLITE_BUILD_SHARED "Build shared sqlite3 library" ON)

option(SQLITE_ENABLE_FTS5  "Enable FTS5 extension" ON)
option(SQLITE_ENABLE_JSON1 "Enable JSON1 extension" ON)

# ---------------- Source ----------------
set(SQLITE_SRC
    sqlite3.c
)

set(SQLITE_PUBLIC_HEADERS
    sqlite3.h
)

# ---------------- Compile Definitions ----------------
set(SQLITE_DEFINES
    SQLITE_THREADSAFE=1
)

if(SQLITE_ENABLE_FTS5)
    list(APPEND SQLITE_DEFINES SQLITE_ENABLE_FTS5)
endif()

if(SQLITE_ENABLE_JSON1)
    list(APPEND SQLITE_DEFINES SQLITE_ENABLE_JSON1)
endif()

# ---------------- Static Library ----------------
if(SQLITE_BUILD_STATIC)
    add_library(sqlite3_static STATIC ${SQLITE_SRC})
    target_compile_definitions(sqlite3_static PRIVATE ${SQLITE_DEFINES})
    target_include_directories(sqlite3_static PUBLIC ${CMAKE_CURRENT_SOURCE_DIR})
    set_target_properties(sqlite3_static PROPERTIES
        OUTPUT_NAME sqlite3
        POSITION_INDEPENDENT_CODE ON
    )
endif()

# ---------------- Shared Library ----------------
if(SQLITE_BUILD_SHARED)
    add_library(sqlite3_shared SHARED ${SQLITE_SRC})
    target_compile_definitions(sqlite3_shared PRIVATE ${SQLITE_DEFINES})
    target_include_directories(sqlite3_shared PUBLIC ${CMAKE_CURRENT_SOURCE_DIR})
    set_target_properties(sqlite3_shared PROPERTIES
        OUTPUT_NAME sqlite3
        VERSION 3
        SOVERSION 3
    )
endif()

# ---------------- Install ----------------
install(FILES ${SQLITE_PUBLIC_HEADERS}
        DESTINATION include)

if(SQLITE_BUILD_STATIC)
    install(TARGETS sqlite3_static
            ARCHIVE DESTINATION lib)
endif()

if(SQLITE_BUILD_SHARED)
    install(TARGETS sqlite3_shared
            LIBRARY DESTINATION lib
            RUNTIME DESTINATION bin)
endif()

3、创建build.sh

bash 复制代码
#!/bin/bash
set -e

MODE=${1:-linux}
LIBTYPE=${2:-both}     # static | shared | both
BUILD_TYPE=Release
JOBS=$(nproc)

ROOT_DIR=$(pwd)
INSTALL_ROOT=${ROOT_DIR}/install

ANDROID_NDK=${ANDROID_NDK:-$HOME/android-sdk/ndk/26.2.11394342}
ANDROID_ABI=arm64-v8a
ANDROID_API=33

# -------- lib type switch --------
SQLITE_BUILD_STATIC=OFF
SQLITE_BUILD_SHARED=OFF

case ${LIBTYPE} in
    static)
        SQLITE_BUILD_STATIC=ON
        ;;
    shared)
        SQLITE_BUILD_SHARED=ON
        ;;
    both)
        SQLITE_BUILD_STATIC=ON
        SQLITE_BUILD_SHARED=ON
        ;;
    *)
        echo "Invalid lib type: ${LIBTYPE}"
        echo "Usage: $0 [linux|android] [static|shared|both]"
        exit 1
        ;;
esac

build_linux() {
    echo "==== Build sqlite3 for Linux (${LIBTYPE}) ===="

    rm -rf build_linux
    mkdir build_linux
    cd build_linux

    cmake .. \
        -DCMAKE_BUILD_TYPE=${BUILD_TYPE} \
        -DCMAKE_INSTALL_PREFIX=${INSTALL_ROOT}/linux \
        -DSQLITE_BUILD_STATIC=${SQLITE_BUILD_STATIC} \
        -DSQLITE_BUILD_SHARED=${SQLITE_BUILD_SHARED} \
        -DSQLITE_ENABLE_FTS5=ON \
        -DSQLITE_ENABLE_JSON1=ON

    make -j${JOBS}
    make install
}

build_android() {
    echo "==== Build sqlite3 for Android (${LIBTYPE}) ===="

    rm -rf build_android
    mkdir build_android
    cd build_android

    cmake .. \
        -DCMAKE_TOOLCHAIN_FILE=${ANDROID_NDK}/build/cmake/android.toolchain.cmake \
        -DANDROID_ABI=${ANDROID_ABI} \
        -DANDROID_PLATFORM=android-${ANDROID_API} \
        -DCMAKE_BUILD_TYPE=${BUILD_TYPE} \
        -DCMAKE_INSTALL_PREFIX=${INSTALL_ROOT}/android/${ANDROID_ABI} \
        -DSQLITE_BUILD_STATIC=${SQLITE_BUILD_STATIC} \
        -DSQLITE_BUILD_SHARED=${SQLITE_BUILD_SHARED} \
        -DSQLITE_ENABLE_FTS5=ON \
        -DSQLITE_ENABLE_JSON1=ON

    make -j${JOBS}
    make install
}

case ${MODE} in
    linux)
        build_linux
        ;;
    android)
        build_android
        ;;
    *)
        echo "Usage: $0 [linux|android] [static|shared|both]"
        exit 1
        ;;
esac

4、编译动态与静态库

编译linux环境 动态库和静态库

sh ./build_sqlite3.sh linux

编译linux环境 动态库

sh ./build_sqlite3.sh linux shared

编译linux环境 静态库

sh ./build_sqlite3.sh linux static

编译android环境 动态库和静态库

sh ./build_sqlite3.sh android

编译android环境 动态库

sh ./build_sqlite3.sh android shared

编译android环境 静态库

sh ./build_sqlite3.sh android static

相关推荐
JoneBB4 分钟前
ABAP Webservice连接
运维·开发语言·数据库·学习
解决问题no解决代码问题9 分钟前
从乱码到脱敏导出:TiDB CSV 导出实战全指南
数据库
未若君雅裁22 分钟前
MySQL高可用与扩展-主从复制读写分离分库分表
java·数据库·mysql
2401_8676239827 分钟前
CSS Flex布局中如何设置子元素间距_掌握gap属性的现代用法
jvm·数据库·python
月落归舟33 分钟前
一篇文章了解Redis内存淘汰机制与过期Key清理
数据库·redis·mybatis
phltxy1 小时前
Redis 事务
数据库·redis·缓存
康乾隆1 小时前
SQL Server Always On 重新添加从库步骤
数据库·sqlserver
环流_2 小时前
redis核心数据类型在java中的操作
java·数据库·redis
雨辰AI2 小时前
SpringBoot3 项目国产化改造完整流程|从 MySQL 到人大金仓落地
java·数据库·后端·mysql·政务
一个天蝎座 白勺 程序猿2 小时前
存储治理:表空间自动目录创建与国产操作系统生态适配
数据库·kingbasees