# 组件构成 一个组件包一般包含如下内容: - 组件包的代码或库(src目录下的代码文件) - ohos\_bundles文件夹(存放依赖的组件,安装组件时自动生成,无需提交到代码库) - 组件包的说明文件\(README.md\) - 组件包元数据声明文件\(bundle.json\) - 开源许可文件\(LICENSE\) ``` my-bundle |_ohos_bundles |_src |_bundle.json |_README.md |_LICENSE ``` ## 代码文件 组件的代码文件和普通的代码目录没有差异。但要注意的是,组件中对外暴露的接口(头文件),会被其他组件所引用,需要单独在bundle.json的dirs中声明。 ## 说明文件 README.md,为markdown格式的描述关于组件自述说明文件。([语法参考](https://www.markdownguide.org/getting-started/)\) 为了帮助他人在hpm上找到该组件,并更方便的使用它,在组件的根目录中包含一个README文件。 README文件可能包括如何安装,配置和使用组件包中的实例代码说明,以及可能会对用户有所帮助的任何其他信息。 每个组件的自述文件将显示在hpm系统的组件详情页面的描述中。 ## 元数据描述文件 bundle.json文件是对当前组件的元数据描述,每个组件中必须包含一个bundle.json文件。 ``` { "name": "@myorg/demo-bundle", "version": "1.0.0", "license": "MIT", "description": "bundle description", "keywords": ["hos"], "tags": ["applications", "drivers"], "author": {"name":"","email":"","url":""}, "contributors":[{"name":"","email":"","url":""},{"name":"","email":"","url":""}], "homepage": "http://www.foo.bar.com", "repository": "https://git@gitee.com:foo/bar.git", "publishAs": "source", "dirs": { "src": ["src/**/*.c"], "headers": ["headers/**/*.h"], "bin": ["bin/**/*.o"] }, "scripts": { "build": "make" }, "envs": {}, "ohos": { "os": "2.0.0", "board": "hi3516", "kernel": "liteos-a" }, "rom": "10240", "ram": "1024", "dependencies": { "@myorg/net":"1.0.0" } } ``` 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,可以定义继承自的发行版。