HarmonyOS单模块编译与源码导读 原创 精华

开源夏德旺
发布于 2021-2-5 00:00
浏览
13收藏

我这里以3518的开发板为例进行讲解,3516的也是通用的。

下面是之前全量编译的脚本

python build.py ipcamera_hi3518ev300 -b debug

HarmonyOS最初只能支持全量编译的方式,这种方式最大的弊端就是我们在系统源码上开发一个用户态程序,每次都需要全量编译好系统之后进行镜像的烧录,每次编译加烧录少说需要15分钟时间,对于我们开发测试及其消耗时间,试想下每次就是想加入一行log调试下这么费劲会多么麻烦。

还好,后面随着HarmonyOS的源码更新,开始支持用户态程序的单模块编译了,编译的脚本如下:

python build.py ipcamera_hi3518ev300 -T //applications/sample/camera/app:camera_app

这里以单独编译HarmonyOS自带的HelloWorld项目为例,这个-T参数非常重要,它就是代表单模块编译的,//applications/sample/camera/app只的要编译的模块的绝对路径,camera_app为要编译的模块名称。

这里先结合HarmonyOS源码讲下-T参数的由来,如果各位是通过下载压缩包的方式下载的官方的code1.0的源码压缩包解压的话,肯定是不支持该参数的,也就是说不支持单模块编译。下面来看下该参数是在什么时候更新到源码库的吧,首先我们去gitee上找到编译构建框架所在的代码仓,如下图

HarmonyOS单模块编译与源码导读-鸿蒙开发者社区

然后,我们查看该仓库下的commit记录,然后就可以找到下面的关键记录

HarmonyOS单模块编译与源码导读-鸿蒙开发者社区

看commit的日志已经很明确了这里加入了单模块构建,下面我们打开该commit记录仔细看看具体修改了什么

HarmonyOS单模块编译与源码导读-鸿蒙开发者社区

看到这里,大家就知道这个-T参数怎么来的了吧,为了让你的代码支持单模块编译,赶紧去git更新下代码吧,如果下载code1.0离线代码的也不用着急,可以直接把build仓下的最新代码全部下载下来替换之前的build仓即可。

下面再来讲讲前面单模块编译最后面的那个模块名称camera_app怎么来的吧,关于用户态程序如何编译的,建议大家好好看看官方源码的“用户程序框架”仓下的介绍,绝对会受益良多。我这里挑重点讲,首先是在//build/lite/product/ipcamera_hi3518ev300.json这个文件中进行了用户程序编译的相关配置,可以理解为一个配置清单,告诉系统哪些用户态程序需要参与编译。我们可以在里面找到如下配置

    {
      "name": "applications",
      "component": [
        { "name": "camera", "dir": "//applications/sample/camera/app:camera_app", "features":[] },
        { "name": "communication", "dir": "//applications/sample/camera/communication:sample", "features":[] }
      ]
    },

看到dir后面的配置就自然会联想到我们之前-T后面的参数为何要使用它了吧,那么最后的冒号后面的camera_app参数又从哪里来呢?

那么这里首先要对linux下的c语言编译有一定了解才行了,大家如果看不懂后面的可以先去补习下Makefile和gn的知识。

这里每个用户态程序都是通过gn文件配置进行编译的,我们先在源码目录下找到这个模块路径,如下图

HarmonyOS单模块编译与源码导读-鸿蒙开发者社区

哈哈,大家可能会疑惑我咋是用idea在看代码,因为本人电脑没安装source insight,加上本人最精通的技术是java和Android,所以使用idea习惯了,一个快速检索功能足够我阅读系统源码了。

这里我们看到了BUILD.gn脚本,打开瞅瞅,可以看到如下关键代码,

lite_component("camera_app") {
    target_type = "executable"

    features = [
        ":hello_world",
    ]
}

之前调用的参数模块名称camera_app就是在这里配置的。

下面简单列举一个gn的一个标准的helloworld用法,如下

executable("hello_world") {
  sources = [
    "hello_world.c",
  ]
}

后面我在讲如何创建一个独立的用户态程序会编写这个gn文件和json文件。本篇已经够长了,就放在下一篇博客讲解了。

看系统源码确实还是很有意思的,只奈工作太忙没有时间看。。。

©著作权归作者所有,如需转载,请注明出处,否则将追究法律责任
已于2021-2-5 00:11:08修改
9
收藏 13
回复
举报
3条回复
按时间正序
/
按时间倒序
angel
angel

可以这次跟这老师好好学习一波源码

回复
2021-2-5 09:38:20
红叶亦知秋
红叶亦知秋

可以的,跟的看看源码

回复
2021-2-5 10:13:05
软通田可辉
软通田可辉

好文,学习了

回复
2021-2-23 14:13:34
回复
    相关推荐