当前位置: 首页 > news >正文

OpenHarmony构建脚本build.sh解析

文章目录

    • 引言
    • 构建脚本的架构与实现
      • 1. 脚本的核心职责与架构设计
      • 2. 环境检查与配置
        • Shell环境验证
        • 源码根目录定位
      • 3. 工具链配置详解
        • Python环境设置
        • Node.js配置
      • 4. 依赖管理系统
        • ohpm初始化
        • SDK构建机制
      • 5. 构建执行与结果处理
        • 工具链完整性检查
        • 构建系统
        • 结果反馈

引言

​ 在OpenHarmony生态系统中,构建系统是开发流程的核心枢纽。build.sh脚本作为构建过程的统一入口,不仅简化了复杂的构建流程,更确保了跨平台开发环境的一致性。本文将从架构设计到实现细节,全面解析这个关键脚本的工作原理,帮助开发者深入理解OpenHarmony构建系统的内部机制。

构建脚本的架构与实现

1. 脚本的核心职责与架构设计

build.sh是OpenHarmony构建系统的入口点,承担着多重关键职责:

功能模块核心职责实现机制
环境管理确保构建环境一致性Shell环境检查、工具链配置
路径解析定位关键目录递归查找.gn文件
工具链管理提供标准化工具预置Python、Node.js等
依赖处理管理SDK和组件ohpm初始化、SDK构建
构建调度执行实际构建调用hb或entry.py
结果反馈提供构建反馈彩色输出、状态码处理

脚本采用分层架构设计:

环境准备
工具链配置
依赖管理
构建执行
结果反馈

环境准备工具链配置依赖管理构建执行结果反馈

2. 环境检查与配置

Shell环境验证
function check_shell_environment() {case $(uname -s) in Linux)shell_result=$(/bin/sh -c 'echo ${BASH_VERSION}')if [ -z "${shell_result}" ]; thenecho "请切换至Bash环境"fi;;# 其他平台处理esac
}

关键点

  • Bash必要性:依赖pushd/popd等Bash特有命令
  • Ubuntu适配:通过sudo dpkg-reconfigure dash切换默认Shell
  • 跨平台支持:目前主要支持Linux,macOS支持在开发中
源码根目录定位
while [[ ! -f "${SOURCE_ROOT_DIR}/.gn" ]]; doSOURCE_ROOT_DIR=$(dirname "${SOURCE_ROOT_DIR}")[[ "$SOURCE_ROOT_DIR" == "/" ]] && exit 1
done

.gn文件作为GN构建系统的标志,其定位原理:

  1. 从脚本所在目录开始向上递归
  2. 找到包含.gn文件的目录即为根目录
  3. 防止无限递归的安全检查

3. 工具链配置详解

Python环境设置
PYTHON3_DIR=${SOURCE_ROOT_DIR}/prebuilts/python/${HOST_DIR}/current/
PYTHON3=${PYTHON3_DIR}/bin/python3
[[ ! -f "$PYTHON3" ]] && echo "请执行prebuilts_download.sh" && exit 1
ln -sf "$PYTHON3" "${PYTHON3_DIR}/bin/python" # 创建兼容链接

设计理念

  • 版本隔离:使用项目预置Python而非系统Python
  • 兼容性处理:创建python→python3的软链接
  • 错误预防:提前检查避免构建中途失败
Node.js配置
EXPECTED_NODE_VERSION="14.21.1"
export PATH=${SOURCE_ROOT_DIR}/prebuilts/nodejs/node-v${EXPECTED_NODE_VERSION}/bin:$PATH# 严格版本检查
[[ "$(node -v)" != "v$EXPECTED_NODE_VERSION" ]] && exit 1# 国内镜像加速
npm config set registry https://repo.huaweicloud.com/repository/npm/
npm config set @ohos:registry https://repo.harmonyos.com/npm/

优化策略

  • 版本锁定:确保所有开发者环境一致
  • 镜像加速:使用国内源解决下载慢问题
  • 安全平衡strict_ssl false解决企业内网证书问题

4. 依赖管理系统

ohpm初始化
function init_ohpm() {# 下载命令行工具wget https://.../ohcommandline-tools-linux.zip# 初始化配置ohpm config set registry https://repo.harmonyos.com/ohpm/# 设置hvigor环境mkdir -p $HOME/.hvigor/wrapper/toolsecho '{"dependencies": {"pnpm": "7.30.0"}}' > package.jsonnpm install
}

