Pau*_*cas 1 macos cocoa osx-snow-leopard
我的应用程序中有代码响应"Open Document"(odoc)事件.在Mac OS X Tiger和Leopard中,此代码可以正常工作:
- (void) handleOpenDocumentEvent:
(NSAppleEventDescriptor*)event
withReplyEvent:(NSAppleEventDescriptor*)replyEvent
{
NSAppleEventDescriptor const *const dirObj =
[event descriptorForKeyword:keyDirectObject];
DescType const dirObjType = [dirObj descriptorType];
if ( dirObjType == 'alis' ) {
//
// Open a single file.
//
NSData const *const data = [dirObj data];
AliasHandle const fileHandle =
reinterpret_cast<AliasHandle>( ::NewHandle( [data length] ) );
if ( fileHandle ) {
[data getBytes:*fileHandle];
err = [self queueFile:fileHandle fromSender:senderSig];
}
} else if ( dirObjType == 'list' ) {
//
// Open multiple files.
//
AliasHandle fileHandle =
reinterpret_cast<AliasHandle>( ::NewHandle( 0 ) );
if ( fileHandle ) {
int const numItems = [dirObj numberOfItems];
for ( int i = 1; i <= numItems; ++i ) {
NSData const *const data = [[dirObj descriptorAtIndex:i] data];
::SetHandleSize( reinterpret_cast<Handle>( fileHandle ), [data length] );
if ( (err = ::MemError()) != noErr )
break;
[data getBytes:*fileHandle];
err = [self queueFile:fileHandle fromSender:senderSig];
if ( err != noErr )
break;
}
}
}
}
Run Code Online (Sandbox Code Playgroud)
但是,在Mac OS X Snow Leopard下,此代码不起作用.这是来自Leopard系统的AppleEvent转储:
{ 1 } 'aevt': aevt/odoc (i386){
return id: 1012269061 (0x3c560005)
transaction id: 0 (0x0)
interaction level: 112 (0x70)
reply required: 0 (0x0)
remote: 0 (0x0)
for recording: 0 (0x0)
reply port: 150031 (0x24a0f)
target:
{ 1 } 'psn ': 8 bytes {
{ 0x0, 0x655655 } (iPhoto)
}
fEventSourcePSN: { 0x0,0x655655 } (iPhoto)
optional attributes:
< empty record >
event data:
{ 1 } 'aevt': - 1 items {
key '----' -
{ 1 } 'list': - 1 elements {
{ 1 } 'alis': 326 bytes {
/Users/pjl/Pictures/IMG_8501.JPG
}
}
}
}
Run Code Online (Sandbox Code Playgroud)
以下是来自Snow Leopard系统的AppleEvent转储:
{ 1 } 'aevt': aevt/odoc (i386){
return id: 5173 (0x1435)
transaction id: 0 (0x0)
interaction level: 112 (0x70)
reply required: 0 (0x0)
remote: 0 (0x0)
for recording: 0 (0x0)
reply port: 81695 (0x13f1f)
target:
{ 1 } 'psn ': 8 bytes {
{ 0x0, 0x17c17c } (iPhoto)
}
fEventSourcePSN: { 0x0,0x17c17c } (iPhoto)
optional attributes:
< empty record >
event data:
{ 1 } 'aevt': - 1 items {
key '----' -
{ 1 } 'list': - 1 elements {
{ 1 } 'bmrk': 944 bytes {
000: 626f 6f6b b003 0000 0000 0110 1000 0000 book............
001: c002 0000 0500 0000 0101 0000 5573 6572 ............User
002: 7300 0000 0300 0000 0101 0000 706a 6c00 s...........pjl.
003: 0800 0000 0101 0000 5069 6374 7572 6573 ........Pictures
004: 0e00 0000 0101 0000 6950 686f 746f 204c ........iPhoto L
005: 6962 7261 7279 0000 0800 0000 0101 0000 ibrary..........
006: 4d6f 6469 6669 6564 0400 0000 0101 0000 Modified........
007: 3230 3037 0b00 0000 0101 0000 4a75 6e20 2007........Jun
008: 392c 2032 3030 3700 0c00 0000 0101 0000 9, 2007.........
009: 494d 475f 3633 3837 2e6a 7067 2000 0000 IMG_6387.jpg ...
....
058: 0000 0000 30f0 0000 3002 0000 0000 0000 ....0...0.......
}
}
}
}
Run Code Online (Sandbox Code Playgroud)
'alis'类型已被新的Snow Leopard"书签"类型所取代.如何修改此代码以便它:
a)测试并处理新的'bmrk'类型,即获取文件的绝对路径
b)继续使用Tiger和Leopard
?
或者我可以通过某种方式告诉操作系统我仍然想要包含'alis'结构的odoc事件?
此处包含的"书签数据"可以使用Snow Leopard中引入的一些新的CFURL和/或NSURL API进行处理. + [NSURL URLByResolvingBookmarkData:options:relativeToURL:bookmarkDataIsStale:error]是可用于解析事件描述符中包含的书签数据的NSURL API.
您也可以使用该coerceToDescriptorType:方法将描述符强制转换为别名并以这种方式处理它,认为没有记录Snow Leopard是否包含内置的强制处理程序(看起来确实应该如此).
至于Tiger/Leopard的兼容性,你永远不会在这两个系统上传递书签数据,所以调用新的NSURL方法不应该是一个问题,因为在旧系统上永远不会遵循该代码路径.
顺便说一句,头文件"AEDataModel.h"包含您正在使用的四个字符代码的符号常量,因此您可以使用typeAlias而不是代替'alis',typeBookmark而不是'bmrk'等等.这往往会使代码更具可读性,并让编译器保护您免受打字错误等.
| 归档时间: |
|
| 查看次数: |
960 次 |
| 最近记录: |