lycium_plusplus介绍

项目地址

lycium++ 是基于openharmony cpp 编译框架lycium的增强

主要包含以下几个目标:

  1. 针对目标产物,构建依赖关系树,一键构建
  2. 对于三方库的HPKBUILD,提供多版本构建能力,代码仓脱离本仓独立发布,可通过三方件源码仓获取编译
  3. 提供hnp构建产物的生成,支持Harmony系统使用
    关于lycium编译框架,请访问OpenHarmony-SIG/tpc_c_cplusplus了解更多

如何使用

原生构建方式

本项目遵循lycium编译框架,您可以基于lycium基础进行构建,如

cd lyium
./build.sh unzip

通过原生方式,lycium编译框架会基于community/thirdparty 中已存在的三方库进行编译构建

增强型构建方式

框架示意
在这里插入图片描述

外部适配仓参与构建

本项目新增目录outerrepo用于临时存放外部仓,外部仓信息存放在outerrepo/module.json

该文件中包含的关键要素如下:

    "module" : [
        {
            "name" : "tree",
            "branch" : "ohos_2.2.1",
            "version" : "2.2.1",
            "type" : "git",
            "url" : "https://gitcode.com/OpenHarmonyPCDeveloper/ohos_tree.git"
        }
    ]
  1. name为模块名称,如上述示例中的tree
  2. url为适配仓代码地址,以及适配仓所对应的原生代码tree的版本信息version
  3. branch为适配仓为该对应关系中适配仓的对应分支信息
  4. type为适配仓托管类型的下载方式,如上述中,ohos_tree适配仓的下载方式为git(其他获取源码方式待扩展)
外部ports仓规范

外部代码仓适配遵循lycium原生框架所需要的内容,仅作为独立仓库部署,例如tree的适配,额外可以增加打包hnp时的配置文件hnp.json

├── 0001-ports-for-ohos.patch
├── HPKBUILD
└── hnp.json

hnp.json示例如下:

{
    "type":"hnp-config",
    "name":"tree",
    "version":"2.2.1",
    "install":{}
}

此外,在HPKBUILD中,按照需求可以增加archive阶段

archive() {
    mkdir -p ${LYCIUM_ROOT}/output/$ARCH
    pushd $LYCIUM_ROOT/usr/$pkgname/$ARCH
        tar -zvcf ${LYCIUM_ROOT}/output/$ARCH/${pkgname}_${pkgver}.tar.gz *
    popd
    cp hnp.json $LYCIUM_ROOT/usr/$pkgname/$ARCH
    ${HNP_TOOL} pack -i ${LYCIUM_ROOT}/usr/$pkgname/$ARCH -o ${LYCIUM_ROOT}/output/$ARCH/
}

在这里插入图片描述

该阶段将会在package()阶段后被调用,该阶段需要按照${LYCIUM_ROOT}/output/$ARCH路径进行输出

编译

适配完成后,可以按照原生编译的方式执行,仍以tree举例:

 cd lyium
 ./build.sh tree

在这里插入图片描述

产物获取

获取编译产物

  1. 可在lycium/usr/tree/<ARCH>下获取对应架构下的二进制产物
  2. 可在lycium/output/<ARCH>/下获取对应架构下的归档产物
贡献

生成hnp的命令行产物,可以贡献到lycium_plusplus中,通过提交module.json即可简单完成贡献

您的hnp产物,也可以贡献到DevBox中,通过该方式使用命令行

Logo

讨论HarmonyOS开发技术,专注于API与组件、DevEco Studio、测试、元服务和应用上架分发等。

更多推荐