ohpm核心功能

  1. 鸿蒙组件管理:专用OpenHarmony包仓库
  2. 混合生态支持:兼容npm包管理体系
  3. 安全扫描:对鸿蒙组件进行安全检查

hvigor的作用:作为前端构建系统,管理JS/TS项目的构建生命周期,使用pnpm提供高效的依赖管理。

SDK构建机制
function build_sdk() {./build.py --product-name ohos-sdk --gn-args sdk_platform=linux# 处理SDK包unzip "native-linux*.zip"api_version=$(grep apiVersion oh-uni-package.json | awk '{print $2}')mkdir -p $api_version# 组织SDK目录结构
}

SDK预构建原因

  • 工具链依赖:编译需要SDK中的编译器和库文件
  • 效率优化:避免重复构建耗时任务
  • 版本一致性:确保团队使用相同开发环境

触发条件

# 当预编译SDK不存在时自动构建
if [[ ! -d "${PREBUILT_SDK_DIR}" && "$*" != *ohos-sdk* ]]; thenbuild_sdk
fi

5. 构建执行与结果处理

工具链完整性检查
${PYTHON3} ${SOURCE_ROOT_DIR}/build/scripts/tools_checker.py

检查内容

  1. GN/Ninja等基础工具存在性
  2. 工具版本兼容性验证
  3. 环境变量配置正确性
  4. 磁盘空间充足性检查
构建系统
if grep -q "using_hb_new=false" <<< "$@"; then# 旧构建系统${PYTHON3} ${SOURCE_ROOT_DIR}/build/scripts/entry.py $@
else# 新构建系统${PYTHON3} ${SOURCE_ROOT_DIR}/build/hb/main.py build $@
fi

系统对比

特性传统系统(entry.py)现代系统(hb)
抽象层级底层(直接操作GN)高层(任务抽象)
使用难度高(需了解GN语法)低(简单命令)
产品配置手动管理内置产品管理
增量构建基础支持优化支持
未来支持维护模式持续增强
结果反馈
if [[ $? -ne 0 ]]; thenecho -e "\033[31m=====构建失败=====\033[0m"exit 1
elseecho -e "\033[32m=====构建成功=====\033[0m"
fi# 构建后处理扩展点
#(
#  source build_updater_package.sh
#)
http://www.lqws.cn/news/520093.html

相关文章:

  • 【MongoDB】MongoDB从零开始详细教程 核心概念与原理 环境搭建 基础操作
  • 使用EasyExcel处理动态表头数据导入
  • AWS WebRTC:通过shell实现多进程启动viewer
  • Object.assign()
  • 获取YARN application 应用列表的几种方法
  • 2025年Java后端最新面试场景题 + 八股文高频面试题
  • Dagster数据管道构建指南:I/O管理与数据库连接实践
  • React Native【实战范例】账号管理(含转换分组列表数据的封装,分组折叠的实现,账号的增删改查,表单校验等)
  • rules写成动态
  • syncthing忘记密码怎么办(Mac版)?
  • 成都芯谷金融中心·文化科技园打造文化科技高地
  • 微服务思想与C++服务化框架
  • 跟着AI学习C#之项目实践Day7
  • sentinel 自定义 dashboard 用户名密码
  • 第⼀个与⼤模型交互的应⽤
  • Swagger 在 Spring Boot 中的详细使用指南
  • thinkphp8之文件上传
  • 用户体验驱动的3D设计:从功能实现到情感共鸣的设计升级
  • 融合聚类与分类的退役锂电智能分选技术:助力新能源汽车产业可持续发展
  • JVM调优实战 Day 6:JVM性能监控工具实战
  • 数据结构 顺序表与链表
  • python的易家宜超市云购物系统
  • webman 利用tcp 做服务端 对接物联网
  • 使用 Spread.net将 Excel 中的文本拆分为多段
  • 注解+AOP+自动配置实现自定义starter
  • Java8 Stream流:Stream流的思想和获取Stream流
  • 深入浅出:RocketMQ与Kafka的双剑合璧,实现高可用与高吞吐
  • 服务器不支持PUT,DELETE 的解决方案
  • python爬虫框架scrapy学习记录
  • 打造属于你的AI智能体,从数据开始 —— 使用 Bright Data MCP+Trae快速构建垂直智能体