我的Mac OS应用程序与非系统提供的框架Foo.framework链接。我在XCode中添加了对框架的引用,并且应用程序构建正常。我还有一个规则将框架复制到输出Frameworks文件夹(MyApp.app/Contents/Frameworks)。但是,在运行时,二进制文件正在〜/ Library / Frameworks中查找框架,并且应用程序无法加载。
otool -l MyApp.app还告诉我它正在/ Users // Library / Frameworks中寻找框架。
有人可以解释为什么会发生这种情况,以及在应用程序包的Frameworks文件夹中查看应用程序的正确方法是什么?
我的hacky解决方法是使用install_name_tool包含一个自定义脚本来更改mach-o二进制文件中的路径,但我确信有一种干净的方法可以执行此操作。
答案 0 :(得分:7)
你走在正确的轨道上。
这是因为在OS X上创建时"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解析为应用程序可执行文件的路径。显然,您还需要设置“复制文件”构建阶段,以将框架复制到应用程序包的Framework文件夹中。
您还可以将install_name_tool
与-change标志一起使用,以便在库已经链接到应用程序之后更改它的install_name,但这显然不是最理想的。在链接之前修复它。