简介
cmake构建方式是开源三方库的主流构建方式。DevEco Studio目前以支持cmake的构建方式。本文将通过在IDE上适配cJSON三方库为例讲来解如何在IDE上集成cmake构建方式得三方库。
创建工程
在开发进行三方库适配以及napi接口开发前,我们需要创建一个三方库对应的工程,具体创建工程方法可以参照文档通过IDE开发一个Napi工程。
IDE上适配三方库
原生库准备
下载代码
通过cJSON github网址,通过Code>>Download ZIP选项下载最新版本的源码包,并将其解压后放在IDE工程中的CPP目录下。
- 下载cJSON v1.7.17版本的库:
- 将库放在IDE工程:
加入编译构建
原生库源码准备完后,我们需要将库加入到工程的编译构建中。在工程目录CPP下的CMakeLists.txt文件中,通过add_subdirectory将cJSON加入到编译中,并通过target_link_libraries添加对cjson的链接,如下图:
到此,我们的三方库适配已经完成,可以通过IDE上的Run entry
按钮进行编译及运行了。
非cmake构建方式的三方库
TinyxPath三方库移植
原生库的准备
原生库下载
本文中是用tinyxpath 1.3.1版本,可以通过以下方式进行下载:
wget https://sourceforge.net/projects/tinyxpath/files/TinyXPath%20%28Linux%20-%20tar.gz%29/TinyXPath%201.3.1/tinyxpath_1_3_1.tgz
下载完后进行解压:
tar -zxvf tinyxpath_1_3_1.tgz -C tinyxpath1.3.1 # 将tinyxpath_1_3_1.tgz解压到tinyxpath1.3.1, tinyxpath1.3.1文件夹必须存在
源码分析
- 依赖分析 tinyxpath是configure构建方式,根据官网提示生成对应configure命令并执行configure:
make -f Makefile.configure ./configure
通过configure的输出日志可以分析出,tinyxpath库不依赖其他任何三方库。
- 源文件分析
- 生成库和测试用例的源文件分析 我们通过分析Makefile,查找对应目标依赖的原文件如,tinyxpath库的Makefile文件中的目标源文件定义
从以上内容可以看出,编译此库目标依赖的上面的所有.cpp文件。tinyxpath库比较特殊,在linux下面没有生成库文件,生成了一个可执行文件,通过tinyxpath官网介绍可知道,main.cpp
和htmlutil.cpp
是用于生成测试用例,其他文件是用来生成库文件。
除了分析Makefile文件,我们也可以通过分析make过程的输出信息来分析.
通过以上分析可以得出,tinyxpath库目标依赖的源文件是:
action_store.cpp lex_util.cpp node_set.cpp tinyxml.cpp tinyxmlparser.cpp xml_util.cpp xpath_processor.cpp xpath_static.cpp xpath_syntax.cpp tinystr.cpp tinyxmlerror.cpp tokenlist.cpp xpath_expression.cpp xpath_stack.cpp xpath_stream.cpp
测试用例依赖的源文件是:
main.cpp htmlutil.cpp
- 特殊变量分析
通过交叉编译原生库可从编译过程中获取一些我们需要的变量或者宏的设定。如若交叉编译过程中缺少变量/宏的定义会导致编译失败,我们需要在cmake构建脚本中添加对应的变量/宏。
通过以上方法可以分析出,tinyxpath库中未涉及特殊变量或者宏定义
新建cmake构建脚本
分析完tinyxpath的源码后,我们就可以根据cmake构建脚本编写的方法编写tinyxpath的cmake构建脚本了。
- 基本信息的编写
设置tinyxpath
cmake
构建的工具版本,工程名及工程版本以和构建语言
cmake_minimum_required (VERSION 3.12)
project(TINYXPATH VERSION 1.3.1)
enable_language(CXX C ASM)
- 设置常用变量
set(BUILD_SHARED_LIBS TRUE CACHE BOOL "If TRUE, tinyxpath is built as a shared library, otherwise as a static library")
set(TARGET_NAME tinyxpath)
set(TARGET_SAMPLE_NAME tinyxpath_test)
set(TARGET_INSTALL_INCLUDEDIR include)
set(TARGET_INSTALL_BINDIR bin)
set(TARGET_INSTALL_LIBDIR lib)
set(TARGET_SRC_PATH ${CMAKE_CURRENT_SOURCE_DIR}/tinyxpath1.3.1)
set(TARGET_SRC ${TARGET_SRC_PATH}/tinystr.cpp
${TARGET_SRC_PATH}/tinyxml.cpp
${TARGET_SRC_PATH}/tinyxmlerror.cpp
${TARGET_SRC_PATH}/tinyxmlparser.cpp
${TARGET_SRC_PATH}/action_store.cpp
${TARGET_SRC_PATH}/lex_util.cpp
${TARGET_SRC_PATH}/node_set.cpp
${TARGET_SRC_PATH}/tokenlist.cpp
${TARGET_SRC_PATH}/xml_util.cpp
${TARGET_SRC_PATH}/xpath_expression.cpp
${TARGET_SRC_PATH}/xpath_processor.cpp
${TARGET_SRC_PATH}/xpath_stack.cpp
${TARGET_SRC_PATH}/xpath_stream.cpp
${TARGET_SRC_PATH}/xpath_syntax.cpp
${TARGET_SRC_PATH}/xpath_static.cpp)
set(TARGET_INCLUDE ${TARGET_SRC_PATH})
- 设置可选项 测试用例做为一个三方库的可选项供用户自行选择是否编译,默认情况下是不编译测试用例
option(BUILD_SAMPLE "Build sample" OFF)
if(BUILD_SAMPLE)
add_executable(${TARGET_SAMPLE_NAME} ${TARGET_SAMPLE_SRC})
target_include_directories(${TARGET_SAMPLE_NAME} PRIVATE ${TARGET_INCLUDE})
target_link_libraries(${TARGET_SAMPLE_NAME} PUBLIC ${TARGET_NAME})
endif()
- 配置库以及其属性
add_library(${TARGET_NAME} ${TARGET_SRC})
target_include_directories(${TARGET_NAME} PRIVATE ${TARGET_INCLUDE})
if(BUILD_SHARED_LIBS)
set_target_properties(${TARGET_NAME} PROPERTIES VERSION ${PROJECT_VERSION_MAJOR}.${PROJECT_VERSION_MINOR}.${PROJECT_VERSION_PATCH}
SOVERSION ${PROJECT_VERSION_MAJOR})
endif()
- 配置库的安装
install(TARGETS ${TARGET_NAME}
EXPORT ${TARGET_NAME}
PUBLIC_HEADER DESTINATION ${TARGET_INSTALL_INCLUDEDIR}
PRIVATE_HEADER DESTINATION ${TARGET_INSTALL_INCLUDEDIR}
RUNTIME DESTINATION ${TARGET_INSTALL_BINDIR}
LIBRARY DESTINATION ${TARGET_INSTALL_LIBDIR}
ARCHIVE DESTINATION ${TARGET_INSTALL_LIBDIR})
install(FILES ${TARGET_SRC_PATH}/xpath_processor.h
${TARGET_SRC_PATH}/action_store.h
${TARGET_SRC_PATH}/byte_stream.h
${TARGET_SRC_PATH}/lex_token.h
${TARGET_SRC_PATH}/lex_util.h
${TARGET_SRC_PATH}/node_set.h
${TARGET_SRC_PATH}/tinystr.h
${TARGET_SRC_PATH}/tinyxml.h
${TARGET_SRC_PATH}/tinyxpath_conf.h
${TARGET_SRC_PATH}/tokenlist.h
${TARGET_SRC_PATH}/xml_util.h
${TARGET_SRC_PATH}/xpath_expression.h
${TARGET_SRC_PATH}/xpath_processor.h
${TARGET_SRC_PATH}/xpath_stack.h
${TARGET_SRC_PATH}/xpath_static.h
${TARGET_SRC_PATH}/xpath_stream.h
${TARGET_SRC_PATH}/xpath_syntax.h
DESTINATION ${TARGET_INSTALL_INCLUDEDIR}/${TARGET_NAME})
install(
EXPORT ${TARGET_NAME}
FILE ${TARGET_NAME}Targets.cmake
DESTINATION ${TARGET_INSTALL_LIBDIR}/cmake/${TARGET_NAME}
)
include(CMakePackageConfigHelpers)
write_basic_package_version_file(
${TARGET_NAME}ConfigVersion.cmake
VERSION ${PROJECT_VERSION_MAJOR}.${PROJECT_VERSION_MINOR}.${PROJECT_VERSION_PATCH}
COMPATIBILITY SameMajorVersion
)
configure_package_config_file(
cmake/PackageConfig.cmake.in ${TARGET_NAME}Config.cmake
INSTALL_DESTINATION ${TARGET_INSTALL_LIBDIR}/cmake/${TARGET_NAME}
)
install(FILES
${CMAKE_CURRENT_BINARY_DIR}/${TARGET_NAME}Config.cmake
${CMAKE_CURRENT_BINARY_DIR}/${TARGET_NAME}ConfigVersion.cmake
DESTINATION
${TARGET_INSTALL_LIBDIR}/cmake/${TARGET_NAME}
)
至此,tinyxpath的cmake构建脚本基本完成,具体可参照完整脚本
加入编译构建
将tinyxpath源码及新建的cmake构建脚本放置IDE工程对应的cpp目录下,并在顶层CMakeLists.txt文本中添加
add_subdirectory(tinyxpath)
target_link_libraries(entry PUBLIC libace_napi.z.so tinyxpath)
1、本站所有资源均从互联网上收集整理而来,仅供学习交流之用,因此不包含技术服务请大家谅解!
2、本站不提供任何实质性的付费和支付资源,所有需要积分下载的资源均为网站运营赞助费用或者线下劳务费用!
3、本站所有资源仅用于学习及研究使用,您必须在下载后的24小时内删除所下载资源,切勿用于商业用途,否则由此引发的法律纠纷及连带责任本站和发布者概不承担!
4、本站站内提供的所有可下载资源,本站保证未做任何负面改动(不包含修复bug和完善功能等正面优化或二次开发),但本站不保证资源的准确性、安全性和完整性,用户下载后自行斟酌,我们以交流学习为目的,并不是所有的源码都100%无错或无bug!如有链接无法下载、失效或广告,请联系客服处理!
5、本站资源除标明原创外均来自网络整理,版权归原作者或本站特约原创作者所有,如侵犯到您的合法权益,请立即告知本站,本站将及时予与删除并致以最深的歉意!
6、如果您也有好的资源或教程,您可以投稿发布,成功分享后有站币奖励和额外收入!
7、如果您喜欢该资源,请支持官方正版资源,以得到更好的正版服务!
8、请您认真阅读上述内容,注册本站用户或下载本站资源即您同意上述内容!
原文链接:https://www.shuli.cc/?p=21706,转载请注明出处。
评论0