HarmonyOS技术社区 · 2020年11月27日

鸿蒙构建系统——gn官方FAQ翻译,以及gn官方文档分享

GN FAQ 翻译

(PS:花了将近半个小时,把GN的官方FAQ翻译了一遍,有错漏之处欢迎大家指正。)

GN 的文档在哪里?

GN有大量的内置的帮助文档,所以你可以运行gn help命令查阅,但是你同样可以在“参考页面”(PS:附件文档包中的gn-reference.pdf)查阅全部帮助文档。你同样可以查阅“快速入门指南”(PS:附件文档包中的gn-quick_start.pdf)和“语言和操作细节”(PS:附件文档包中的gn-language.pdf)。

我可以生成XCode或者Visual Studio项目吗?

你可以用一次构建(PS: gn是两阶段构建的工具)为XCode,Visual Studio,QTCreator和Eclipse生成带有文件列表和目标的骨架(或包装)项目,但是使用 Ninja执行实际的构建(PS:第二次构建)。你不能像使用GYP cloud那样生成真的看起来和这些工具直接创建的一样的项目。

了解详细内容,请运行gn help gen。

我如何生成一般的构建变种(build variants)?

在GN中,参数在构建目录中,而不是在全局环境中。要编辑你的out/Default构建目录下的参数,执行:

gn args out/Default

(PS: 这个命令会打开一个编辑器(默认是vim),查看的话用这个命令:gn args out/Default --list)

你可以在这个文件中设置变量:

默认是debug构建,改为release构建,添加:is_debug = false
默认是静态编译,改为组件编译,添加:is_component_build = true
默认是developer构建,改为offical构建,添加:is_offical_build = true
默认是chromium构建,改为Chrome构建,设置:is_chrome_build = true


我如何进行交叉编译?

GN有健壮的交叉编译和一次构建生成多个架构文件的支持。

详细信息,请查阅GN交叉编译文档(cross_compile.md)。

我可以控制默认编译什么目标吗?

可以!你可以在顶层目录的构建文件中创建一个叫做“default”的组目标,例如“//:default”,GN将会告诉ninja默认编译这个目标,而不是编译所有的目标。

有关于GN的公开演示讲解吗?

这里有一个最近的,2015年的。从那之后,除了将gn变为一个独立的代码仓之外,没有什么太大的变化,所以仍然是相关的。

-------------------------------- 分割线 --------------------------------

以下是我补充的两个自问自答 ;-)

为什么翻译这个FAQ?

学习知识讲究追本溯源,具体到学习软件开发,往往就是查阅官方文档和代码。

鸿蒙使用gn(Generate Ninja)作为构建系统,而 gn 是由谷歌开发的,目前能够找到的文档基本上都是英文的。

FAQ是几个文档中间比较短小的一篇,同时也是初学者容易有疑问的地方。

为什么搬运这些资料?

gn项目官网:https://gn.googlesource.com/gn/

由于国内部分网络条件下无法访问 googlesource.com ,这给广大开发者查阅gn官方文档带了很大的不便。

本帖附件的几个资料包分别是:

  1. gn源码包:gn.zip ;
  2. gn文档包:gn-docs.zip ;
  3. 谷歌大佬关于GN分享的PPT:Using GN build.pdf

欢迎大家下载查阅。

【获取原文资源包】

作者:许思维

想了解更多内容,请访问: 51CTO和华为官方战略合作共建的鸿蒙技术社区https://harmonyos.51cto.com#jssq

推荐阅读
关注数
3010
内容数
446
华为鸿蒙相关技术,活动及资讯,欢迎关注及加入创作
目录
极术微信服务号
关注极术微信号
实时接收点赞提醒和评论通知
安谋科技学堂公众号
关注安谋科技学堂
实时获取安谋科技及 Arm 教学资源
安谋科技招聘公众号
关注安谋科技招聘
实时获取安谋科技中国职位信息