请选择 进入手机版 | 继续访问电脑版

鸿蒙学堂

 找回密码
 立即注册
查看: 1586|回复: 13

如何获取OpenHarmony源码

[复制链接]

12

主题

78

帖子

485

积分

版主

Rank: 7Rank: 7Rank: 7

发表于 2021-1-12 01:43:47 | 显示全部楼层 |阅读模式
本帖最后由 admin 于 2021-1-12 01:45 编辑

OpenHarmony介绍

OpenHarmony是HarmonyOS的开源版,由华为捐赠给开放原子开源基金会(OpenAtom Foundation)开源。第一个开源版本支持在128KB~128MB的设备上运行,欢迎参加开源社区一起持续演进。

代码仓库地址:https://openharmony.gitee.com



说明

当前的OpenHarmony源代码仅支持在Linux环境下编译,如果在Windows下使用,可能会出现异常。

例如,某些组件在下载安装时需要调用Linux命令来设置环境变量,如果在Windows环境下操作可能就会报错。遇到此问题时可以尝试先将hpm 的 shell改为第三方的shell,例如改为git的sh.exe,可通过执行以下命令修改shell:

hpm config set shellPath 'C:\Program Files\Git\bin\sh.exe'


源码获取概述

本文档将介绍如何获取HarmonyOS源码并说明HarmonyOS的源码目录结构。HarmonyOS的代码以组件的形式开放,开发者可以通过如下其中一种方式获取:

  • 获取方式1:从镜像站点下载压缩文件(推荐)
  • 获取方式2:从hpm网站组件式获取。通过HPM,查找满足需求的解决方案,挑选/裁剪组件后下载。
  • 获取方式3:用包管理器命令行工具获取。通过HPM的hpm-cli命令行工具,执行命令下载。
  • 获取方式4:从代码仓库获取。通过repo或git工具从代码仓库中下载。

[color=rgba(0, 0, 0, 0.9)]获取方式1:从镜像站点获取

为了获得更好的下载性能,您可以选择从以下站点的镜像库获取源码或者对应的解决方案。

表1 源码获取路径[td]

下载内容

版本信息

下载站点

SHA256校验码

全量代码

1.0

Hi3861解决方案(二进制)

1.0

Hi3518解决方案(二进制)

1.0

Hi3516解决方案(二进制)

1.0

RELEASE-NOTES

1.0

-




获取方式2:从HPM网站组件式获取
适用场景

对于刚接触HarmonyOS的新用户,希望能够参考一些示例解决方案从而进行快速开发。可以在HPM获取推荐的解决方案,以此为基础,增加或裁剪部分组件,快速定制系统。


操作步骤
  • 查找合适的解决方案组件包。
    • 打开包管理页面HPM,设定搜索的对象为“解决方案”,如下图所示。
    • 自搜索框输入关键字搜索,如"camera"。
    • 结果中显示匹配的解决方案,可以进一步根据组件类别等过滤条件(如:适配的开发板,内核)精确筛选。
    • 查找合适的解决方案,点击查看解决方案详情介绍。图1 包管理


  • 定制解决方案组件包。
    • 仔细阅读解决方案的说明,以了解该解决方案的使用场景、特性、使用方法以及如何进行定制化,如下图所示。
    • 点击「直接下载」,将解决方案下载到本地。
    • 点击「定制组件」,将对解决方案包含的组件进行定制。
    图2 解决方案示例

  • 定制组件。
    • 进入解决方案定制页面,如下图所示。
    • 通过关闭开关移除可选组件,或者通过“添加组件”增加新的组件。
    • 在右边填写您的项目基本信息,包括名称、版本、描述等信息。
    • 点击“下载”,系统会根据您的选择,生成相应的HarmonyOS代码结构文件(如name.zip),保存至本地文件。
      • 下载的压缩文件并未包含源代码的原始文件,可以在IDE中导入下载的压缩包,解压后执行hpm的安装指令(hpm install),才会将所需要的组件全部下载下来。
      • 下载的组件存在工程目录下的ohos_bundles文件夹中。图3 组件定制





获取方式3:用包管理器命令行获取
适用场景
  • 用户已通过组件式获取的方式获取源码,需要对源码中的某个或某几个组件进行独立升级。
  • 用户已经比较熟悉HarmonyOS系统的开发并且熟练掌握命令行工具的使用。

准备

通过命令行获取,需要先安装Node.js和hpm命令行工具,安装步骤如下:

  • 安装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


[color=rgba(0, 0, 0, 0.9)]操作

