Aperture插件与EXC_BAD_ACCESS崩溃

rao*_*son 6 xcode plugins objective-c

我尝试运行Aperture SDK 2.1附带的SampleFTPExportPlugIn.我不得不调整基本SDK设置和手动PluginManager.Framework文件夹复制到/库/框架,描述在这里.

所有编译和Aperture 3.2.3现在提供菜单项File/Export/FTP.

选择"FTP"导出方法并因此触发插件代码时,Aperture会发生EXC_BAD_ACCESS崩溃.当尝试获取对以下内容的引用时,非法内存访问在initWithAPIManager类的方法中发生:SampleFTPExportPlugInApertureExportManager

   _exportManager = [[_apiManager apiForProtocol:@protocol(ApertureExportManager)] retain];
Run Code Online (Sandbox Code Playgroud)

这是在Aperture将控制交给插件后执行的第二行,似乎是ApertureExportManager在任何Aperture插件中获取引用的标准方法(我还没有找到任何替代方法来实现相同的功能)任何地方).

这里的堆栈跟踪:

Exception Type:  EXC_BAD_ACCESS (SIGSEGV)
Exception Codes: 0x000000000000000d, 0x0000000000000000

VM Regions Near 0:
--> 
    __TEXT                 0000000100000000-0000000100798000 [ 7776K] r-x/rwx SM=COW  /Applications/Aperture.app/Contents/MacOS/Aperture

Application Specific Information:
objc_msgSend() selector name: class
objc[3000]: garbage collection is OFF
Performing @selector(a_exportPlugIn:) from sender NSMenuItem 0x111d2a540

Thread 0 Crashed:: Dispatch queue: com.apple.main-thread
0   libobjc.A.dylib                 0x00007fff8711c090 objc_msgSend_vtable2 + 16
1   com.apple.CoreFoundation        0x00007fff8381e25f -[__NSCFString isEqualToString:] + 63
2   com.apple.PluginManager         0x0000000101211218 -[PROBundleHandler apiForProtocol:] + 109
3   com.apple.CoreFoundation        0x00007fff83852f4c __invoking___ + 140
4   com.apple.CoreFoundation        0x00007fff83852de4 -[NSInvocation invoke] + 132
5   com.apple.CoreFoundation        0x00007fff83852fb4 -[NSInvocation invokeWithTarget:] + 52
6   com.apple.CoreFoundation        0x00007fff8384dff4 ___forwarding___ + 756
7   com.apple.CoreFoundation        0x00007fff8384dc88 _CF_forwarding_prep_0 + 232
8   com.apple.SampleFTPExportPlugIn 0x000000012c0d5361 -[SampleFTPExportPlugIn initWithAPIManager:] + 209
9   com.apple.PluginManager         0x000000010120c6fa -[PROConcretePlugIn plugInInstance] + 212
Run Code Online (Sandbox Code Playgroud)

我阅读了有关Objective-C内存管理的所有内容,但无法理解它.我在网上找到的所有其他示例都是这样实现的,所以我想我有一个兼容性问题,我的Aperture/Library安装中缺少一些东西.我该如何缩小问题范围?

编辑:

问题似乎是传入apiManager.方法签名是:

     - (id)initWithAPIManager:(id<PROAPIAccessing>)apiManager
Run Code Online (Sandbox Code Playgroud)

然后将该参数分配给我们的内部参考:

  _apiManager = apiManager;
Run Code Online (Sandbox Code Playgroud)

然而传入的实际类是PROPlugInFirewall,因为此输出reviels:

   NSLog(@"_apiManager class is: %@", [[_apiManager class] description]);
Run Code Online (Sandbox Code Playgroud)

然后调用respondsToSelector导致同样的崩溃,尽管这个方法是从NSObject继承的.

   if ( [_apiManager respondsToSelector:@selector(apiForProtocol:)] ) {
        NSLog(@"responds");
    }
Run Code Online (Sandbox Code Playgroud)

_apiManager本身将自身描述为:

   _apiManager is: <[*<PROBundleHandler: 0x14d79130> (PROAPIAccessing)*]>
Run Code Online (Sandbox Code Playgroud)

还是卡住......

编辑:

所以看起来Aperture正在传递一个指向天堂的指针...但是,我刚从Apple网页安装了另一个插件,安装程序和所有内容.那个在调用时也失败了......

May*_*tin 2

  • 下载FXPlug 1.2.5 SDK
  • 打开安装包的内容
  • 将 PluginManager.framework 复制到 /Library/Frameworks

您的插件现在应该可以工作了!

FXPlug SDK(2.2/2.4) 中较新版本的 PluginManager.framework 会导致此崩溃。

使用 Xcode 4.5 在 10.8 上测试