2021-12-23 flutter module源码方式集成流程分析

官方文档
将 Flutter module 集成到 iOS 项目
https://flutter.cn/docs/development/add-to-app/ios/project-setup

  • 1、flutter pub get
    ->Flutter.framework
  • 2、pod install
    podhelper.rb->.ios下:Flutter.framework、 App.framework
  • 3、xcodebuild
    xcode_backend.sh->Debug-iphoneos目录下:App.framework、
    .ios下Flutter.framework

1、flutter pub get

(1)生成.ios

(1)这时候还没有App.framework , podspec文件是有了

(2)有engine,Flutter.framework。

(3)有插件列表 podspec FlutterPluginRegistrant.podspec,这时没有symlinks/plugins目录软链接

(4)导出当前的环境变量 flutter_export_environment.sh

(2)生成依赖列表

flutter-plugins-dependencies

image.png

2、pod install

执行 podHelper.rb 脚本

做2件事情:

(1)、 把这3个pod 引进native

    Flutter.framework               Flutter.podspec
    插件注册                        FlutterPluginRegistrant.podspec
   plugins下面的所有用到的插件
    App.framework                   flutter_commercial.podspec
       
  • 安装Flutter.framework
    拷贝ios-release版本
    /Volumes/huc/opt/fvm/versions/2.2.0/bin/cache/artifacts/engine/ios-release

  • 安装插件
    从flutter-plugins-dependencies列表,把依赖的插件从
    /opt/fvm/versions/2.2.0/.pub-cache
    拷贝一个快捷链接目录出来。
    然后pod依赖用本地path依赖。

  plugins_file = File.expand_path('.flutter-plugins-dependencies', flutter_application_path)
  plugin_pods = flutter_parse_dependencies_file_for_ios_plugin(plugins_file)
  plugin_pods.each do |plugin_hash|
    plugin_name = plugin_hash['name']
    plugin_path = plugin_hash['path']
    if (plugin_name && plugin_path)
      symlink = File.join(symlinks_dir, plugin_name)
      FileUtils.rm_f(symlink)
      File.symlink(plugin_path, symlink)
      pod plugin_name, :path => File.join(symlink, 'ios'), :inhibit_warnings => true
    end
  end
  • 安装App.framework
    生成一个默认的App.framework 16Kb 一行代码用来占位置

(2)、把一段脚本写进xcode 工程配置.xcodeproj

/Volumes/huc/opt/fvm/versions/2.2.0/packages/flutter_tools/bin/xcode_backend.sh build

      flutter_export_environment_path = File.join('${SRCROOT}', relative, 'flutter_export_environment.sh');
  script_phase :name => 'Run Flutter Build flutter_commercial Script',
    :script => "set -e\nset -u\nsource \"#{flutter_export_environment_path}\"\nexport VERBOSE_SCRIPT_LOGGING=1 && \"$FLUTTER_ROOT\"/packages/flutter_tools/bin/xcode_backend.sh build",
    :execution_position => :before_compile
    end

多了.symlinks 和App.framework,重新拷贝了Flutter.xcframework

image.png

(3) pod install生成

Pods-HouseCommercialCube-frameworks.sh

  install_framework "${PODS_ROOT}/../../flutter_commercial/.ios/Flutter/App.framework"
  install_framework "${PODS_XCFRAMEWORKS_BUILD_DIR}/Flutter/Flutter.framework"

3、run app

执行 xcode_backend.sh

/Volumes/huc/opt/fvm/versions/2.2.0/packages/flutter_tools/bin/xcode_backend.sh 

做3件事情:

(1) 不太懂

AppFrameworkInfo.plist

  if FLTAssetsPath=$(/usr/libexec/PlistBuddy -c "Print :FLTAssetsPath" "${derived_dir}/AppFrameworkInfo.plist" 2>/dev/null); then
    if [[ -n "$FLTAssetsPath" ]]; then
      assets_path="${FLTAssetsPath}"
    fi

assets_path 这个后面也没有人用啊!

(2)通过环境 CONFIGURATION 重新 拿到对应 debug/release/profile版本的 engine: Flutter.framework

