组件构成

    • 组件包的代码或库(src目录下的代码文件)
    • ohos_bundles文件夹(存放依赖的组件,安装组件时自动生成,无需提交到代码库)
    • 组件包的说明文件(README.md)
    • 组件包元数据声明文件(bundle.json)
    • 开源许可文件(LICENSE)

    组件的代码文件和普通的代码目录没有差异。但要注意的是,组件中对外暴露的接口(头文件),会被其他组件所引用,需要单独在bundle.json的dirs中声明。

    README.md,为markdown格式的描述关于组件自述说明文件。(语法参考)

    为了帮助他人在hpm上找到该组件,并更方便的使用它,在组件的根目录中包含一个README文件。

    README文件可能包括如何安装,配置和使用组件包中的实例代码说明,以及可能会对用户有所帮助的任何其他信息。

    bundle.json文件是对当前组件的元数据描述,每个组件中必须包含一个bundle.json文件。

    1. "name": "@myorg/demo-bundle",
    2. "version": "1.0.0",
    3. "license": "MIT",
    4. "description": "bundle description",
    5. "keywords": ["hos"],
    6. "tags": ["applications", "drivers"],
    7. "author": {"name":"","email":"","url":""},
    8. "homepage": "http://www.foo.bar.com",
    9. "publishAs": "source",
    10. "dirs": {
    11. "src": ["src/**/*.c"],
    12. "headers": ["headers/**/*.h"],
    13. "bin": ["bin/**/*.o"]
    14. },
    15. "scripts": {
    16. "build": "make"
    17. },
    18. "ohos": {
    19. "os": "2.0.0",
    20. "board": "hi3516",
    21. "kernel": "liteos-a"
    22. "rom": "10240",
    23. "ram": "1024",
    24. "dependencies": {
    25. "@myorg/net":"1.0.0"
    26. }

    bundle.json文件具有如下功能:

    • name:定义组件的名称,放到组织下, 以@开头,/分割,如:@myorg/mybundle

    • version:定义组件版本号,如1.0.0,需满足semver的标准。

    • description:一句话对组件进行简要的描述。

    • envs: 定义组件编译时所需要的参数,包括全局参数以及依赖所需的参数。

    • scripts:定义在当前组件下能够执行的命令(如编译,构建,测试,烧录等)。

    • publishAs:定义组件的发布类型(source:源码,binary:二进制,distribution:发行版,code-segment:代码片段)。

    • dirs:定义发布时打包的目录结构(如头文件)。

    • ram&rom:统计相关信息:预计占用ROM和RAM信息。

    • ohos:描述OpenHarmony系统版本、开发板及内核的匹配关系(多个请用英文逗号的“,”分割)。
    • 对于发行版类型,还有个base,可以定义继承自的发行版。