CMAKE编译时如何自动下载第三方库并解压、安装到指定目录
- GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源。
导语
在日常开发过程中难免会使用到第三方库或者需要将部分库分离另外存储,如果将库与代码放在一起难免会造成工程庞大,此时就可以采用将库与源码分离的方式,在编译时根据情况来判断是否需要下载。
步骤
下面来解析下具体操作步骤,以下以 oracle oci 库下载为例。
UNSET命令初始化本次编译用到的参数变量
#初始化oci库压缩包路径参数LOCAL_OCI_LIB_ZIP
UNSET(LOCAL_OCI_LIB_ZIP CACHE)
#初始化oci库解压路径参数LOCAL_OCI_LIB_DIR
UNSET(LOCAL_OCI_LIB_DIR CACHE)
#初始化oci库压缩包下载路径参数LOCAL_OCI_LIB_ZIP_DL_DIR
UNSET(LOCAL_OCI_LIB_ZIP_DL_DIR CACHE)
SET命令设置参数初始路径或名称
#设置oci库存放文件夹名称
SET(OCI_LIB_NAME "oci_x86_lib")
# 设置oci库压缩包解压文件夹名称
SET(OCI_LIB_UNZIP_DIR_NAME ${OCI_LIB_NAME})
#设置oci库头文件存放文件夹名称
SET(LOCAL_OCI_INCLUDE_DIR_NAME "oci_include")
#设置oci库压缩包名称
SET(OCI_LIB_ZIP_NAME "oci_lib.tar.gz")
#设置oci库远程下载地址URL
SET(OCI_LIB_DOWNLOAD_URL "http://xxxxxx/oci_lib.tar.gz")
#设置oci库远程下载超时时间
SET(DOWNLOAD_OCI_LIB_TIMEOUT 600 CACHE STRING "Timeout in seconds when downloading oci_lib.")
FIND_FILE命令在路径下查找对应名称文件或文件夹是否存在,判断库是否已经下载或解压
#判断压缩包在文件夹ora_oci_lib下是否已经存在
FIND_FILE(LOCAL_OCI_LIB_ZIP
NAMES ${OCI_LIB_ZIP_NAME}
PATHS "ora_oci_lib"
NO_DEFAULT_PATH
)
#判断压缩包在文件夹ora_oci_lib下是否已经解压
FIND_FILE(LOCAL_OCI_LIB_DIR
NAMES ${OCI_LIB_NAME}
PATHS "ora_oci_lib"
NO_DEFAULT_PATH
)
#判断压缩包下载路径
FIND_FILE(LOCAL_OCI_LIB_ZIP_DL_DIR
NAMES ""
PATHS "ora_oci_lib"
NO_DEFAULT_PATH
)
MESSAGE命令输出相应步骤的提示信息
#输出当前正进行的操作步骤信息
MESSAGE(STATUS "Checking dblink ${OCI_LIB_UNZIP_DIR_NAME} + ${LOCAL_OCI_LIB_ZIP} .....")
判断当前压缩包是否存在,如果不存在则开始根据设定的URL地址进行下载
#判断压缩包是否已经存在
IF(NOT LOCAL_OCI_LIB_ZIP)
#不存在则进行下载操作,输出操作提示信息
MESSAGE(STATUS "Downloading ${OCI_LIB_ZIP_NAME} to ${LOCAL_OCI_LIB_ZIP_DL_DIR}")
#从设定URL地址下载相应的压缩包
FILE(DOWNLOAD ${OCI_LIB_DOWNLOAD_URL}
${LOCAL_OCI_LIB_ZIP_DL_DIR}/${OCI_LIB_ZIP_NAME}
TIMEOUT ${DOWNLOAD_OCI_LIB_TIMEOUT}
STATUS ERR
SHOW_PROGRESS
)
#判断下载是否存在错误
IF(ERR EQUAL 0)
#如果下载无错误则设置压缩包名称标记下载成功
SET(LOCAL_OCI_LIB_ZIP "${LOCAL_OCI_LIB_ZIP_DL_DIR}/${OCI_LIB_ZIP_NAME}")
ELSE()
#下载错误输出相关的提示信息
MESSAGE(STATUS "Download failed, error: ${ERR}")
MESSAGE(FATAL_ERROR
"You can try downloading ${OCI_LIB_DOWNLOAD_URL} manually"
" using curl/wget or a similar tool"
)
ENDIF()
ENDIF()
根据设定标记判断是否下载成功,如果下载成功则对压缩包文件进行初步的校验,无问题则进行解压缩操作
IF(LOCAL_OCI_LIB_ZIP )
#输出相应的提示信息校验解压路径等
MESSAGE(STATUS "Checking dblink ${OCI_LIB_UNZIP_DIR_NAME} + ${LOCAL_OCI_INCLUDE_DIR_NAME} + ${LOCAL_OTL_INCLUDE_DIR_NAME} ")
IF(NOT EXISTS "${LOCAL_OCI_LIB_ZIP_DL_DIR}/${OCI_LIB_UNZIP_DIR_NAME}" OR NOT EXISTS "${LOCAL_OCI_LIB_ZIP_DL_DIR}/${LOCAL_OCI_INCLUDE_DIR_NAME}" OR NOT EXISTS "${LOCAL_OCI_LIB_ZIP_DL_DIR}/${LOCAL_OTL_INCLUDE_DIR_NAME}" )
#输出提示信息准备进行解压缩
MESSAGE(STATUS "cd ${LOCAL_OCI_LIB_ZIP_DL_DIR}; tar xfz ${LOCAL_OCI_LIB_ZIP}")
#获取已下载的压缩包大小做基本的判断
GET_FILE_SIZE(${LOCAL_OCI_LIB_ZIP} LOCAL_ZIP_SIZE)
#如果压缩包大小为0则输出对应的错误信息
IF(LOCAL_ZIP_SIZE EQUAL 0)
#移除损坏压缩包,重置相应的参数
FILE(REMOVE ${LOCAL_OCI_LIB_ZIP})
UNSET(LOCAL_OCI_LIB_ZIP)
UNSET(LOCAL_OCI_LIB_ZIP CACHE)
MESSAGE(FATAL_ERROR "${OCI_LIB_ZIP_NAME} is zero length. Deleting it.")
ELSE()
#下载文件基本无问题,进入解压路径开始解压压缩包
EXECUTE_PROCESS(
COMMAND ${CMAKE_COMMAND} -E tar xfz "${LOCAL_OCI_LIB_ZIP}"
WORKING_DIRECTORY "${LOCAL_OCI_LIB_ZIP_DL_DIR}"
RESULT_VARIABLE tar_result
)
#判断解压是否成功
IF (tar_result MATCHES 0)
#解压成功设置成功标记参数
SET(OCI_LIB_FOUND 1 CACHE INTERNAL "")
ELSE()
#解压失败输出相应错误提示信息
MESSAGE(STATUS "Failed to extract files.\n"
" Please try downloading and extracting yourself.\n"
" The url is: ${OCI_LIB_DOWNLOAD_URL}")
ENDIF()
ENDIF()
ENDIF()
ENDIF()
至此第三方库已经下载解压完成,后续可以根据自己源码,设置对应的链接路径进行编译
INCLUDE_DIRECTORIES 命令可以设置引用头文件包括路径
LINK_DIRECTORIES 命令可以设置引用第三方库文件所在路径
编译完成后可以使用INSTALL命令将后续应用运行时需要使用的库,拷贝到指定的安装目录
CMAKE_INSTALL_PREFIX 为设置的安装路径
OCI_LIB_NAME为库放置文件夹
# copy lib
INSTALL(
FILES ${allCopyFiles} DESTINATION ${CMAKE_INSTALL_PREFIX}/${OCI_LIB_NAME}
)
Enjoy GreatSQL
文章推荐:
面向金融级应用的GreatSQL正式开源
https://mp.weixin.qq.com/s/cI_wPKQJuXItVWpOx_yNTg
Changes in GreatSQL 8.0.25 (2021-8-18)
https://mp.weixin.qq.com/s/qcn0lmsMoLtaGO9hbpnhVg
MGR及GreatSQL资源汇总
https://mp.weixin.qq.com/s/qXMct_pOVN5FGoLsXSD0MA
GreatSQL MGR FAQ
https://mp.weixin.qq.com/s/J6wkUpGXw3YkyEUJXiZ9xA
在Linux下源码编译安装GreatSQL/MySQL
https://mp.weixin.qq.com/s/WZZOWKqSaGSy-mpD2GdNcA
关于 GreatSQL
GreatSQL是由万里数据库维护的MySQL分支,专注于提升MGR可靠性及性能,支持InnoDB并行查询特性,是适用于金融级应用的MySQL分支版本。
Gitee:
https://gitee.com/GreatSQL/GreatSQL
GitHub:
https://github.com/GreatSQL/GreatSQL
Bilibili:
https://space.bilibili.com/1363850082/video
微信&QQ群:
可搜索添加GreatSQL社区助手微信好友,发送验证信息“加群”加入GreatSQL/MGR交流微信群
QQ群:533341697
微信小助手:wanlidbc
本文由博客一文多发平台 OpenWrite 发布!
CMAKE编译时如何自动下载第三方库并解压、安装到指定目录的更多相关文章
- 【.Net Core】编译时禁止自动生成netcoreapp文件夹
原文:[.Net Core]编译时禁止自动生成netcoreapp文件夹 每次在编译生成文件时,VS都会自动在<OutputPath>属性指定的路劲后再追加一个用NetCore命名的文件夹 ...
- PyCharm里面执行代码没问题,Jenkins执行时找不到第三方库
在PyCharm里面代码执行没问题 本地cmd执行也没问题 Jenkins执行时报错 原因是第三方库是用PyCharm安装的,后来在Jenkins服务器上用pip装好第三方库后,就可以执行了 再执行 ...
- Linux(CentOS-7) 下载 解压 安装 redis 操作的一些基本命令
使用xshell 连接到虚拟机,并且创建 一个redis目录:创建文件命令:mkdir 文件名ls:查看当前文件里面的所有文件 使用xftp 将下载的linux版本 reids上传动新建的redis目 ...
- wget下载与tar压缩/解压
目录 wget命令 下载整个网站 压缩与解压 小节 wget命令 Usage: wget [OPTION]... [URL]... # 后台运行 -b, --background go to back ...
- VS编译时使用/去除NuGet管理库
原文链接:VS编译时自动下载NuGet管理的库 之前一直使用NuGet来管理一些第三方的库,但是每次check in代码时候为了保证编译通过,都需要把对应的packages check in. 比较耗 ...
- 用CMake设置Visual Studio工程中第三方库
较大的工程文件中一般会调用动态库或者静态库,如果这些库文件是当前工程包含的项目,CMake会自动识别并添加Debug和Release编译时需要的库文件路径和文件名,可以使用命令: Target_Lin ...
- 解决办法:CMake编译时出现“error in configuration process project files may be invalid”
无论是CMake2.84 还是当前最新的CMake2.87都可能会出现这种错: 查遍国内外的网上都没有给出可行办法,结果还是自己解决了 现把出错原因和解决办法如下:出错原因:因是英文版本,通常安装没有 ...
- AndroidStudio2.2.x以上使用cMake编译调用底层c生成依赖库
最近使用AndroidStudio的最新ndk编译方式cMake来编译底层cpp文件,由于之前没有接触过cMake语法,先附上官方学习文档地址:https://developer.android.co ...
- Python标准库与第三方库详解(转载)
转载地址: http://www.codeweblog.com/python%e6%a0%87%e5%87%86%e5%ba%93%e4%b8%8e%e7%ac%ac%e4%b8%89%e6%96%b ...
随机推荐
- springSecurity + jwt + redis 前后端分离用户认证和授权
记录一下使用springSecurity搭建用户认证和授权的代码... 技术栈使用springSecurity + redis + JWT + mybatisPlus 部分代码来自:https://b ...
- 20212115 实验二 《python程序设计》实验报告
实验二 计算器设计 #20212115 2021-2022-2 <python程序设计> 实验报告二 课程: 课程:<Python程序设计>班级: 2121姓名: 朱时鸿学号: ...
- 关于『Markdown』:第二弹
关于『Markdown』:第二弹 建议缩放90%食用 道家有云:一生二,二生三,三生万物 为什么我的帖子不是这样 各位打工人们! 自从我学了Markdown以来 发现 Markdown 语法真的要比 ...
- java基础题(3)
5.面向对象 5.1封装 5.1.1修改Data类的定义 描述 现有一个Data类,内部定义了属性x和y,在main方法中实例化了Data类,并计算了data对象中x和y的和.但是,Data类的定义存 ...
- C++调用C#的动态库dll
以往我们经常是需要使用C#来调用C++的dll,这通过PInvoke就能实现.现在在实际的项目过程中,有时会遇到在C++的项目中调用某个C#的dll来完成特定的某个功能,我们都知道,Native C+ ...
- Jmeter接口参数化<自动化>(csv文件)管理测试用例以及断言
1.创建相关线程组(不解释) 2.创建相应的请求(在请求中设置变量) 下面截图中①②③④⑤⑥⑦皆可以设置为变量 3.新建CSV文件 将请求中设置的变量为明确了解每个字段的含义(皆可以将变量填写到列表的 ...
- camunda流程引擎概念术语
前言 本文重点介绍开源流程引擎camunda的核心概念,这些概念同样适用于JBMP.Activiti.Flowable流程引擎,了解这些基本概念和原理,使用流程引擎API将更得心应手. 一.Proce ...
- C++ 炼气期之变量的生命周期和作用域
1. 前言 什么是变量的生命周期? 从变量被分配空间到空间被收回的这一个时间段,称为变量的生命周期. 什么是变量的作用域? 在变量的生命周期内,其存储的数据并不是在任何地方都能使用,变量能使用的范围, ...
- LVGL库入门教程04-样式
LVGL样式 LVGL样式概述 创建样式 在 LVGL 中,样式都是以对象的方式存在,一个对象可以描述一种样式.每个控件都可以独立添加样式,创建的样式之间互不影响. 可以使用 lv_style_t 类 ...
- 一文详解JackSon配置信息
背景 1.1 问题 Spring Boot 在处理对象的序列化和反序列化时,默认使用框架自带的JackSon配置.使用框架默认的,通常会面临如下问题: Date返回日期格式(建议不使用Date,但老项 ...