diff --git a/thirdparty/libxlsxwriter/HPKBUILD b/thirdparty/libxlsxwriter/HPKBUILD new file mode 100644 index 0000000000000000000000000000000000000000..6245b657b971a86b5595b65f64b6de7df5ede1f0 --- /dev/null +++ b/thirdparty/libxlsxwriter/HPKBUILD @@ -0,0 +1,49 @@ +# Contributor: wupingyuan +# Maintainer: wupingyuan +pkgname=libxlsxwriter +pkgver=RELEASE_1.1.5 +pkgrel=0 +pkgdesc="Libxlsxwriter is a C library that can be used to write text, numbers, formulas and hyperlinks to multiple worksheets in an Excel 2007+ XLSX file." +url="https://github.com/jmcnamara/libxlsxwriter" +archs=("armeabi-v7a" "arm64-v8a") +license=("FreeBSD") +depends=() +makedepends=() +install= +source="https://github.com/jmcnamara/$pkgname/archive/refs/tags/$pkgver.tar.gz" + +autounpack=true +downloadpackage=true +builddir=$pkgname-$pkgver +packagename=$builddir.tar.gz + +prepare() { + mkdir -p $builddir/$ARCH-build +} + +build() { + cd $builddir + ${OHOS_SDK}/native/build-tools/cmake/bin/cmake "$@" -DOHOS_ARCH=$ARCH -DBUILD_TESTS=ON -B$ARCH-build -S./ -L > `pwd`/$ARCH-build/build.log 2>&1 + make -j4 -C $ARCH-build >> `pwd`/$ARCH-build/build.log 2>&1 + ret=$? + cd $OLDPWD + return $ret +} + +package() { + cd $builddir + make -C $ARCH-build install >> `pwd`/$ARCH-build/build.log 2>&1 + ret=$? + cd $OLDPWD + return $ret +} + +check() { + echo "The test must be on an OpenHarmony device!" + # 在OpenHarmony开发板中执行用例 + # ctest +} + +cleanbuild(){ + rm -rf ${PWD}/$builddir #${PWD}/$packagename +} diff --git a/thirdparty/libxlsxwriter/README.OpenSource b/thirdparty/libxlsxwriter/README.OpenSource new file mode 100644 index 0000000000000000000000000000000000000000..628d67e73b422293a344450c707242e96842ee50 --- /dev/null +++ b/thirdparty/libxlsxwriter/README.OpenSource @@ -0,0 +1,11 @@ +[ + { + "Name": "libxlsxwriter", + "License": "FreeBSD", + "License File": "License.txt", + "Version Number": "RELEASE_1.1.5", + "Owner": "wupingyuan@huawei.com", + "Upstream URL": "https://github.com/jmcnamara/libxlsxwriter/archive/refs/tags/RELEASE_1.1.5.tar.gz", + "Description": "Libxlsxwriter is a C library that can be used to write text, numbers, formulas and hyperlinks to multiple worksheets in an Excel 2007+ XLSX file." + } +] diff --git a/thirdparty/libxlsxwriter/README_zh.md b/thirdparty/libxlsxwriter/README_zh.md new file mode 100644 index 0000000000000000000000000000000000000000..d146388670082bdd4308f49aafcdced32feab3e9 --- /dev/null +++ b/thirdparty/libxlsxwriter/README_zh.md @@ -0,0 +1,12 @@ +# libxlsxwriter三方库说明 +## 功能简介 +libxlsxwriter是一个可以向Excel写入文字和图片的库。 +## 使用约束 +- IDE版本:DevEco Studio 3.1 Beta2 +- SDK版本:ohos_sdk_public 3.2.11.9 (API Version 9 Release) +- 三方库版本:RELEASE_1.1.5 +- 当前适配的功能:Excel写入文字和图片 +- [FreeBSD](https://github.com/jmcnamara/libxlsxwriter) + +## 集成方式 ++ [应用hap包集成](docs/hap_integrate.md) diff --git a/thirdparty/libxlsxwriter/SHA512SUM b/thirdparty/libxlsxwriter/SHA512SUM new file mode 100644 index 0000000000000000000000000000000000000000..c5c057127c6717b4e937840871efe8e6fbaa515e --- /dev/null +++ b/thirdparty/libxlsxwriter/SHA512SUM @@ -0,0 +1 @@ +bd7db0fcf25ebf492b4d8f7da8fdb6cc79400d7d0fa5856ddae259cb24817034fc97d4828cbde42434f41198dcfb6732ac63c756abd962689f4249ca64bf19c6 libxlsxwriter-RELEASE_1.1.5.tar.gz \ No newline at end of file diff --git a/thirdparty/libxlsxwriter/docs/hap_integrate.md b/thirdparty/libxlsxwriter/docs/hap_integrate.md new file mode 100644 index 0000000000000000000000000000000000000000..fffa23792aab8c6242b65021d70f1a6f7863d623 --- /dev/null +++ b/thirdparty/libxlsxwriter/docs/hap_integrate.md @@ -0,0 +1,67 @@ +# libxlsxwriter集成到应用hap +本库是在RK3568开发板上基于OpenHarmony3.2 Release版本的镜像验证的,如果是从未使用过RK3568,可以先查看[润和RK3568开发板标准系统快速上手](https://gitee.com/openharmony-sig/knowledge_demo_temp/tree/master/docs/rk3568_helloworld)。 +## 开发环境 +- ubuntu20.04 +- [OpenHarmony3.2Release镜像](https://gitee.com/link?target=https%3A%2F%2Frepo.huaweicloud.com%2Fopenharmony%2Fos%2F3.2-Release%2Fdayu200_standard_arm32.tar.gz) +- [ohos_sdk_public 3.2.11.9 (API Version 9 Release)](https://gitee.com/link?target=https%3A%2F%2Frepo.huaweicloud.com%2Fopenharmony%2Fos%2F3.2-Release%2Fohos-sdk-windows_linux-public.tar.gz) +- [DevEco Studio 3.1 Beta2](https://gitee.com/link?target=https%3A%2F%2Fcontentcenter-vali-drcn.dbankcdn.cn%2Fpvt_2%2FDeveloperAlliance_package_901_9%2Ff3%2Fv3%2FuJyuq3syQ2ak4hE1QZmAug%2Fdevecostudio-windows-3.1.0.400.zip%3FHW-CC-KV%3DV1%26HW-CC-Date%3D20230408T013335Z%26HW-CC-Expire%3D315360000%26HW-CC-Sign%3D96262721EDC9B34E6F62E66884AB7AE2A94C2A7B8C28D6F7FC891F46EB211A70) +- [准备三方库构建环境](../../../tools/README.md#编译环境准备) +- [准备三方库测试环境](../../../tools/README.md#ci环境准备) +## 编译三方库 +- 下载本仓库 + ``` + git clone https://gitee.com/openharmony-sig/tpc_c_cplusplus.git --depth=1 + ``` +- 三方库目录结构 + ``` + tpc_c_cplusplus/thirdparty/libxlsxwriter #三方库libxlsxwriter的目录结构如下 + ├── docs #三方库相关文档的文件夹 + ├── HPKBUILD #构建脚本 + ├── SHA512SUM #三方库校验文件 + ├── README.OpenSource #说明三方库源码的下载地址,版本,license等信息 + ├── README_zh.md + ``` + +- 将libxlsxwriter拷贝至tools/main目录下 + ``` + cd tpc_c_cplusplus + cp thirdparty/libxlsxwriter tools/main -rf + ``` +- 在tools目录下编译三方库 + 编译环境的搭建参考[准备三方库构建环境](../../../tools/README.md#编译环境准备) + ``` + cd tools + ./build.sh libxlsxwriter + ``` +- 三方库头文件及生成的库 + 在tools目录下会生成usr目录,该目录下存在已编译完成的32位和64位三方库 + ``` + libxlsxwriter/arm64-v8a libxlsxwriter/armeabi-v7a + ``` + +- [测试三方库](#测试三方库) + +## 应用中使用三方库 + +- 在IDE的cpp目录下新增thirdparty目录,将编译生成的库拷贝到该目录下,如下图所示 + ![thirdparty_install_dir](pic/libxlsxwriter_install_dir.jpg) +- 在最外层(cpp目录下)CMakeLists.txt中添加如下语句 + ``` + #将三方库加入工程中 + target_link_libraries(entry PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/thirdparty/libxlsxwriter/${OHOS_ARCH}/lib/libxlsxwriter.a) + #将三方库的头文件加入工程中 + target_include_directories(entry PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/thirdparty/libxlsxwriter/${OHOS_ARCH}/include) + ``` + ![libxlsxwriter_usage](pic/libxlsxwriter_usage.jpg) +## 测试三方库 +三方库的测试使用原库自带的测试用例来做测试,[准备三方库测试环境](../../../tools/README.md#ci环境准备) + +进入到构建目录执行ctest运行测试用例(arm64-v8a-build为构建64位的目录,armeabi-v7a-build为构建32位的目录), 备注:由于ohos不支持python,因此涉及到python的用例无法通过 + + ![libxlsxwriter_test](pic/libxlsxwriter_test.jpg) + +## 参考资料 +- [润和RK3568开发板标准系统快速上手](https://gitee.com/openharmony-sig/knowledge_demo_temp/tree/master/docs/rk3568_helloworld) +- [OpenHarmony三方库地址](https://gitee.com/openharmony-tpc) +- [OpenHarmony知识体系](https://gitee.com/openharmony-sig/knowledge) +- [通过DevEco Studio开发一个NAPI工程](https://gitee.com/openharmony-sig/knowledge_demo_temp/blob/master/docs/napi_study/docs/hello_napi.md) diff --git a/thirdparty/libxlsxwriter/docs/pic/libxlsxwriter_install_dir.jpg b/thirdparty/libxlsxwriter/docs/pic/libxlsxwriter_install_dir.jpg new file mode 100644 index 0000000000000000000000000000000000000000..204969ec5907b037a8a218d47bb93eba696c493d Binary files /dev/null and b/thirdparty/libxlsxwriter/docs/pic/libxlsxwriter_install_dir.jpg differ diff --git a/thirdparty/libxlsxwriter/docs/pic/libxlsxwriter_test.jpg b/thirdparty/libxlsxwriter/docs/pic/libxlsxwriter_test.jpg new file mode 100644 index 0000000000000000000000000000000000000000..37488297918d882f750d8a4be65114388350d95d Binary files /dev/null and b/thirdparty/libxlsxwriter/docs/pic/libxlsxwriter_test.jpg differ diff --git a/thirdparty/libxlsxwriter/docs/pic/libxlsxwriter_usage.jpg b/thirdparty/libxlsxwriter/docs/pic/libxlsxwriter_usage.jpg new file mode 100644 index 0000000000000000000000000000000000000000..ffaa4179151683f4b076e46d39665e9aab7ba467 Binary files /dev/null and b/thirdparty/libxlsxwriter/docs/pic/libxlsxwriter_usage.jpg differ