我的Mac应用程序链接了一个非系统提供的框架Foo.framework。我在XCode中添加了对框架的引用,应用程序构建得很好。我还有一个将框架复制到输出框架文件夹(MyApp.app/Contents/ Frameworks )的规则。然而,在运行时,二进制文件在~/Library/Frameworks中查找框架,应用程序无法加载。
otool -l MyApp.app还告诉我,它正在/Users//Library/Frameworks中寻找框架。
谁能解释一下为什么会发生这种情况,以及让应用程序在应用程序包的Frameworks文件夹中显示的正确方法是什么?
我的变通方法是在mach-o二进制文件中包含一个使用install_name_tool更改路径的自定义脚本,但我确信有一种干净的方法可以做到这一点。
发布于 2009-08-20 06:18:45
你在正确的轨道上。
这是因为在OS上,当创建"install_name"时,它会被记录在库中。然后,该install_name被复制到与其链接的任何应用程序。
解决这个问题的“最佳”方法是修改框架的源代码,以便在构建框架时设置-install_name链接器标志。
然而,这通常是不可能的,要么是因为你没有源代码,要么是因为框架中有大量的autoconf东西,这使得它几乎是不可能的。在这种情况下,可以使用带有-id标志的install_name_tool来更改库中记录的install_name。
那么,说了这么多,你要把它改成什么呢?
@executable_path/../Frameworks/Foo.framework/Foo (或其他任何名称)
因此,从包含Foo.framework的目录中:
install_name_tool -id @executable_path/../Frameworks/Foo.framework/Foo Foo.framework/Foo在运行时,加载器会将@executable_path解析为应用程序可执行文件的路径。显然,您还需要设置一个Copy Files构建阶段,将框架复制到应用程序包的framework文件夹中。
在库已经链接到应用程序之后,您也可以使用带有-change标志的install_name_tool来更改库的install_name,但这显然不是最好的做法。在链接之前修复它。
https://stackoverflow.com/questions/1304239
复制相似问题