Manipulação de eventos “Open Document” (ODOD) no Snow Leopard
-
22-07-2019 - |
Pergunta
Eu tenho o código em meu aplicativo que resposta a eventos (ODOD) "Abrir documento". No Mac OS X Tiger e Leopard, este código fina funciona:
- (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;
}
}
}
}
No Mac OS X Snow Leopard, no entanto, este código não funciona. Aqui é um lixo de um AppleEvent de um sistema Leopard:
{ 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
}
}
}
}
Aqui é um lixo de um AppleEvent de um sistema Snow Leopard:
{ 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.......
}
}
}
}
O tipo 'alis' foi substituído pelo novo tipo Snow Leopard "bookmark". Como posso modificar este código para que ele:
a) testes para e alças do tipo novo 'bmrk', ou seja, obter o caminho absoluto do arquivo
b) continua a trabalhar no Tiger e Leopard
?
Ou é a alguma maneira eu posso dizer o sistema operacional que eu ainda quero eventos ODOD que contêm estruturas 'alis'?
Solução
Os "dados dos favoritos" incluídos aqui podem ser manipulados usando algum novo CFURL e / ou APIs NSURL que foram introduzidas no Snow Leopard. + [NSURL URLByResolvingBookmarkData: opções: relativeToURL: bookmarkDataIsStale: erro] é a API NSURL você pode usar para resolver os dados de marcadores incluídos no descritor de evento.
Você também pode ser capaz de coagir o descritor para um alias, utilizando o método coerceToDescriptorType:
e manipulá-lo dessa maneira, pensei que não está documentado ou não Snow Leopard inclui um built-in manipulador de coerção para isso (com certeza parece que deveria embora).
Quanto à compatibilidade Tiger / Leopard, você nunca vai ser passado de dados de marcadores de cada um desses sistemas, assim que chamar o novo método NSURL (s) não deve ser um problema, uma vez que a caminho de código nunca será seguido no sistemas mais antigos.
BTW, o arquivo de cabeçalho "AEDataModel.h" contém constantes simbólicas para os quatro códigos de char que você está usando, assim você pode usar typeAlias
vez de 'alis'
, typeBookmark
vez de 'bmrk'
, e assim por diante. Que tende a tornar o código um pouco mais legível e permite que o compilador protegê-lo contra erros de digitação e tal.