解决「KeychainAccess.framework: bundle format is ambiguous」的问题

为了提升生产力,最近我租来了一台 MacBook Pro MJLT2,于是花了一点点时间重新设置了自己的生产环境。大多数东西都很快设置成功了,但是在构建自己的一个私用 Mac App 的时候却出了问题,Xcode 给的出错信息是:

KeychainAccess.framework: bundle format is ambiguous (could be app or framework)

于是我根据这个「bundle format is ambiguous (could be app or framework)」去搜索问题,搜到了来自官方的 Technical Note TN2206 macOS Code Signing In Depth。其中有这么一条:

Perhaps a framework was copied incorrectly so the symlinks it contained were converted to normal files.

简单的说,如果 Framework 里面的文件引用,如果不是符号链接的,而是转成了普通文件,就会出错。我去检查了一下这个 KeychainAccess.framework,它的目录结构果然有问题。所有的文件都被重复复制了一份,而不是正常的 Current -> A 这样的结构。我尝试手动把文件给重新符号链接了一次,问题解决。

虽然问题解决了,但是为什么会发生这样的情况?之前好好的。

我尝试从 GitHub 上把 KeychainAccess 下载下来自己编译了一份,符号链接好好的,这意味着这个项目没问题啊。难道是 Carthage 的问题?也不见得…

就在我一筹莫展的时候,我发现了问题所在:carthage 默认使用了官方 pre-build 的 Binary,而不是手动构建,KeychainAccess 官方提供的 v3.1.1 的 Binary,果然有符号链接的问题。

那么以后要怎么避免这个问题?很简单,就是不要相信官方的包,在用 Carthage 的时候,始终使用 --no-use-binaries 这个参数来构建 Framework。

欢迎使用图拉鼎开发的产品

Manico - 快速启动和切换 App

高效率 App 启动与切换工具,使用它将加倍电脑日常使用的效率,免费下载体验。

1 Comment

Leave a Comment