Cocoapods Packager + Xcode14 适配

Cocoapods Packager + Xcode14 适配

升级到Xcode14之后,苹果做了一些优化,但有部分优化Cocoapods Packager并没有适配,会导致无法顺利打出包或者打出的包有兼容性问题。

前往 Github repo,会发现Cocoapods Packager的最新发布 1.5.0 在 2016 年, 最新的代码提交在 2019 年,这就是痛苦根源。

Xcode14 的架构变更适配

Xcode 14 Release Notes可以看到,目前最低支持版本已经提到了 iOS11,并且自然而然的移除了无法升级到 iOS11 的armv7, armv7s, and i386。

这导致了我们打包遇到的第一个问题:架构报错。

error: The armv7 architecture is deprecated. You should update your ARCHS build setting to remove the armv7 architecture. (in target 'Pods-packager' from project 'Pods')
error: The armv7s architecture is deprecated. You should update your ARCHS build setting to remove the armv7s architecture. (in target 'Pods-packager' from project 'Pods')

报错原因已经在前文提到了,那么参照参考1,通过修改builder.rb 的 ARCHS 为
$(ARCHS_STANDARD)成功修复了Xcode14打已经被移除的armv7(s)失败的问题,果然这个16年就停更的东西有点没力气了啊

eee5d57a857718e16693569764a4472c.png

修改后应为:

def ios_build_options
   "ARCHS=\'$(ARCHS_STANDARD)\' OTHER_CFLAGS=\'-fembed-bitcode -Qunused-arguments'"
end

需要留意的是,参考中builder.rb 的路径为
/Library/Ruby/Gems/2.6.0/gems/cocoapods-packager-1.5.0/lib/cocoapods-packager
但在我本机的路径实际为
/usr/local/lib/ruby/gems/2.6.0/gems/cocoapods-packager-1.5.0/lib/cocoapods-packager
安装路径不同,供参考

Xcode12 的 arm64 冲突适配

如果是没有修改过这块,仅仅使用ARCHS_STANDARD架构有可能还是无法成功出包的,原因在于,Xcode12 开始增加了 M1 设备支持,模拟器和真机同时包含arm64架构,导致了架构冲突。

对于这一点,参照参考 2能修复Xcode12之后arm64冲突的问题,修改方式为修改cocoapods-packager的源码中的pod_utils.rb文件(文件路径前文已有,不再重复):

    unless static_installer.nil?
      static_installer.pods_project.targets.each do |target|
        target.build_configurations.each do |config|
          config.build_settings['CLANG_MODULES_AUTOLINK'] = 'NO'
          config.build_settings['GCC_GENERATE_DEBUGGING_SYMBOLS'] = 'NO'
          config.build_settings['EXCLUDED_ARCHS[sdk=iphonesimulator*]'] = 'arm64' // <-- inserted here
        end
      end
      static_installer.pods_project.save
    end

看着其实就是设置模拟器不打 arm64 架构,保持只有一份 arm64 架构?

Xcode 14 打的 sdk 适配 Xcode13

按照前文一路解决下来,已经可以通过packager漂亮的打出一个 framework 了。不过,还有一个隐藏问题可能在后面暴露出来:Xcode 14 打的 sdk ,在 Xcode13 上继承会报错,提示大量的找不到_objc_msgSend$xxx。

Undefined symbol: _objc_msgSend$stringByTrimmingCharactersInSet:
Undefined symbol: _objc_msgSendSsize
Undefined symbol: _objc_msgSend$drawInRect:
// balabala

这又是一个坑,不过幸运的是,对于我们来说,这是目前需要解决的最后一个坑了。

这一个特性更新隐藏在WWDC2022 Session 110363 Improve app size and runtime performance中,在 Xcode14 的 release note 里没有提及,更隐蔽了。

特性内容是优化 objc_msgSend,提取为一个 helper func(selector stub),通过这一优化减少了 2%的二进制大小,并且这一优化在 Xcode14 自动启用


截屏.png
DraggedImage-1.png

虽然这一优化并不限制你的ipa部署版本,在旧版本系统也能使用,但是它没有说的是,这一优化只有 Xcode14+才能理解,这就导致了Xcode 14 打的 sdk , Xcode13无法理解,于是就有了前面提到的找不到_objc_msgSend$xxx。

对于这点,网上的大家说的修改OTHER_CFLAGS,添加-fno-objc-msgsend-selector-stubs参数,关闭这项优化。
这个原理是对的,但是实际验证下来都无效,packager打出来的 sdk Xcode13 还是无法理解。
结合这里和 参考1,基本确定主要原因是 packager 就没有使用那些参数去打包,而是用自己的 build options,所以在 pod spec 里配置的都是无法影响打包结果

因此需要在前面的 参考 1 基础上,再追加-fno-objc-msgsend-selector-stubs

所以对于 Xcode14 的最终修改是,修改 builder.rb 的ios_build_options如下:

def ios_build_options
   "ARCHS=\'$(ARCHS_STANDARD)\' OTHER_CFLAGS=\'-fembed-bitcode -Qunused-arguments -fno-objc-msgsend-selector-stubs\'"
end

All done, 完美✿✿ヽ(°▽°)ノ✿

更多

在进行前面疑难杂症攻关过程中,发现了fastlane 的一个 action create_xcframework,可以用来构建xcframework。那么,是不是可以用 fastlane 来打包 sdk 呢?有没有相关资源呢?

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

推荐阅读更多精彩内容