1 #import "iTunesRemote.h"
3 @implementation iTunesRemote
7 return [[[iTunesRemote alloc] init] autorelease];
10 - (NSString *)remoteTitle
12 return @"iTunes Remote";
15 - (NSString *)remoteInformation
17 return @"Default MenuTunes plugin to control iTunes, by iThink Software.";
20 - (NSImage *)remoteIcon
27 ITDebugLog(@"iTunesRemote begun");
28 savedPSN = [self iTunesPSN];
34 ITDebugLog(@"iTunesRemote halted");
38 - (NSString *)playerFullName
43 - (NSString *)playerSimpleName
48 - (NSDictionary *)capabilities
50 return [NSDictionary dictionaryWithObjectsAndKeys:
51 [NSNumber numberWithBool: YES], @"Remote",
52 [NSNumber numberWithBool: YES], @"Basic Track Control",
53 [NSNumber numberWithBool: YES], @"Track Information",
54 [NSNumber numberWithBool: YES], @"Track Navigation",
55 [NSNumber numberWithBool: YES], @"Upcoming Songs",
56 [NSNumber numberWithBool: YES], @"Playlists",
57 [NSNumber numberWithBool: YES], @"Volume",
58 [NSNumber numberWithBool: YES], @"Shuffle",
59 [NSNumber numberWithBool: YES], @"Repeat Modes",
60 [NSNumber numberWithBool: YES], @"Equalizer",
61 [NSNumber numberWithBool: YES], @"Track Rating",
65 - (BOOL)showPrimaryInterface
67 ITDebugLog(@"Showing player primary interface.");
68 // Still have to convert these to AEs:
69 // set minimized of browser window 1 to false
70 [[ITAppleEventCenter sharedCenter] sendAEWithSendString:@"data:long(0), '----':obj { form:'prop', want:type('prop'), seld:type('pMin'), from:obj { form:'indx', want:type('cBrW'), seld:1, from:'null'() } }" eventClass:@"core" eventID:@"setd" appPSN:savedPSN];
71 // set visible of browser window 1 to true
72 [[ITAppleEventCenter sharedCenter] sendAEWithSendString:@"data:long(1), '----':obj { form:'prop', want:type('prop'), seld:type('pvis'), from:obj { form:'indx', want:type('cBrW'), seld:1, from:'null'() } }" eventClass:@"core" eventID:@"setd" appPSN:savedPSN];
73 // Make this into AppleEvents... shouldn't be too hard, I'm just too tired to do it right now.
74 [[ITAppleEventCenter sharedCenter] sendAEWithSendString:@"data:long(1), '----':obj { form:'prop', want:type('prop'), seld:type('pisf'), from:'null'() }" eventClass:@"core" eventID:@"setd" appPSN:savedPSN];
75 ITDebugLog(@"Done showing player primary interface.");
79 - (ITMTRemotePlayerRunningState)playerRunningState
81 NSArray *apps = [[NSWorkspace sharedWorkspace] launchedApplications];
83 int count = [apps count];
85 for (i = 0; i < count; i++) {
86 if ([[[apps objectAtIndex:i] objectForKey:@"NSApplicationName"] isEqualToString:@"iTunes"]) {
87 ITDebugLog(@"Player running state: 1");
88 return ITMTRemotePlayerRunning;
91 ITDebugLog(@"Player running state: 0");
92 return ITMTRemotePlayerNotRunning;
95 - (ITMTRemotePlayerPlayingState)playerPlayingState
99 ITDebugLog(@"Getting player playing state");
101 result = [[ITAppleEventCenter sharedCenter] sendAEWithSendStringForNumber:@"'----':obj { form:'prop', want:type('prop'), seld:type('pPlS'), from:'null'() }" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
106 ITDebugLog(@"Getting player playing state done. Player state: Playing");
107 return ITMTRemotePlayerPlaying;
109 ITDebugLog(@"Getting player playing state done. Player state: Paused");
110 return ITMTRemotePlayerPaused;
112 ITDebugLog(@"Getting player playing state done. Player state: Rewinding");
113 return ITMTRemotePlayerRewinding;
115 ITDebugLog(@"Getting player playing state done. Player state: Forwarding");
116 return ITMTRemotePlayerForwarding;
119 ITDebugLog(@"Getting player playing state done. Player state: Stopped");
120 return ITMTRemotePlayerStopped;
122 ITDebugLog(@"Getting player playing state done. Player state: Stopped");
123 return ITMTRemotePlayerStopped;
126 - (NSArray *)playlists
129 const signed long numPlaylists = [[ITAppleEventCenter sharedCenter] sendAEWithSendStringForNumber:@"kocl:type('cPly'), '----':()" eventClass:@"core" eventID:@"cnte" appPSN:savedPSN];
130 NSMutableArray *playlists = [[NSMutableArray alloc] initWithCapacity:numPlaylists];
132 ITDebugLog(@"Getting playlists.");
134 for (i = 1; i <= numPlaylists; i++) {
136 NSString *sendStr = [NSString stringWithFormat:@"'----':obj { form:'prop', want:type('prop'), seld:type('pnam'), from:obj { form:'indx', want:type('cPly'), seld:long(%lu), from:'null'() } }",(unsigned long)j];
137 NSString *theObj = [[ITAppleEventCenter sharedCenter] sendAEWithSendString:sendStr eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
138 ITDebugLog(@"Adding playlist: %@", theObj);
139 [playlists addObject:theObj];
141 ITDebugLog(@"Finished getting playlists.");
142 return [playlists autorelease];
145 - (int)numberOfSongsInPlaylistAtIndex:(int)index
148 ITDebugLog(@"Getting number of songs in playlist at index %i", index);
149 temp1 = [[ITAppleEventCenter sharedCenter] sendAEWithSendStringForNumber:[NSString stringWithFormat:@"kocl:type('cTrk'), '----':obj { form:'indx', want:type('cPly'), seld:long(%lu), from:'null'() }",index] eventClass:@"core" eventID:@"cnte" appPSN:savedPSN];
150 ITDebugLog(@"Getting number of songs in playlist at index %i done", index);
154 - (ITMTRemotePlayerSource)currentSource
156 unsigned long fourcc;
158 ITDebugLog(@"Getting current source.");
161 fourcc = [[ITAppleEventCenter sharedCenter] sendAEWithSendStringForNumber :[NSString stringWithFormat:@"'----':obj { form:'prop', want:type('prop'), seld:type('pKnd'), from:obj { form:'prop', want:type('prop'), seld:type('cntr'), from:obj { form:'prop', want:type('prop'), seld:type('pPla'), from:'null'() } } }",index] eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
163 fourcc = (unsigned long)[[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pKnd" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
167 ITDebugLog(@"Getting current source done. Source: Radio.");
168 return ITMTRemoteRadioSource;
171 ITDebugLog(@"Getting current source done. Source: Generic Device.");
172 return ITMTRemoteGenericDeviceSource;
174 ITDebugLog(@"Getting current source done. Source: iPod.");
175 return ITMTRemoteiPodSource; //this is stupid
179 ITDebugLog(@"Getting current source done. Source: CD.");
180 return ITMTRemoteCDSource;
186 ITDebugLog(@"Getting current source done. Source: Library.");
187 return ITMTRemoteLibrarySource;
192 - (ITMTRemotePlayerPlaylistClass)currentPlaylistClass
194 int realResult = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pcls" fromObjectByKey:@"pPla" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
196 ITDebugLog(@"Getting current playlist class");
200 ITDebugLog(@"Getting current playlist class done. Class: Library.");
201 return ITMTRemotePlayerLibraryPlaylist;
204 ITDebugLog(@"Getting current playlist class done. Class: Radio.");
205 return ITMTRemotePlayerRadioPlaylist;
208 ITDebugLog(@"Getting current playlist class done. Class: Standard playlist.");
209 return ITMTRemotePlayerPlaylist;
213 - (int)currentPlaylistIndex
216 ITDebugLog(@"Getting current playlist index.");
217 temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pidx" fromObjectByKey:@"pPla" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
218 ITDebugLog(@"Getting current playlist index done.");
222 - (NSString *)songTitleAtIndex:(int)index
225 ITDebugLog(@"Getting song title at index %i.", index);
226 temp1 = [[ITAppleEventCenter sharedCenter] sendAEWithSendString:[NSString stringWithFormat:@"'----':obj { form:'prop', want:type('prop'), seld:type('pnam'), from:obj { form:'indx', want:type('cTrk'), seld:long(%lu), from:obj { form:'prop', want:type('prop'), seld:type('pPla'), from:'null'() } } }",index] eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
227 ITDebugLog(@"Getting song title at index %i done.", index);
231 - (int)currentAlbumTrackCount
234 ITDebugLog(@"Getting current album track count.");
235 temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pTrC" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
236 ITDebugLog(@"Getting current album track count done.");
240 - (int)currentSongTrack
243 ITDebugLog(@"Getting current song track.");
244 temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pTrN" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
245 ITDebugLog(@"Getting current song track done.");
249 - (NSString *)playerStateUniqueIdentifier
252 ITDebugLog(@"Getting current unique identifier.");
253 temp1 = [NSString stringWithFormat:@"%i-%i", [self currentPlaylistIndex], [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pDID" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]];
254 ITDebugLog(@"Getting current unique identifier done.");
258 - (int)currentSongIndex
261 ITDebugLog(@"Getting current song index.");
262 temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pidx" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
263 ITDebugLog(@"Getting current song index done.");
267 - (NSString *)currentSongTitle
270 ITDebugLog(@"Getting current song title.");
271 temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pnam" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
272 ITDebugLog(@"Getting current song title done.");
276 - (NSString *)currentSongArtist
279 ITDebugLog(@"Getting current song artist.");
280 temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pArt" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
281 ITDebugLog(@"Getting current song artist done.");
285 - (NSString *)currentSongAlbum
288 ITDebugLog(@"Getting current song album.");
289 temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pAlb" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
290 ITDebugLog(@"Getting current song album done.");
294 - (NSString *)currentSongGenre
297 ITDebugLog(@"Getting current song genre.");
298 temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pGen" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
299 ITDebugLog(@"Getting current song genre done.");
303 - (NSString *)currentSongLength
306 ITDebugLog(@"Getting current song length.");
307 temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pTim" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
308 ITDebugLog(@"Getting current song length done.");
312 - (NSString *)currentSongRemaining
317 ITDebugLog(@"Getting current song remaining time.");
319 duration = [[ITAppleEventCenter sharedCenter]
320 sendTwoTierAEWithRequestedKeyForNumber:@"pDur" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
321 current = [[ITAppleEventCenter sharedCenter]
322 sendAEWithRequestedKeyForNumber:@"pPos" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
323 ITDebugLog(@"Getting current song remaining time done.");
324 return [[NSNumber numberWithLong:duration - current] stringValue];
327 - (NSString *)currentSongElapsed
331 ITDebugLog(@"Getting current song elapsed time.");
333 current = [[ITAppleEventCenter sharedCenter]
334 sendAEWithRequestedKeyForNumber:@"pPos" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
335 ITDebugLog(@"Getting current song elapsed time done.");
336 return [[NSNumber numberWithLong:current] stringValue];
339 - (float)currentSongRating
342 ITDebugLog(@"Getting current song rating.");
343 temp1 = ((float)[[ITAppleEventCenter sharedCenter]
344 sendTwoTierAEWithRequestedKeyForNumber:@"pRte" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN] / 100.0);
345 ITDebugLog(@"Getting current song rating done.");
349 - (BOOL)setCurrentSongRating:(float)rating
351 ITDebugLog(@"Setting current song rating to %f.", rating);
352 [[ITAppleEventCenter sharedCenter] sendAEWithSendString:[NSString stringWithFormat:@"data:long(%lu), '----':obj { form:'prop', want:type('prop'), seld:type('pRte'), from:obj { form:'indx', want:type('cTrk'), seld:long(%lu), from:obj { form:'prop', want:type('prop'), seld:type('pPla'), from:'null'() } } }",(long)(rating*100),[self currentSongIndex]] eventClass:@"core" eventID:@"setd" appPSN:savedPSN];
353 ITDebugLog(@"Setting current song rating to %f done.", rating);
357 - (BOOL)equalizerEnabled
359 ITDebugLog(@"Getting equalizer enabled status.");
360 int thingy = [[ITAppleEventCenter sharedCenter] sendAEWithSendStringForNumber:@"'----':obj { form:type('prop'), want:type('prop'), seld:type('pEQ '), from:() }" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
361 ITDebugLog(@"Done getting equalizer enabled status.");
365 - (BOOL)setEqualizerEnabled:(BOOL)enabled
367 ITDebugLog(@"Setting equalizer enabled to %i.", enabled);
368 [[ITAppleEventCenter sharedCenter] sendAEWithSendString:[NSString stringWithFormat:@"data:long(%lu), '----':obj { form:'prop', want:type('prop'), seld:type('pEQ '), from:'null'() }",enabled] eventClass:@"core" eventID:@"setd" appPSN:savedPSN];
369 ITDebugLog(@"Done setting equalizer enabled to %i.", enabled);
373 - (NSArray *)eqPresets
376 long numPresets = [[ITAppleEventCenter sharedCenter] sendAEWithSendStringForNumber:@"kocl:type('cEQP'), '----':(), &subj:()" eventClass:@"core" eventID:@"cnte" appPSN:savedPSN];
377 NSMutableArray *presets = [[NSMutableArray alloc] initWithCapacity:numPresets];
378 ITDebugLog(@"Getting EQ presets");
379 for (i = 1; i <= numPresets; i++) {
380 NSString *theObj = [[ITAppleEventCenter sharedCenter] sendAEWithSendString:[NSString stringWithFormat:@"'----':obj { form:'prop', want:type('prop'), seld:type('pnam'), from:obj { form:'indx', want:type('cEQP'), seld:long(%lu), from:'null'() } }",i] eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
382 ITDebugLog(@"Adding preset %@", theObj);
383 [presets addObject:theObj];
386 ITDebugLog(@"Done getting EQ presets");
387 return [presets autorelease];
390 - (int)currentEQPresetIndex
393 ITDebugLog(@"Getting current EQ preset index.");
394 result = [[ITAppleEventCenter sharedCenter]
395 sendTwoTierAEWithRequestedKeyForNumber:@"pidx" fromObjectByKey:@"pEQP" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
396 ITDebugLog(@"Getting current EQ preset index done.");
402 ITDebugLog(@"Getting volume.");
403 ITDebugLog(@"Getting volume done.");
404 return (float)[[ITAppleEventCenter sharedCenter] sendAEWithRequestedKeyForNumber:@"pVol" eventClass:@"core" eventID:@"getd" appPSN:savedPSN] / 100;
407 - (BOOL)setVolume:(float)volume
409 ITDebugLog(@"Setting volume to %f.", volume);
410 [[ITAppleEventCenter sharedCenter] sendAEWithSendString:[NSString stringWithFormat:@"data:long(%lu), '----':obj { form:'prop', want:type('prop'), seld:type('pVol'), from:'null'() }",(long)(volume*100)] eventClass:@"core" eventID:@"setd" appPSN:savedPSN];
411 ITDebugLog(@"Setting volume to %f done.", volume);
415 - (BOOL)shuffleEnabled
417 ITDebugLog(@"Getting shuffle enabled status.");
419 int result = [[ITAppleEventCenter sharedCenter]
420 sendTwoTierAEWithRequestedKeyForNumber:@"pShf" fromObjectByKey:@"pPla" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
426 NSLog(@"shuffleEnabled: final = %i", final);
427 ITDebugLog(@"Getting shuffle enabled status done.");
431 - (BOOL)setShuffleEnabled:(BOOL)enabled
433 ITDebugLog(@"Set shuffle enabled to %i", enabled);
434 [[ITAppleEventCenter sharedCenter] sendAEWithSendString:[NSString stringWithFormat:@"data:long(%lu), '----':obj { form:'prop', want:type('prop'), seld:type('pShf'), from:obj { form:'prop', want:type('prop'), seld:type('pPla'), from:'null'() } }",(unsigned long)enabled] eventClass:@"core" eventID:@"setd" appPSN:savedPSN];
435 ITDebugLog(@"Set shuffle enabled to %i done", enabled);
439 - (ITMTRemotePlayerRepeatMode)repeatMode
441 FourCharCode m00f = 0;
443 m00f = [[ITAppleEventCenter sharedCenter]
444 sendTwoTierAEWithRequestedKeyForNumber:@"pRpt" fromObjectByKey:@"pPla" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
445 ITDebugLog(@"Getting repeat mode.");
450 ITDebugLog(@"Repeat off");
451 result = ITMTRemotePlayerRepeatOff;
454 ITDebugLog(@"Repeat one");
455 result = ITMTRemotePlayerRepeatOne;
458 ITDebugLog(@"Repeat all");
459 result = ITMTRemotePlayerRepeatAll;
462 ITDebugLog(@"Getting repeat mode done.");
466 - (BOOL)setRepeatMode:(ITMTRemotePlayerRepeatMode)repeatMode
469 ITDebugLog(@"Setting repeat mode to %i", repeatMode);
472 case ITMTRemotePlayerRepeatOne:
475 case ITMTRemotePlayerRepeatAll:
478 case ITMTRemotePlayerRepeatOff:
483 [[ITAppleEventCenter sharedCenter] sendAEWithSendString:[NSString stringWithFormat:@"data:'%s', '----':obj { form:'prop', want:type('prop'), seld:type('pRpt'), from:obj { form:'prop', want:type('prop'), seld:type('pPla'), from:() } }",m00f] eventClass:@"core" eventID:@"setd" appPSN:savedPSN];
484 ITDebugLog(@"Setting repeat mode to %c done", m00f);
491 [[ITAppleEventCenter sharedCenter] sendAEWithEventClass:@"hook" eventID:@"Play" appPSN:savedPSN];
492 ITDebugLog(@"Play done");
498 ITDebugLog(@"Pause");
499 [[ITAppleEventCenter sharedCenter] sendAEWithEventClass:@"hook" eventID:@"Paus" appPSN:savedPSN];
500 ITDebugLog(@"Pause done");
506 ITDebugLog(@"Go to next track");
507 [[ITAppleEventCenter sharedCenter] sendAEWithEventClass:@"hook" eventID:@"Next" appPSN:savedPSN];
508 ITDebugLog(@"Go to next track done");
512 - (BOOL)goToPreviousSong
514 ITDebugLog(@"Go to previous track");
515 [[ITAppleEventCenter sharedCenter] sendAEWithEventClass:@"hook" eventID:@"Prev" appPSN:savedPSN];
516 ITDebugLog(@"Go to previous track done");
522 ITDebugLog(@"Fast forward action");
523 [[ITAppleEventCenter sharedCenter] sendAEWithEventClass:@"hook" eventID:@"Fast" appPSN:savedPSN];
524 ITDebugLog(@"Fast forward action done");
530 ITDebugLog(@"Rewind action");
531 [[ITAppleEventCenter sharedCenter] sendAEWithEventClass:@"hook" eventID:@"Rwnd" appPSN:savedPSN];
532 ITDebugLog(@"Rewind action done");
536 - (BOOL)switchToPlaylistAtIndex:(int)index
538 ITDebugLog(@"Switching to playlist at index %i", index);
539 [[ITAppleEventCenter sharedCenter] sendAEWithSendString:[NSString stringWithFormat:@"'----':obj { form:'indx', want:type('cPly'), seld:long(%lu), from:() }",index] eventClass:@"hook" eventID:@"Play" appPSN:savedPSN];
540 ITDebugLog(@"Done switching to playlist at index %i", index);
544 - (BOOL)switchToSongAtIndex:(int)index
546 ITDebugLog(@"Switching to track at index %i", index);
547 [[ITAppleEventCenter sharedCenter] sendAEWithSendString:[NSString stringWithFormat:@"'----':obj { form:'indx', want:type('cTrk'), seld:long(%lu), from:obj { form:'prop', want:type('prop'), seld:type('pPla'), from:() } }",index] eventClass:@"hook" eventID:@"Play" appPSN:savedPSN];
548 ITDebugLog(@"Done switching to track at index %i", index);
552 - (BOOL)switchToEQAtIndex:(int)index
554 ITDebugLog(@"Switching to EQ preset at index %i", index);
555 // index should count from 0, but itunes counts from 1, so let's add 1.
556 [[ITAppleEventCenter sharedCenter] sendAEWithSendString:[NSString stringWithFormat:@"'----':obj { form:'prop', want:type('prop'), seld:type('pEQP'), from:'null'() }, data:obj { form:'indx', want:type('cEQP'), seld:long(%lu), from:'null'() }",(index+1)] eventClass:@"core" eventID:@"setd" appPSN:savedPSN];
557 ITDebugLog(@"Done switching to EQ preset at index %i", index);
561 - (ProcessSerialNumber)iTunesPSN
563 /*NSArray *apps = [[NSWorkspace sharedWorkspace] launchedApplications];
564 ProcessSerialNumber number;
566 int count = [apps count];
568 number.highLongOfPSN = kNoProcess;
570 for (i = 0; i < count; i++)
572 NSDictionary *curApp = [apps objectAtIndex:i];
574 if ([[curApp objectForKey:@"NSApplicationName"] isEqualToString:@"iTunes"])
576 number.highLongOfPSN = [[curApp objectForKey:
577 @"NSApplicationProcessSerialNumberHigh"] intValue];
578 number.lowLongOfPSN = [[curApp objectForKey:
579 @"NSApplicationProcessSerialNumberLow"] intValue];
583 ProcessSerialNumber number;
584 number.highLongOfPSN = kNoProcess;
585 number.lowLongOfPSN = 0;
586 ITDebugLog(@"Getting iTunes' PSN.");
587 while ( (GetNextProcess(&number) == noErr) )
590 if ( (CopyProcessName(&number, &name) == noErr) )
592 if ([(NSString *)name isEqualToString:@"iTunes"])
594 ITDebugLog(@"iTunes' highLongOfPSN: %lu.", number.highLongOfPSN);
595 ITDebugLog(@"iTunes' lowLongOfPSN: %lu.", number.lowLongOfPSN);
596 ITDebugLog(@"Done getting iTunes' PSN.");
599 [(NSString *)name release];
602 ITDebugLog(@"Failed getting iTunes' PSN.");