Flutter引擎源码分析(一) - 编译调试

flutter.png

一、下载引擎代码

(一)工具准备

depot_tools 套件包含许多git工作流增强工具,通过这些工具可以协同工作,任何人都可以熟练地处理Chromium的代码库
[图片上传失败...(image-7f507-1654869060068)]

  • github配置SSH

    提示问题

    git@github.com: Permission denied (publickey).

    可能key过期,也就是配置到github上的公钥过期

    也可能本地的私钥删除

    这种情况下,重新配置,easy

    1. cd ~/.ssh

    2. vi known_hosts

    3. 删除里面的github部分

    4. ssh-keygen -t rsa -b 4096 -C "email@qq.com" [生成一对新的公钥,私钥]

    5. vi config

       Host *
      
         AddKeysToAgent yes
         UseKeychain yes
         IdentityFile ~/.ssh/自己生成的私钥文件
      
    6. ssh-add -K ~/.ssh/自己生成的私钥文件 (默认id_rsa, 避免与其他平台冲突,最好自己起一个) [将您的SSH私钥添加到ssh-agent并将密码短语存储在钥匙串中]

    7. pbcopy < ~/.ssh/id_rsa.pub (或者自己起的名字)

    8. 登录个人github,头像 - Settings - SSH and GPG Keys - NEW SSH Key - 粘贴

  • brew 安装 ant工具

brew install ant

  • brew 安装 ninja

brew install ninja

(二)下载引擎

  • 新建flutter_engine目录(注意:路径不能有中文)

    mkdir flutter_engine

  • 创建gclient文件 (通过gclient下载源码)

    touch .glient

solutions = [
{
   "managed": False,
   "name": "src/flutter",
   "url": "git@github.com:flutter/engine.git@caaafc5604ee9172293eb84a381be6aadd660317",
    "custom_deps": {},
    "deps_file": "DEPS",
    "safesync_url": "",
}, 
]

执行 glient sync

cat ~/Developer/kit/flutter/bin/internal/engine.versio
caaafc5604ee9172293eb84a381be6aadd660317

用这个结果去替换 .glient 中 'flutter/engine.git@' 后面的长字符串, 此处用的是 3.0.1 (版本一致)

image.png

(三)升级操作

如果已有engine源码,但是版本不一致,通过配置 sync来解决 (M1的话还是再等等吧,目前3.0.1稳定版 M1还做不到完美engine调试)

  • cat ~/Developer/kit/flutter/bin/internal/engine.versio 拿到当前flutter引擎版本号
  • 粘贴覆盖 .glient 文件 'flutter/engine.git@'后面的长串部分
  • 进入到 flutter_engine/src/flutter 目录,
  • 执行一次 git pull
  • 然后 git reset --hard caaafc5604ee9172293eb84a381be6aadd660317
  • 回到 flutter_engine目录,gclient sync --with_branch_heads --with_tags --verbose

二、编译引擎代码

image.png

ninja 构建

#构建iOS设备使用的引擎
#真机debug版本
./gn --ios --unoptimized
#真机release版本
./gn --ios -unoptimized --runtime-mode=release
#模拟器版本
./gn --ios -simulator --unoptimized
#主机端(Mac)构建  --  热重载
./gn --unoptimized

flutter_engine/src/out 目录下产生4个文件

image.png

进入到 flutter_engine/src/out目录,使用ninja编译工程 (相当耗时....)

ninja -C host_debug_unopt && ninja -C ios_debug_sim_unopt && ninja -C
ios_debug_unopt && ninja -C ios_release_unopt

三、配置iOS项目代码

创建一个flutter项目,运行
xcode启动ios项目 - Runner
配置脚本

temp.png

执行脚本,build 脚本target


temp.png

四、Xcode编译项目能debug关键

iOS Runner项目 build 启动, 启动阶段,操作pause programexecution

temp1.png

lldb设置符号断点

temp.png

键入c 回车,跳过,正常启动
继续键入c,跳过汇编

temp.png

temp.png

look, 调试的log信息出来了...

打开ninja编译到 模拟器xcode工程

open flutter_engine/src/out/ios_debug_sim_unopt/flutter_engine.xcodeproj


temp.png

之前调试是在 创建的fluuter项目/ios工程Runner里添加的调试log

vs

同时在 flutter_engine源码编译的 模拟器项目里 找到了修改的调试log代码

肯定的是,编译调试engine的目的是达到了,接下来就是搞清楚为什么了

out/engine编译的模拟器xcode项目里 touchesBegan 目的代码部分, command + shift + J,导航侧栏显示文件 - finder查看

image.png

最终调试改动的代码 存在与 flutter_engine/src/flutter/shell/platform/darwin/ios/framework/Source/FlutterViewController.mm

VS

而engine源码编译的xcode工程 在
flutter_engine/src/out/ios_debug_sim_unopt

至此,也就是,刚才,engine通过同一份源码,编译出4种xcode工程,源码共享一份

为什么能关联起来,Flutter引擎源码分析(二) - channel原生通信

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,504评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,434评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,089评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,378评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,472评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,506评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,519评论 3 413
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,292评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,738评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,022评论 2 329
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,194评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,873评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,536评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,162评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,413评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,075评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,080评论 2 352

推荐阅读更多精彩内容