为了提升生产力,最近我租来了一台 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。
MacBook 还能租的?