qidao123.com技术社区-IT企服评测·应用市场

标题: 鸿蒙北向开发 ubuntu20.04 gn + ninja环境傻瓜式搭建闭坑指南 [打印本页]

作者: 莱莱    时间: 2024-8-12 11:03
标题: 鸿蒙北向开发 ubuntu20.04 gn + ninja环境傻瓜式搭建闭坑指南
ninja跟gn都是比较时髦的东西,由歪果仁维护,假如走下载源码并编译这种流程的话需要走github跟google官网下载,国内的用网环境相信各位傻瓜都知道,github跟google这几年基本是属于连不上的状态,好在你看的鸿蒙项目跟国内的一些软件大厂已经帮你爬过梯子了,ninja工具跟gn工具已经被他们搬到国内来了
一.安装ninja
关于ninja的介绍网上还是比较多的,这里就不多讲了.贴一个写的不错的帖子各位可以去看看
ninja
相信你看过上面的帖子,对ninja基本上算是有个不错的概念认知,各个社区都集成了ninja,那么为什么各人都集成ninja呢?ninja专注于构建速度,最关键的是ninja可以配合cmake一起利用且ninja极其的小巧轻巧
ninja的安装比较简单
  1. $ sudo apt install ninja-build
复制代码
 利用如下指令查看安装的ninja版本,能查出版本即证明ninja安装成功
  1. $ ninja --version
复制代码

二.安装gn,源码编译
gn的安装稍微有点麻烦,gn需要前置clang,我当前的假造机是ubuntu20.04lts版本

这个版本的ubuntu apt源中配置了clang,直接通过如下指令下载
  1. sudo apt install clang
复制代码
因为我这台假造机已经安装过了clang,如下提示表示我的clang已经是最新版本了

利用
  1. $ clang --version
复制代码
查看当前clang版本

gn的源码编译需要clang-8以上的支持,各位根据本身当前体系环境善用百度安装clang-8以上版本
下载gn源码
gn的源码可以从多个地方下载,google官方的跟GitHub上有fork的仓库的需要科学上网,唯一能用的就是鸿蒙提供的Gitee的仓库
鸿蒙gitee
但是鸿蒙gitee下载的有点标题,下载下来后编译出来的测试步伐有标题,我就没有继续了,具体什么缘故因由还不太清楚

刚好我手里有开源鸿蒙4.1主干版本,我从主干上复制出来了gn源码,现已上传到csdn下载
gn 源码下载
将源码复制到ubuntu体系里面
进入gn目次
  1. $ cd gn
  2. $ python build/gen.py
  3. $ ninja -C out
复制代码

如上表示编译执行成功,跑一下测试代码
  1. $ ./out/gn_unittests
复制代码

如上表示测试成功
编译成功后,将gn复制到/usr/bin目次下
  1. $ sudo cp ./out/gn /usr/bin
复制代码

/usr/bin 目次就是体系默认添加环境变量的目次,将gn放到这个目次后可以在任一新建终端测试gn是否可用
新建终端:输入 gn help

如上表示gn安装成功
三.简单的测试
gn测试命令

ninja命令

建议初学者以gn仓为例举行学习,首先辈入gn/examples/simple_build文件夹,该文件夹下BUILD.GN形貌了一个最基本的C++文件的编译配置,如下可执行步伐hello依赖了动态库文件hello_shared以及静态库hello_static。
  1. # Copyright 2014 The Chromium Authors. All rights reserved.
  2. # Use of this source code is governed by a BSD-style license that can be
  3. # found in the LICENSE file.
  4. executable("hello") {
  5.   sources = [ "hello.cc" ]
  6.   deps = [
  7.     ":hello_shared",
  8.     ":hello_static",
  9.   ]
  10. }
  11. shared_library("hello_shared") {
  12.   sources = [
  13.     "hello_shared.cc",
  14.     "hello_shared.h",
  15.   ]
  16.   defines = [ "HELLO_SHARED_IMPLEMENTATION" ]
  17. }
  18. static_library("hello_static") {
  19.   sources = [
  20.     "hello_static.cc",
  21.     "hello_static.h",
  22.   ]
  23. }
复制代码
在目次下执行gn gen -C out同时进入out文件夹下,分别执行以下命令。

​ gn refs列出了哪些目的依赖了目的//:hello
_shared,从上面可以看出目的//:hello
依赖了目的//:hello
_shared,从GN配置文件也可以看出来。


下面是ninja命令测试 在simple_build目次下执行如下指令

第一个hello world
进入out目次,运行hello


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 qidao123.com技术社区-IT企服评测·应用市场 (https://dis.qidao123.com/) Powered by Discuz! X3.4