源码获取
详情请参考:https://gitee.com/openharmony/docs/blob/master/get-code/%E6%BA%90%E7%A0%81%E8%8E%B7%E5%8F%96.mdgit
OpenHarmony介绍
OpenHarmony是HarmonyOS的开源版,由华为捐赠给开放原子开源基金会(OpenAtom Foundation)开源。第一个开源版本支持在128KB~128MB设备上运行,欢迎参加开源社区一块儿持续演进。npm
代码仓库地址:https://openharmony.gitee.comapi
源码获取概述
本文档将介绍如何获取OpenHarmony源码并说明OpenHarmony的源码目录结构。OpenHarmony的代码以组件的形式开放,开发者能够经过以下其中一种方式获取:bash
- 获取方式1: 从镜像站点下载压缩文件(推荐)
- 获取方式2: 从hpm网站组件式获取。经过HPM,查找知足需求的解决方案,挑选/裁剪组件后下载。
- 获取方式3: 用包管理器命令行工具获取。经过HPM的hpm-cli命令行工具,执行命令下载。
- 获取方式4: 从代码仓库获取。经过repo或git工具从代码仓库中下载。
获取方式1:从镜像站点获取
为了得到更好的下载性能,您能够选择从如下站点的镜像库获取源码或者对应的解决方案。服务器
表 1 源码获取路径app
下载内容 | 版本信息 | 下载站点 | SHA256校验码 |
---|---|---|---|
OpenHarmony全量代码 | 1.0 | 站点一、站点2 | SHA256 校验码 |
Hi3861解决方案 | 1.0 | 站点一、站点2 | SHA256 校验码 |
Hi3518解决方案 | 1.0 | 站点一、站点2 | SHA256 校验码 |
Hi3516解决方案 | 1.0 | 站点一、站点2 | SHA256 校验码 |
RELEASE-NOTES | 1.0 | 站点1 | - |
获取方式2:从hpm网站组件式获取
适用场景
对于刚接触OpenHarmony的新用户,但愿可以参考一些示例解决方案从而进行快速开发。能够在HPM获取推荐的解决方案,以此为基础,增长或裁剪部分组件,快速定制系统。dom
操做步骤
- 查找合适的解决方案组件包。
- 打开包管理页面HPM,设定搜索的对象为“解决方案“,以下图所示。
- 自搜索框输入关键字搜索,如"camera"。
- 结果中显示匹配的解决方案,能够进一步根据组件类别等过滤条件(如:适配的开发板,内核)精确筛选。
- 查找合适的解决方案,点击查看解决方案详情介绍
-
定制解决方案组件包。curl
- 仔细阅读解决方案的说明,以了解该解决方案的使用场景、特性、使用方法以及如何进行定制化,以下图所示。
- 点击「直接下载」,将解决方案下载到本地。
- 点击「定制组件」,将对解决方案包含的组件进行定制。
- 定制组件。
- 下载的压缩文件并未包含源代码的原始文件,能够在IDE中导入下载的压缩包,解压后执行hpm的安装指令(hpm install),才会将所须要的组件所有下载下来。
- 下载的组件存在工程目录下的ohos_bundles文件夹中。
- 进入解决方案定制页面,以下图所示。
- 经过关闭开关移除可选组件,或者经过“添加组件”增长新的组件。
- 在右边填写您的项目基本信息,包括名称、版本、描述等信息。
- 点击“下载“,系统会根据您的选择,生成相应的OpenHarmony代码结构文件(如name.zip),保存至本地文件。
获取方式3:用包管理器命令行获取
适用场景
- 用户已经过组件式获取的方式获取源码,须要对源码中的某个或某几个组件进行独立升级。
- 用户已经比较熟悉OpenHarmony系统的开发而且熟练掌握命令行工具的使用。
准备
经过命令行获取,须要先安装Node.js和hpm命令行工具,安装步骤以下:ide
- 安装Node.js。
官网下载并在本地安装Node.js.
推荐安装 Node.js 12.x (包含 npm 6.14.4)或更高版本 (推荐 12.13.0+)。
- 经过Node.js自带的npm安装hpm命令行工具。
打开CMD,执行如下命令:
npm install -g @ohos/hpm-cli
- 安装完成后执行以下命令,显示hpm版本,即安装成功。
hpm -V 或 hpm --version
- 若是升级hpm的版本,请执行以下命令:
npm update -g @ohos/hpm-cli
操做
接下来将组件添加到开发项目中,假定要获取的组件名为@ohos/demo,具体操做以下:工具
- 进入开发目录,执行以下命令,采用默认模板建立一个开发项目。
hpm init -t default
- 执行以下命令,安装组件@ohos/demo
hpm install @ohos/demo
- 工具会自动从服务器下载全部依赖的组件,下载成功则显示Install successfully!
$ hpm install @ohos/demoRequesting: https://url.foo.bar/hpm/registry/api/bundles/@ohos/demodownloading @ohos/demoRequesting: https://lfcontentcenterdev....../bMAlLrYISLqdUTFFFCdgzA.tgzextract D:\demo\ohos_bundles\@ohos\demo\@ohos-demo-1.0.7.tgzInstall successfully!
获取方式4:从代码仓库获取
适用场景
- 基于OpenHarmony的稳定分支创建本身的基线,分发下游客户。
- 已经完成自身软件与OpenHarmony的对接,须要进行OpenHarmony官方认证。
- 芯片/模组/app经过OpenHarmony官方认证后,贡献代码到OpenHarmony生态。
- 修复OpenHarmony的问题。
- 学习OpenHarmony的源码。
准备
- 注册码云gitee帐号。
- 注册码云SSH公钥,请参考码云帮助中心的公钥管理:https://gitee.com/help/articles/4181
- 安装git客户端并配置用户信息。
git config --global user.name "yourname"git config --global user.email "your-email-address"git config --global credential.helper store
- 安装码云repo工具,能够执行以下命令。
curl https://gitee.com/oschina/repo/raw/fork_flow/repo-py3 > /usr/local/bin/repochmod a+x /usr/local/bin/repopip install -i https://pypi.tuna.tsinghua.edu.cn/simple requests
操做
方式一(推荐):经过repo下载
repo init -u https://gitee.com/openharmony/manifest.git -b master --no-repo-verifyrepo sync -c
方式二:经过git clone单个代码仓库
进入代码仓库主页:https://gitee.com/openharmony ,选择须要克隆的代码仓库,执行命令,如:
git clone https://gitee.com/openharmony/manifest.git -b master
源码目录简介
下表是OpenHarmony源码的目录及简单说明:
表 2 源码目录的说明 |
目录名 | 描述 |
---|---|---|
applications | 应用程序样例,包括wifi-iot,camera等 | |
base | 基础软件服务子系统集&硬件服务子系统集 | |
build | 组件化编译、构建和配置脚本 | |
domains | 加强软件服务子系统集 | |
drivers | 驱动子系统 | |
foundation | 系统基础能力子系统集 | |
kernel | 内核子系统 | |
prebuilts | 编译器及工具链子系统 | |
test | 测试子系统 | |
third_party | 开源第三方组件 | |
utils | 经常使用的工具集 | |
vendor | 厂商提供的软件 | |
build.py | 编译脚本文件 |
HarmonyOS官方开发者论坛:https://developer.huawei.com/consumer/cn/forum/blockdisplay?fid=0101303901040230869
原文连接:https://developer.huawei.com/consumer/cn/forum/topicview?tid=0202350736685590542&fid=0101303901040230869
原做者:kelly