From 4740388716dc49958b8fab291e44ea26f2bc1578 Mon Sep 17 00:00:00 2001 From: Kent Sutherland Date: Fri, 14 Feb 2003 09:16:41 +0000 Subject: [PATCH] Commented out some annoying error checking. --- ITAppleEventCenter.h | 3 ++ ITAppleEventCenter.m | 73 ++++++++++++++++++++++++++++++++++++++------ 2 files changed, 67 insertions(+), 9 deletions(-) diff --git a/ITAppleEventCenter.h b/ITAppleEventCenter.h index 189c0cc..a458d87 100755 --- a/ITAppleEventCenter.h +++ b/ITAppleEventCenter.h @@ -31,5 +31,8 @@ - (NSString *)sendAEWithRequestedArray:(NSArray *)array eventClass:(NSString*)eventClass eventID:(NSString*)eventID appPSN:(ProcessSerialNumber)psn; - (void)sendAEWithEventClass:(NSString*)eventClass eventID:(NSString*)eventID appPSN:(ProcessSerialNumber)psn; + +- (long)sendAEWithSendStringForNumber:(NSString*)string eventClass:(NSString*)eventClass eventID:(NSString*)eventID appPSN:(ProcessSerialNumber)psn; + - (void)printCarbonDesc:(AEDesc*)desc; @end diff --git a/ITAppleEventCenter.m b/ITAppleEventCenter.m index 11671b5..fa7dc28 100755 --- a/ITAppleEventCenter.m +++ b/ITAppleEventCenter.m @@ -95,7 +95,7 @@ static ITAppleEventCenter *_sharedAECenter = nil; if (err3) { NSLog(@"Error After AEGetParamPtr: %i", err3); } else { - _finalString = [[NSString stringWithCharacters:result length:charResultSize/sizeof(unichar)] copy]; + _finalString = [NSString stringWithCharacters:result length:charResultSize/sizeof(unichar)]; } } free(result); @@ -156,8 +156,6 @@ static ITAppleEventCenter *_sharedAECenter = nil; if (err3) { NSLog(@"Error After AEGetParamPtr: %i", err3); - } else { - NSLog(@"%i", result); } } } @@ -221,7 +219,7 @@ static ITAppleEventCenter *_sharedAECenter = nil; if (err3) { NSLog(@"Error After AEGetParamPtr: %i", err3); } else { - _finalString = [[NSString stringWithCharacters:result length:charResultSize/sizeof(unichar)] copy]; + _finalString = [NSString stringWithCharacters:result length:charResultSize/sizeof(unichar)]; } } free(result); @@ -282,8 +280,6 @@ static ITAppleEventCenter *_sharedAECenter = nil; if (err3) { NSLog(@"Error After AEGetParamPtr: %i", err3); - } else { - NSLog(@"%i", result); } } } @@ -355,7 +351,7 @@ static ITAppleEventCenter *_sharedAECenter = nil; if (err3) { NSLog(@"Error After AEGetParamPtr: %i", err3); } else { - _finalString = [[NSString stringWithCharacters:result length:charResultSize/sizeof(unichar)] copy]; + _finalString = [NSString stringWithCharacters:result length:charResultSize/sizeof(unichar)]; } } free(result); @@ -382,10 +378,10 @@ static ITAppleEventCenter *_sharedAECenter = nil; } - (void)printCarbonDesc:(AEDesc*)desc { - Handle xx; + /*Handle xx; AEPrintDescToHandle(desc,&xx); NSLog(@"Handle: %s", *xx); - DisposeHandle(xx); + DisposeHandle(xx);*/ } @@ -439,4 +435,63 @@ static ITAppleEventCenter *_sharedAECenter = nil; return result; } +- (long)sendAEWithSendStringForNumber:(NSString*)string eventClass:(NSString*)eventClass eventID:(NSString*)eventID appPSN:(ProcessSerialNumber)psn +{ + //Add error checking... + AEEventClass eClass = *((unsigned long*)[eventClass UTF8String]); + AEEventID eID = *((unsigned long*)[eventID UTF8String]); + + const char *sendString = [string UTF8String]; + long result = 0; + + AppleEvent sendEvent, replyEvent; + + DescType resultType; + Size resultSize, charResultSize; + + AEBuildError buildError; + OSStatus err; + OSErr err2, err3; + /* + if ((GetProcessPID(&psn, &pid) == noErr) && (pid == 0)) { + NSLog(@"Error getting PID of application! Exiting."); + return nil; + } + */ + //NSLog(@"_sendString: %s", sendString); + + err = AEBuildAppleEvent(eClass, eID, typeProcessSerialNumber,(ProcessSerialNumber*)&psn, sizeof(ProcessSerialNumber), kAutoGenerateReturnID, 0, &sendEvent, &buildError, sendString); + + //[self printCarbonDesc:&sendEvent]; + + if (err) { + NSLog(@"%d:%d at \"%@\"",(int)buildError.fError,buildError.fErrorPos,[sendString substringToIndex:buildError.fErrorPos]); + } + + err = AESend(&sendEvent, &replyEvent, kAEWaitReply, kAENormalPriority, kNoTimeOut, idleUPP, NULL); + + [self printCarbonDesc:&replyEvent]; + + if (err) { + NSLog(@"Send Error: %i",err); + } else { + err2 = AESizeOfParam(&replyEvent, keyDirectObject, &resultType, &resultSize); + + if (err2) { + NSLog(@"Error After AESizeOfParam: %i", err2); + } else { + err3 = AEGetParamPtr(&replyEvent, keyDirectObject, resultType, NULL, &result, resultSize, &charResultSize); + + if (err3) { + NSLog(@"Error After AEGetParamPtr: %i", err3); + } + } + } + + AEDisposeDesc(&sendEvent); + AEDisposeDesc(&replyEvent); + + return result; +} + @end -- 2.20.1