|
HarmonyOS学习之四:OpenHarmony源码下载及构成简介, OpenHarmony是开放原子开源基金会(OpenAtom Foundation)旗下开源项目,定位是一款面向全场景的开源分布式操作系统,第一个版本支持128K-128M设备上运行。 代码仓库地址:https://openharmony.gitee.com/openharmony
一、源码获取方式 OpenHarmony的代码以组件的形式开放,开发者可以通过下面所列的方式其中一种方式获取:
获取方式1:从镜像站点下载压缩文件(推荐) 从以下站点的镜像库获取源码或者对应的解决方案。
下载内容 版本信息 下载站点 SHA256校验码 OpenHarmony 全量代码 1.0 站点 SHA256 校验码 Hi3861解决方案(二进制) 1.0 站点 SHA256 校验码 Hi3518解决方案(二进制) 1.0 站点 SHA256 校验码 Hi3516解决方案(二进制) 1.0 站点 SHA256 校验码 RELEASE-NOTES 1.0
获取方式2:从hpm网站组件式获取 通过HPM,查找满足需求的解决方案,挑选/裁剪组件后下载。
适用场景 对于刚接触OpenHarmony的新用户,希望能够参考一些示例解决方案从而进行快速开发。可以在HPM获取推荐的解决方案,以此为基础,增加或裁剪部分组件,快速定制系统。
操作步骤
1.查找合适的解决方案组件包。
- 打开包管理页面HPM,设定搜索的对象为“解决方案“,如下图所示。
- 自搜索框输入关键字搜索,如“camera“。
- 结果中显示匹配的解决方案,可以进一步根据组件类别等过滤条件(如:适配的开发板,内核)精确筛选。
- 查找合适的解决方案,点击查看解决方案详情介绍。
2.定制解决方案组件包。
- 仔细阅读解决方案的说明,以了解该解决方案的使用场景、特性、使用方法以及如何进行定制化,如下图所示。
- 点击「直接下载」,将解决方案下载到本地。
- 点击「定制组件」,将对解决方案包含的组件进行定制。
3.定制组件。 3.1进入解决方案定制页面,如下图所示。 3.2通过关闭开关移除可选组件,或者通过“添加组件”增加新的组件。 3.2在右边填写您的项目基本信息,包括名称、版本、描述等信息。 3.4点击“下载“,系统会根据您的选择,生成相应的OpenHarmony代码结构文件(如name.zip),保存至本地文件。
- 下载的压缩文件并未包含源代码的原始文件,可以在IDE中导入下载的压缩包,解压后执行hpm的安装指令(hpm install),才会将所需要的组件全部下载下来。
- 下载的组件存在工程目录下的ohos_bundles文件夹中。
获取方式3:用包管理器命令行工具获取 通过HPM的hpm-cli命令行工具,执行命令下载。
适用场景 用户已通过组件式获取的方式获取源码,需要对源码中的某个或某几个组件进行独立升级。
用户已经比较熟悉OpenHarmony系统的开发并且熟练掌握命令行工具的使用。
准备 通过命令行获取,需要先安装Node.js和hpm命令行工具,安装步骤如下:
官网下载并在本地安装Node.js. 推荐安装 Node.js 12.x (包含 npm 6.14.4)或更高版本 (推荐 12.13.0+)。 2.通过Node.js自带的npm安装hpm命令行工具。 打开CMD,执行以下命令:
- $npm install -g @ohos/hpm-cli
复制代码 3.安装完成后执行如下命令,显示hpm版本,即安装成功。 $ hpm -V 或 hpm --version 4.如果升级hpm的版本,请执行如下命令: $ npm update -g @ohos/hpm-cli
操作 接下来将组件添加到开发项目中,假定要获取的组件名为@ohos/demo,具体操作如下: 1.进入开发目录,执行如下命令,采用默认模板创建一个开发项目。
复制代码 2.执行如下命令,安装组件@ohos/demo
复制代码 3.工具会自动从服务器下载所有依赖的组件,下载成功则显示Install successfully!
- <span style=“font-size: 18px;“>$ hpm install @ohos/demo </span>
- <span style=“font-size: 18px;“> Requesting: </span><font size=“4“>https://url.foo.bar/hpm/registry/api/bundles/@ohos/demo
- </font><span style=“font-size: 18px;“> downloading @ohos/demo</span>
- <span style=“font-size: 18px;“> Requesting: </span><font size=“4“>https://lfcontentcenterdev....../bMAlLrYISLqdUTFFFCdgzA.tgz </font>
- <span style=“font-size: 18px;“> extract D:\demo\ohos_bundles\@ohos\demo\@ohos-demo-1.0.7.tgz</span>
- <span style=“font-size: 18px;“> Install successfully!</span>
复制代码
获取方式4:从代码仓库获取 通过repo或git工具从代码仓库中下载。
适用场景
- 基于OpenHarmony的稳定分支建立自己的基线,分发下游客户。
- 已经完成自身软件与OpenHarmony的对接,需要进行OpenHarmony官方认证。
- 芯片/模组/app通过OpenHarmony官方认证后,贡献代码到OpenHarmony生态。
- 修复OpenHarmony的问题。
- 学习OpenHarmony的源码。
准备 1.注册码云gitee账号。 2.注册码云SSH公钥,请参考码云帮助中心的公钥管理:https://gitee.com/help/articles/4181 3.安装git客户端并配置用户信息。
- git config --global user.name “yourname“
- git config --global user.email “your-email-address“
- git config --global credential.helper store
复制代码 4.安装码云repo工具,可以执行如下命令。
- <span style=“font-size: 18px;“>curl </span><font size=“4“>https://gitee.com/oschina/repo/raw/fork_flow/repo-py3</font><span style=“font-size: 18px;“> > /usr/local/bin/repo</span>
- <span style=“font-size: 18px;“>chmod a+x /usr/local/bin/repo</span>
- <span style=“font-size: 18px;“>pip install -i </span><font size=“4“>https://pypi.tuna.tsinghua.edu.cn/simple</font><span style=“font-size: 18px;“> requests</span>
复制代码
操作 方式一(推荐):通过repo下载
- <span style=“font-size: 18px;“>repo init -u </span><font size=“4“>https://gitee.com/openharmony/manifest.git</font><span style=“font-size: 18px;“> -b master</span>
- <span style=“font-size: 18px;“>repo sync -c</span>
复制代码 方式二:通过git clone单个代码仓库 进入代码仓库主页:https://gitee.com/openharmony,选择需要克隆的代码仓库,执行命令,如:
- <span style=“font-size: 18px;“>git clone </span><font size=“4“>https://gitee.com/openharmony/manifest.git</font><span style=“font-size: 18px;“> -b master</span>
复制代码
二、源码目录说明 OpenHarmony的主要源码的目录及说明如下:
applications: 应用程序样例,包括wifi-iot,camera等
base: 基础软件服务子系统集&硬件服务子系统集
build: 组件化编译、构建和配置脚本
domains: 增强软件服务子系统集
drivers: 驱动子系统
foundation: 系统基础能力子系统集
kernel: 内核子系统
prebuilts: 编译器及工具链子系统
test: 测试子系统
third_party: 开源第三方组件
utils: 常用的工具集
vendor: 厂商提供的软件
build.py: 编译脚本文件
文章来源:jyl_sh |
|