组件构成

一个组件包一般包含如下内容:

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

    1. my-bundle
    2. |_ohos_bundles
    3. |_src
    4. |_bundle.json
    5. |_README.md
    6. |_LICENSE

代码文件

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

说明文件

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

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

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

每个组件的自述文件将显示在hpm系统的组件详情页面的描述中。

元数据描述文件

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

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

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

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

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

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

  • dependencies:定义组件的依赖组件。

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

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

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

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

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

  • ohos:描述OpenHarmony系统版本、开发板及内核的匹配关系(多个请用英文逗号的“,”分割)。
  • 定义其他扩展信息:作者,主页,代码仓库,许可协议,标签,关键字。
  • 对于发行版类型,还有个base,可以定义继承自的发行版。