BearPi-HM_Nano 开发板源码获取 原创
BearPi-HM_Nano源码获取
BearPi-HM_Nano源码获取概述
本文档将介绍如何获取BearPi-HM_Nano的OpenHarmony源码,并说明源码目录结构。OpenHarmony的代码以组件的形式开放,开发者可以通过如下其中一种方式获取:
- 获取方式1:从hpm网站组件式获取。通过HPM,查找满足需求的解决方案,挑选/裁剪组件后下载。
- 获取方式2:用包管理器命令行工具获取。通过HPM的hpm-cli命令行工具,执行命令下载。
- 获取方式3:从代码仓库获取。通过git工具从代码仓库中下载。
获取方式1:从hpm网站组件式获取
适用场景
对于刚接触OpenHarmony的新用户,希望能够参考一些示例解决方案从而进行快速开发。可以在HPM获取推荐的解决方案,以此为基础,增加或裁剪部分组件,快速定制系统。
准备
-
安装Node.js
推荐安装 Node.js 12.x (包含 npm 6.14.4)或更高版本 (推荐 12.13.0+)。可先通过
nodo -v
命令先查询是否已经安装Node.js- 下载Nodejs
wget https://nodejs.org/dist/v14.15.1/node-v14.15.1-linux-x64.tar.xz
- 解压
tar -xvf node-v14.15.1-linux-x64.tar.xz -C ~/
- 使用 ln 命令来设置软连接
sudo ln -s ~/node-v14.15.1-linux-x64/bin/npm /usr/bin/ sudo ln -s ~/node-v14.15.1-linux-x64/bin/node /usr/bin/
- 下载Nodejs
-
安装hpm命令行工具
npm install -g @ohos/hpm-cli sudo ln -s ~/node-v14.15.1-linux-x64/bin/hpm /usr/bin
下载源码
-
下载解决方案组件包。
-
打开包管理页面HPM,设定搜索的对象为"解决方案"。
-
点击小熊派BearPi-HM Nano开发板解决方案,查看解决方案详情介绍。
-
-
安装解决方案组件包。
- 将下载的解决方案组件包压缩包复制到Linux服务器上。
- 解压压缩包
unzip demo.zip
- 在demo文件夹目录下执行
hpm install
命令安装组件hpm install
-
定制组件(可选)。
- 进入解决方案定制页面,如下图所示。
- 通过关闭开关移除可选组件,或者通过“添加组件”增加新的组件。
- 在右边填写您的项目基本信息,包括名称、版本、描述等信息。
- 点击“下载“,系统会根据您的选择,生成相应的OpenHarmony代码结构文件(如name.zip),保存至本地文件。
-
下载的压缩文件并未包含源代码的原始文件,可以在IDE中导入下载的压缩包,解压后执行hpm的安装指令(hpm install),才会将所需要的组件全部下载下来。
-
下载的组件存在工程目录下的ohos_bundles文件夹中。
图 3 组件定制<a name=“fig2448349749”></a>
-
编译源码
执行以下命令编译源码
hpm dist
获取方式2:用包管理器命令行获取
适用场景
- 用户已通过组件式获取的方式获取源码,需要对源码中的某个或某几个组件进行独立升级。
- 用户已经比较熟悉OpenHarmony系统的开发并且熟练掌握命令行工具的使用。
准备
-
安装Node.js
推荐安装 Node.js 12.x (包含 npm 6.14.4)或更高版本 (推荐 12.13.0+)。可先通过
nodo -v
命令先查询是否已经安装Node.js- 下载Nodejs
wget https://nodejs.org/dist/v14.15.1/node-v14.15.1-linux-x64.tar.xz
- 解压
tar -xvf node-v14.15.1-linux-x64.tar.xz -C ~/
- 使用 ln 命令来设置软连接
sudo ln -s ~/node-v14.15.1-linux-x64/bin/npm /usr/bin/ sudo ln -s ~/node-v14.15.1-linux-x64/bin/node /usr/bin/
- 下载Nodejs
-
安装hpm命令行工具
npm install -g @ohos/hpm-cli sudo ln -s ~/node-v14.15.1-linux-x64/bin/hpm /usr/bin
下载源码
接下来将组件添加到开发项目中,具体操作如下:
-
进入开发目录,执行如下命令,采用默认模板创建一个开发项目。
hpm init -t default
-
执行如下命令,安装组件@bearpi/bearpi_hm_nano
hpm i @bearpi/bearpi_hm_nano
-
工具会自动从服务器下载所有依赖的组件,下载成功则显示Install successfully!
$ hpm install @bearpi/bearpi_hm_nano Requesting: https://url.foo.bar/hpm/registry/api/bundles/@bearpi/bearpi_hm_nano downloading @bearpi/bearpi_hm_nano Requesting: https://lfcontentcenterdev....../bMAlLrYISLqdUTFFFCdgzA.tgz Install successfully!
编译源码
执行以下命令编译源码
hpm dist
获取方式3:从代码仓库获取
适用场景
-
基于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 clone单个代码仓库
进入代码仓库主页:https://gitee.com/bearpi/bearpi-hm_nano,选择需要克隆的代码仓库,执行命令,如:
git clone https://gitee.com/bearpi/bearpi-hm_nano.git -b master
编译源码
执行以下命令编译源码
python build.py BearPi-HM_Nano
源码目录简介
下表是OpenHarmony源码的目录及简单说明:
表 2 源码目录的说明
目录名 | 描述 |
---|---|
applications | 应用程序样例,包括wifi-iot,camera等 |
base | 基础软件服务子系统集&硬件服务子系统集 |
build | 组件化编译、构建和配置脚本 |
domains | 增强软件服务子系统集 |
drivers | 驱动子系统 |
foundation | 系统基础能力子系统集 |
kernel | 内核子系统 |
prebuilts | 编译器及工具链子系统 |
test | 测试子系统 |
third_party | 开源第三方组件 |
utils | 常用的工具集 |
vendor | 厂商提供的软件 |
build.py | 编译脚本文件 |