flutter engine framework斷點(diǎn)調(diào)試

編譯framework

https://github.com/flutter/engine/blob/master/CONTRIBUTING.md

編譯release

debug

ninja -C out/ios_debug_unopt && ninja -C out/host_debug_unopt

release

$ ninja -C out/ios_release_unopt && ninja -C out/host_release_unopt 

指定engine版本運(yùn)行 flutter run



$../../bin/flutter run --local-engine-src-path /Users/boo/Documents/engine/engine/src/out/ios_debug  --local-engine=ios_debug_unopt

$  flutter run --local-engine-src-path /Users/boo/Documents/engine/engine/src  --local-engine=ios_debug_unopt

flutter packages get --local-engine-src-path /Users/boo/Documents/engine/engine/src  --local-engine=ios_debug_sim_unopt -d XXXX

//運(yùn)行flutter
$ flutter run --local-engine-src-path /Users/boo/Documents/engine/engine/src  --local-engine=ios_debug_sim_unopt -d XXXX

修改完源代碼添加runscript

image.png
cd /Users/boo/Documents/engine/engine/src

ninja -C out/ios_debug_unopt && ninja -C out/host_debug_unopt

cp -rf /Users/boo/Documents/engine/engine/src/out/ios_debug_unopt/Flutter.framework  /Users/boo/Documents/demo/flutterbeta/flutterOnExistApp_SelfEngine/Flutter/engine

作用是重新編譯framework使其生效
注意這里的debug认境,release较剃,或模擬器目錄要設(shè)正確,否則編譯不過挽霉,下次生效

打開

設(shè)置xcode斷點(diǎn)

image.png
initWithFlutterAssets:dartMain:packages:
hellobooob

修改資源加載路徑

https://github.com/flutter/engine/blob/f4aadb11cf132c13c16c8f8011680d3f9cc7d505/shell/platform/darwin/ios/framework/Source/FlutterDartProject.mm

修復(fù)循環(huán)引用

image.png
image.png

常見錯(cuò)誤

image.png
Undefined symbols for architecture x86_64:
  "_OBJC_CLASS_$_FlutterAppDelegate", referenced from:
      _OBJC_CLASS_$_AppDelegate in AppDelegate.o
  "_OBJC_CLASS_$_FlutterMethodChannel", referenced from:
      objc-class-ref in libpackage_info.a(PackageInfoPlugin.o)
  "_OBJC_METACLASS_$_FlutterAppDelegate", referenced from:
      _OBJC_METACLASS_$_AppDelegate in AppDelegate.o
  "_FlutterMethodNotImplemented", referenced from:
      -[FLTPackageInfoPlugin handleMethodCall:result:] in libpackage_info.a(PackageInfoPlugin.o)
  "_OBJC_CLASS_$_FlutterViewController", referenced from:
      objc-class-ref in ViewController.o
ld: symbol(s) not found for architecture x86_64
clang: error: linker command failed with exit code 1 (use -v to see invocation)

flutter.framework編譯版本問題翩蘸,需要重新編譯或使用舊的替換先


[VERBOSE-1:callback_cache.cc(132)] Could not parse callback cache, aborting restore
2018-10-18 16:47:21.434650+0800 flutterOnExistApp[33371:13930425] [VERBOSE-2:shell.cc(181)] Dart Error: Can't load Kernel binary: Invalid kernel binary format version.
2018-10-18 16:47:21.434875+0800 flutterOnExistApp[33371:13930425] [VERBOSE-2:engine.cc(157)] Could not prepare to run the isolate.
2018-10-18 16:47:21.435723+0800 flutterOnExistApp[33371:13930425] [VERBOSE-2:engine.cc(116)] Engine not prepare and launch isolate.
2018-10-18 16:47:21.436000+0800 flutterOnExistApp[33371:13930425] [VERBOSE-2:FlutterViewController.mm(462)] Could not launch engine with configuration.
2018-10-18 16:47:21.554817+0800 flutterOnExistApp[33371:13930431] flutter: Observatory listening on http://127.0.0.1:54038/

還是flutter.framework 編譯版本問


出現(xiàn)錯(cuò)誤
You must specify --local-engine if you are using a locally built engine.

image.png

提示出錯(cuò)了所意,engin少了一個(gè)e 應(yīng)該是engine

$ flutter packages get --local-engine=ios_debug_unopt

$ flutter run  --local-engine=ios_debug_unopt

問題