放到.ios下面

  local derived_dir="${SOURCE_ROOT}/Flutter"
  if [[ -e "${project_path}/.ios" ]]; then
    derived_dir="${project_path}/.ios/Flutter"
  fi



  local framework_path="${FLUTTER_ROOT}/bin/cache/artifacts/engine/${artifact_variant}"
  local flutter_engine_flag=""
  local local_engine_flag=""
  local flutter_framework="${framework_path}/Flutter.xcframework"



  # TODO(jmagman): use assemble copied engine in add-to-app.
  if [[ -e "${project_path}/.ios" ]]; then
    RunCommand rm -rf -- "${derived_dir}/engine/Flutter.framework"
    RunCommand cp -r -- "${flutter_framework}" "${derived_dir}/engine"
  fi

.ios/Flutter/engine/Flutter.xcframework
编译前, 把这个下面添加一个空文件, engine被覆盖了,那么那个空文件就没了?

对比了一下大小。 release
debug 版本的Flutter.xcframework 255M
ios-release 1.03 GB

一开始是1.03G, run之后, 变成了255M
说明确实拷贝到这里了

(2) 编译App.framework 放到 BUILT_PRODUCTS_DIR 下面

.ios下面App.framework 没有变

   RunCommand "${FLUTTER_ROOT}/bin/flutter"                                \
    ${verbose_flag}                                                       \
    ${flutter_engine_flag}                                                \
    ${local_engine_flag}                                                  \
    assemble                                                              \
    --no-version-check                                                    \
    --output="${BUILT_PRODUCTS_DIR}/"                                     \
    ${performance_measurement_option}                                     \
    -dTargetPlatform=ios                                                  \
    -dTargetFile="${target_path}"                                         \
    -dBuildMode=${build_mode}                                             \
    -dIosArchs="${ARCHS}"                                                 \
    -dSdkRoot="${SDKROOT}"                                                \
    -dSplitDebugInfo="${SPLIT_DEBUG_INFO}"                                \
    -dTreeShakeIcons="${TREE_SHAKE_ICONS}"                                \
    -dTrackWidgetCreation="${TRACK_WIDGET_CREATION}"                      \
    -dDartObfuscation="${DART_OBFUSCAT

App.framework 61Mb
Flutter.framework 35Mb


♦ rm 
-rf -- 
/Volumes/huc/houseCommercial/flutter_commercial/
.ios/Flutter/engine/Flutter.framework

♦ cp -r -- /opt/fvm/versions/2.2.0
/bin/cache/artifacts/engine/ios/Flutter.xcframework /Volumes/huc/houseCommercial/flutter_commercial/
.ios/Flutter/engine

♦ /opt/fvm/versions/2.2.0/bin/flutter
 --verbose assemble 
 --no-version-check 

 --output=/Users/huchu/Library/Developer/Xcode/DerivedData/HouseCommercialCube-haouxiieutwwizfrzseumgibdjxb/Build/Products/Debug-iphoneos/ 

 -dTargetPlatform=ios 

 -dTargetFile=lib/main.dart 
 
 -dBuildMode=debug 

 -dIosArchs=arm64 

 -dSdkRoot=/Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS15.0.sdk 

 -dSplitDebugInfo= 

 -dTreeShakeIcons=false 

 -dTrackWidgetCreation=false 

 -dDartObfuscation=false 

 -dEnableBitcode= 

 -dCodesignIdentity=FD1A800911570C03E014A5628E4B5F87C416FC06 

 --ExtraGenSnapshotOptions= 

 --DartDefines= 

 --ExtraFrontEndOptions= 

 debug_ios_bundle_flutter_assets

(3)嵌入式库

"${PODS_ROOT}/Target Support Files/Pods-HouseCommercialCube/Pods-HouseCommercialCube-frameworks.sh"

if [[ "$CONFIGURATION" == "Debug" ]]; then
  ///其他动态库
  install_framework "${PODS_ROOT}/../../flutter_commercial/.ios/Flutter/App.framework"
  install_framework "${PODS_XCFRAMEWORKS_BUILD_DIR}/Flutter/Flutter.framework"
fi

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

推荐阅读更多精彩内容