4

我正在对Vienna进行扩展,以增加第三方编写 Objective-C 插件的能力,但是只有在 64 位模式下运行时我才会遇到一些运行时链接器问题(在 32 位模式下一切似乎都可以正常工作) . 我的插件 SynkPlugin 由 Vienna.app 中的以下代码加载:

NSArray * bundlePaths = [NSBundle pathsForResourcesOfType:@"bundle" inDirectory:[[Preferences standardPreferences] pluginsFolder]];
NSEnumerator * enumerator = [bundlePaths objectEnumerator];
NSString * bundlePath;
NSMutableArray * plugins = [NSMutableArray array];
while ( (bundlePath = [enumerator nextObject]) != nil )
{
    NSBundle * pluginBundle = [NSBundle bundleWithPath:bundlePath];
    Class principalClass = [pluginBundle principalClass];
    id <ViennaPlugin, NSObject> plugin = [[principalClass alloc] init];
    [plugins addObject:plugin];
    [plugin release];
    NSLog(@"Loaded plugin %@ [main class: %@]", bundlePath, principalClass);
}

在控制台输出中,我收到以下错误消息:

2010-07-09 08:55:40.128 Vienna[74065:a0f] Error loading /Users/dcrosta/Library/Application Support/Vienna/PlugIns/SynkPlugin.bundle/Contents/MacOS/SynkPlugin: dlopen(/Users/dcrosta/Library/Application Support/Vienna/PlugIns/SynkPlugin.bundle/Contents/MacOS/SynkPlugin, 265): Symbol not found: _OBJC_CLASS_$_Article
  Referenced from: /Users/dcrosta/Library/Application Support/Vienna/PlugIns/SynkPlugin.bundle/Contents/MacOS/SynkPlugin
  Expected in: flat namespace
  in /Users/dcrosta/Library/Application Support/Vienna/PlugIns/SynkPlugin.bundle/Contents/MacOS/SynkPlugin

此错误仅在以 64 位模式运行时发生,而不是在 32 位模式下运行。Vienna 和 SynkPlugin 都使用“标准 32/64 通用”设置进行编译,并且 SynkPlugin 具有附加的链接器标志“-undefined dynamic_lookup”,据我了解,它允许它链接到在 Vienna.app 中找到的类而无需将这些类的代码编译成自己的二进制文件。

Stack Overflow 上对这个错误的其他引用与 iPhone/iPod Touch 和 iPad 之间的 UIKit 差异有关——在这些情况下,框架实际上缺少 iPhone/iPod Touch 上的类。在我的例子中,我确信 Vienna.app 在它的某个地方有 Article 类,因为它是由与 32 位版本相同的代码构建的。

有没有人见过这样的错误?对在哪里寻找更多信息有什么建议吗?谢谢。

4

1 回答 1

1

在 Vienna 目标的构建设置中,在GCC 4.2 - Code Generation下取消选中Symbols Hidden by Default ( GCC_SYMBOLS_PRIVATE_EXTERN)。

于 2010-07-09T14:46:52.097 回答