image.png
Unable to detect local Flutter engine build directory.
Either specify a dependency_override for the sky_engine package in your pubspec.yaml and
ensure --package-root is set if necessary, or set the $FLUTTER_ENGINE environment variable, or
use --local-engine-src-path to specify the path to the root of your flutter/engine repository.
Failed to package /Users/boo/Documents/demo/flutterbeta/flutterOnExistApp_SelfEngine/myflutter.
Command /bin/sh failed with exit code 255

重新執(zhí)行

pod update

其他不通過情況再嘗試使用

flutter packages get

flutter run


問題:

2018-10-18 21:24:03.474221+0800 flutterOnExistApp[54577:15146469] [VERBOSE-2:shell.cc(182)] Dart Error: Can't load Kernel binary: Invalid kernel binary format version.
2018-10-18 21:24:03.474442+0800 flutterOnExistApp[54577:15146469] [VERBOSE-2:engine.cc(174)] Could not prepare to run the isolate.
2018-10-18 21:24:03.474760+0800 flutterOnExistApp[54577:15146469] [VERBOSE-2:engine.cc(121)] Engine not prepare and launch isolate.
2018-10-18 21:24:03.475266+0800 flutterOnExistApp[54577:15146469] [VERBOSE-2:FlutterViewController.mm(486)] Could not launch engine with configuration.
2018-10-18 21:24:03.522773+0800 flutterOnExistApp[54577:15146476] flutter: Observatory listening on http://127.0.0.1:56060/

flutter 和 engine版本不一致

需要更新到一致狀態(tài)
使用命令

flutter upgrade

建了個(gè)qq群,大家有問題可以繼續(xù)在里面討論 217429001

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末催首,一起剝皮案震驚了整個(gè)濱河市扶踊,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌郎任,老刑警劉巖秧耗,帶你破解...
    沈念sama閱讀 219,589評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異舶治,居然都是意外死亡分井,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,615評(píng)論 3 396
  • 文/潘曉璐 我一進(jìn)店門霉猛,熙熙樓的掌柜王于貴愁眉苦臉地迎上來尺锚,“玉大人,你說我怎么就攤上這事惜浅√北纾” “怎么了?”我有些...
    開封第一講書人閱讀 165,933評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長伐厌。 經(jīng)常有香客問我阅仔,道長,這世上最難降的妖魔是什么弧械? 我笑而不...
    開封第一講書人閱讀 58,976評(píng)論 1 295
  • 正文 為了忘掉前任八酒,我火速辦了婚禮,結(jié)果婚禮上刃唐,老公的妹妹穿的比我還像新娘羞迷。我一直安慰自己,他們只是感情好画饥,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,999評(píng)論 6 393
  • 文/花漫 我一把揭開白布衔瓮。 她就那樣靜靜地躺著,像睡著了一般抖甘。 火紅的嫁衣襯著肌膚如雪热鞍。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,775評(píng)論 1 307
  • 那天衔彻,我揣著相機(jī)與錄音薇宠,去河邊找鬼。 笑死艰额,一個(gè)胖子當(dāng)著我的面吹牛澄港,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播柄沮,決...
    沈念sama閱讀 40,474評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼回梧,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼!你這毒婦竟也來了祖搓?” 一聲冷哼從身側(cè)響起狱意,我...
    開封第一講書人閱讀 39,359評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎拯欧,沒想到半個(gè)月后详囤,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,854評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡哈扮,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,007評(píng)論 3 338
  • 正文 我和宋清朗相戀三年纬纪,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了蚓再。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片滑肉。...
    茶點(diǎn)故事閱讀 40,146評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖摘仅,靈堂內(nèi)的尸體忽然破棺而出靶庙,到底是詐尸還是另有隱情,我是刑警寧澤娃属,帶...
    沈念sama閱讀 35,826評(píng)論 5 346
  • 正文 年R本政府宣布六荒,位于F島的核電站护姆,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏掏击。R本人自食惡果不足惜卵皂,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,484評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望砚亭。 院中可真熱鬧灯变,春花似錦、人聲如沸捅膘。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,029評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽寻仗。三九已至刃泌,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間署尤,已是汗流浹背耙替。 一陣腳步聲響...
    開封第一講書人閱讀 33,153評(píng)論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留曹体,地道東北人林艘。 一個(gè)月前我還...
    沈念sama閱讀 48,420評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像混坞,于是被迫代替她去往敵國和親狐援。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,107評(píng)論 2 356

推薦閱讀更多精彩內(nèi)容