三方库是指其他公司或者组织提供的服务或模块,例如常见的开源 OpenCV、libcurl 库,将三方库迁移至OpenHarmony 上,有助于系统的生态建设。
本文首先以三方库 curl 为例,分别给出 Windows 和 Linux 开发环境下,curl 移植到 OpenHarmony 上的流程示意。主要涉及三部分内容,分别为编译环境的准备、编译工具的使用以及生成文件的调用。然后以 luajit 库为例,介绍非camke编译时,如何配置环境变量,并使用make进行编译构建。
git clone https://github.com/curl/curl.git
native中cmake的相关工具添加到系统环境变量,cmake编译工具位于OpenHarmony SDK的native目录下
mkdir build
cd build
# 编译64或者32,二选一,选择 Ninja 生成器
# arm64-v8a 编译64位
cmake -DCMAKE_TOOLCHAIN_FILE=C:\Users\duwentao\AppData\Local\OpenHarmony\Sdk\9\native\build\cmake\ohos.toolchain.cmake -DOHOS_ARCH=arm64-v8a -DOHOS_STL=c++_shared .. -G Ninja
# lib下的cmake
# armeabi-v7a 编译32位
cmake -DCMAKE_TOOLCHAIN_FILE=C:\Users\duwentao\AppData\Local\OpenHarmony\Sdk\9\native\build\cmake\ohos.toolchain.cmake -DOHOS_ARCH=armeabi-v7a -DOHOS_STL=c++_shared .. -G Ninja
# 编译构建
cmake --build .
编译环境目前主要支持Ubuntu18.04和Ubuntu20.04(Ubuntu22.04暂不支持)
本节基于wsl和Ubuntu20.04,在Linux环境下编译 curl 库,并在应用中调用 curl 中的相关接口
git clone https://github.com/curl/curl.git
下载 OpenHarmony SDK 命令行工具
unzip command-line-tools.zip
vim config.properties
./sdkmgr install native:9 toolchains --accept-license
vim ~/.bashrc
# 配置路径
export PATH='/home/dwt/ndk/9/native/build-tools/cmake/bin':$PATH
# 执行source命令使配置文件立即生效
source ~/.bashrc
mkdir build
cd build
cmake -DCMAKE_TOOLCHAIN_FILE=//home/dwt/ndk/9/native/build/cmake/ohos.toolchain.cmake -DOHOS_ARCH=arm64-v8a -DOHOS_STL=c++_shared .. -G Ninja -DHAVE_WRITABLE_ARGV_EXITCODE=0 -DHAVE_WRITABLE_ARGV_EXITCODE__TRYRUN_OUTPUT=0
DHAVE_WRITABLE_ARGV_EXITCODE和DHAVE_WRITABLE_ARGV_EXITCODE__TRYRUN_OUTPUT为cmake中 try_run()函数 所需缓存变量
在 /curl/build/lib 目录下将会生成目标文件:libcurl.so
参照上文windows示例的调用方式,开发者可在业务native代码中调用curl相关接口
luajit 是一个以makefile进行构建的三方库。这种情况下有两种处理策略,一种是使用 cmake 构建脚本重写开源库的构建过程,对于cmake的命令语法要求较高。另一种是直接使用开源库原生的构建工具,例如 configure、makefile,然后配置ohos_sdk的环境变量,进行编译。
首先,编译工具都有自己对应的环境变量。构建脚本并不是直接调用 gcc 或者 clang 编译工具链的,而是优先调用 CC 环境变量以达到调用 c 编译器的目的,对应的 CXX 环境变量对应 c++ 编译器。通过设置环境变量,让构建工具使用 ohos SDK 的编译工具链。
#aarch64-linux-ohos
export OHOS_SDK=/home/dwt/ndk/9
export AS=${OHOS_SDK}/native/llvm/bin/llvm-as
export CC="${OHOS_SDK}/native/llvm/bin/clang --target=aarch64-linux-ohos"
export CXX="${OHOS_SDK}/native/llvm/bin/clang++ --target=aarch64-linux-ohos"
export LD="${OHOS_SDK}/native/llvm/bin/lld --target=aarch64-linux-ohos"
export STRIP=${OHOS_SDK}/native/llvm/bin/llvm-strip
export RANLIB=${OHOS_SDK}/native/llvm/bin/llvm-ranlib
export OBJDUMP=${OHOS_SDK}/native/llvm/bin/llvm-objdump
export OBJCOPY=${OHOS_SDK}/native/llvm/bin/llvm-objcopy
export NM=${OHOS_SDK}/native/llvm/bin/llvm-nm
export AR=${OHOS_SDK}/native/llvm/bin/llvm-ar
export CFLAGS="-fPIC -D__MUSL__=1"
export CXXFLAGS="-fPIC -D__MUSL__=1"
linux-arm
export OHOS_SDK=/home/dwt/ndk/9
export AS=${OHOS_SDK}/native/llvm/bin/llvm-as
export CC="${OHOS_SDK}/native/llvm/bin/clang --target=arm-linux-ohos"
export CXX="${OHOS_SDK}/native/llvm/bin/clang++ --target=arm-linux-ohos"
export LD="${OHOS_SDK}/native/llvm/bin/lld --target=arm-linux-ohos"
export STRIP=${OHOS_SDK}/native/llvm/bin/llvm-strip
export RANLIB=${OHOS_SDK}/native/llvm/bin/llvm-ranlib
export OBJDUMP=${OHOS_SDK}/native/llvm/bin/llvm-objdump
export OBJCOPY=${OHOS_SDK}/native/llvm/bin/llvm-objcopy
export NM=${OHOS_SDK}/native/llvm/bin/llvm-nm
export AR=${OHOS_SDK}/native/llvm/bin/llvm-ar
export CFLAGS="-fPIC -march=armv7a -D__MUSL__=1"
export CXXFLAGS="-fPIC -march=armv7a -D__MUSL__=1"
make