接下来将组件添加到开发项目中,假定要获取的组件名为@ohos/demo,具体操作如下:

  • 进入开发目录,执行如下命令,采用默认模板创建一个开发项目。
    • hpm init -t default
  • 执行如下命令,安装组件@ohos/demo
    • hpm install @ohos/demo
  • 工具会自动从服务器下载所有依赖的组件,下载成功则显示Install successfully!
    • $ hpm install @ohos/demo
    • Requesting: https://url.foo.bar/hpm/registry/api/bundles/@ohos/demo
    • downloading @ohos/demo
    • Requesting: https://lfcontentcenterdev....../bMAlLrYISLqdUTFFFCdgzA.tgz
    • extract D:\demo\ohos_bundles\@ohos\demo\@ohos-demo-1.0.7.tgz
    • Install successfully!


[color=rgba(0, 0, 0, 0.9)]获取方式4:从代码仓库获取
[color=rgba(0, 0, 0, 0.9)]适用场景
  • 基于HarmonyOS的稳定分支建立自己的基线,分发下游客户。

  • 已经完成自身软件与HarmonyOS的对接,需要进行HarmonyOS官方认证。

  • 芯片/模组/app通过HarmonyOS官方认证后,贡献代码到HarmonyOS生态。

  • 修复HarmonyOS的问题。

  • 学习HarmonyOS的源码。



[color=rgba(0, 0, 0, 0.9)]准备
  • 注册码云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/repo
    • chmod a+x /usr/local/bin/repo
    • pip install -i https://pypi.tuna.tsinghua.edu.cn/simple requests


[color=rgba(0, 0, 0, 0.9)]操作

方式一(推荐):通过repo下载



  • repo init -u https://gitee.com/openharmony/manifest.git -b master --no-repo-verify
  • repo sync -c

方式二:通过git clone单个代码仓库

进入代码仓库主页,选择需要克隆的代码仓库,执行命令,如:



  • git clone https://gitee.com/openharmony/manifest.git -b master

[color=rgba(0, 0, 0, 0.9)]源码目录简介

下表是HarmonyOS源码的目录及简单说明:

表2 源码目录的说明[td]

目录名

描述

applications

应用程序样例,包括wifi-iot,camera等

base

基础软件服务子系统集&硬件服务子系统集

build

组件化编译、构建和配置脚本

docs

说明文档

domains

增强软件服务子系统集

drivers

驱动子系统

foundation

系统基础能力子系统集

kernel

内核子系统

prebuilts

编译器及工具链子系统

test

测试子系统

third_party

开源第三方组件

utils

常用的工具集

vendor

厂商提供的软件

build.py

编译脚本文件





回复

使用道具 举报

6

主题

8

帖子

36

积分

新手上路

Rank: 1

发表于 2021-1-12 11:02:14 | 显示全部楼层
表格有点乱
回复

使用道具 举报

0

主题

3

帖子

8

积分

审核员

Rank: 7Rank: 7Rank: 7

发表于 2021-1-12 11:32:31 | 显示全部楼层
回复

使用道具 举报

0

主题

14

帖子

55

积分

注册会员

Rank: 2

发表于 2021-1-13 05:30:50 | 显示全部楼层
多想china版 :)
回复

使用道具 举报

30

主题

131

帖子

670

积分

高级会员

Rank: 4

发表于 2021-1-17 16:36:07 | 显示全部楼层
放原子开源基金会(OpenAtom Foundation)开源,什么样一个机构
回复

使用道具 举报

0

主题

14

帖子

137

积分

注册会员

Rank: 2

发表于 2021-3-5 12:08:29 | 显示全部楼层
学习学习
回复

使用道具 举报

0

主题

2

帖子

1106

积分

金牌会员

Rank: 6Rank: 6

发表于 2021-3-9 09:07:05 | 显示全部楼层
谢谢分享 收藏了
回复

使用道具 举报

1

主题

15

帖子

852

积分

高级会员

Rank: 4

发表于 2021-6-4 11:05:27 | 显示全部楼层
很赞,收场
回复

使用道具 举报

0

主题

3

帖子

23

积分

新手上路

Rank: 1

发表于 2021-6-4 16:56:06 | 显示全部楼层
有虚拟机可以安装鸿蒙吗
回复

使用道具 举报

0

主题

3

帖子

13

积分

新手上路

Rank: 1

发表于 2021-6-5 11:59:16 | 显示全部楼层
谢谢分享  很干货
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|鸿蒙学堂

GMT+8, 2021-7-31 07:53 , Processed in 0.045598 second(s), 24 queries .

Powered by Discuz! X3.4

Copyright © 2019-2021, 鸿蒙学堂.

快速回复 返回顶部 返回列表