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.");
160 fourcc = (unsigned long)[[ITAppleEventCenter sharedCenter] sendAEWithSendStringForNumber :[NSString stringWithFormat:@"'----':obj { form:'prop', want:type('prop'), seld:type('pKnd'), from:obj { form:'prop', want:type('prop'), seld:type('ctnr'), from:obj { form:'prop', want:type('prop'), seld:type('pPla'), from:'null'() } } }"] eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
162 NSLog(@"FourCC: %u", fourcc);
166 ITDebugLog(@"Getting current source done. Source: Radio.");
167 return ITMTRemoteRadioSource;
170 ITDebugLog(@"Getting current source done. Source: Generic Device.");
171 return ITMTRemoteGenericDeviceSource;
173 ITDebugLog(@"Getting current source done. Source: iPod.");
174 return ITMTRemoteiPodSource; //this is stupid
178 ITDebugLog(@"Getting current source done. Source: CD.");
179 return ITMTRemoteCDSource;
185 ITDebugLog(@"Getting current source done. Source: Library.");
186 return ITMTRemoteLibrarySource;
191 - (ITMTRemotePlayerPlaylistClass)currentPlaylistClass
193 int realResult = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pcls" fromObjectByKey:@"pPla" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
195 ITDebugLog(@"Getting current playlist class");
199 ITDebugLog(@"Getting current playlist class done. Class: Library.");
200 return ITMTRemotePlayerLibraryPlaylist;
203 ITDebugLog(@"Getting current playlist class done. Class: Radio.");
204 return ITMTRemotePlayerRadioPlaylist;
207 ITDebugLog(@"Getting current playlist class done. Class: Standard playlist.");
208 return ITMTRemotePlayerPlaylist;
212 - (int)currentPlaylistIndex
215 ITDebugLog(@"Getting current playlist index.");
216 temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pidx" fromObjectByKey:@"pPla" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
217 ITDebugLog(@"Getting current playlist index done.");
221 - (NSString *)songTitleAtIndex:(int)index
224 ITDebugLog(@"Getting song title at index %i.", index);
225 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];
226 ITDebugLog(@"Getting song title at index %i done.", index);
230 - (int)currentAlbumTrackCount
233 ITDebugLog(@"Getting current album track count.");
234 temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pTrC" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
235 ITDebugLog(@"Getting current album track count done.");
239 - (int)currentSongTrack
242 ITDebugLog(@"Getting current song track.");
243 temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pTrN" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
244 ITDebugLog(@"Getting current song track done.");
248 - (NSString *)playerStateUniqueIdentifier
251 ITDebugLog(@"Getting current unique identifier.");
252 temp1 = [NSString stringWithFormat:@"%i-%i", [self currentPlaylistIndex], [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pDID" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]];
253 ITDebugLog(@"Getting current unique identifier done.");
257 - (int)currentSongIndex
260 ITDebugLog(@"Getting current song index.");
261 temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pidx" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
262 ITDebugLog(@"Getting current song index done.");
266 - (NSString *)currentSongTitle
269 ITDebugLog(@"Getting current song title.");
270 temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pnam" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
271 ITDebugLog(@"Getting current song title done.");
275 - (NSString *)currentSongArtist
278 ITDebugLog(@"Getting current song artist.");
279 temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pArt" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
280 ITDebugLog(@"Getting current song artist done.");
284 - (NSString *)currentSongAlbum
287 ITDebugLog(@"Getting current song album.");
288 temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pAlb" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
289 ITDebugLog(@"Getting current song album done.");
293 - (NSString *)currentSongGenre
296 ITDebugLog(@"Getting current song genre.");
297 temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pGen" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
298 ITDebugLog(@"Getting current song genre done.");
302 - (NSString *)currentSongLength
305 ITDebugLog(@"Getting current song length.");
306 temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pTim" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
307 ITDebugLog(@"Getting current song length done.");
311 - (NSString *)currentSongRemaining
316 ITDebugLog(@"Getting current song remaining time.");
318 duration = [[ITAppleEventCenter sharedCenter]
319 sendTwoTierAEWithRequestedKeyForNumber:@"pDur" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
320 current = [[ITAppleEventCenter sharedCenter]
321 sendAEWithRequestedKeyForNumber:@"pPos" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
322 ITDebugLog(@"Getting current song remaining time done.");
323 return [[NSNumber numberWithLong:duration - current] stringValue];
326 - (NSString *)currentSongElapsed
330 ITDebugLog(@"Getting current song elapsed time.");
332 current = [[ITAppleEventCenter sharedCenter]
333 sendAEWithRequestedKeyForNumber:@"pPos" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
334 ITDebugLog(@"Getting current song elapsed time done.");
335 return [[NSNumber numberWithLong:current] stringValue];
338 - (float)currentSongRating
341 ITDebugLog(@"Getting current song rating.");
342 temp1 = ((float)[[ITAppleEventCenter sharedCenter]
343 sendTwoTierAEWithRequestedKeyForNumber:@"pRte" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN] / 100.0);
344 ITDebugLog(@"Getting current song rating done.");
348 - (BOOL)setCurrentSongRating:(float)rating
350 ITDebugLog(@"Setting current song rating to %f.", rating);
351 [[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];
352 ITDebugLog(@"Setting current song rating to %f done.", rating);
356 - (BOOL)equalizerEnabled
358 ITDebugLog(@"Getting equalizer enabled status.");
359 int thingy = [[ITAppleEventCenter sharedCenter] sendAEWithSendStringForNumber:@"'----':obj { form:type('prop'), want:type('prop'), seld:type('pEQ '), from:() }" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
360 ITDebugLog(@"Done getting equalizer enabled status.");
364 - (BOOL)setEqualizerEnabled:(BOOL)enabled
366 ITDebugLog(@"Setting equalizer enabled to %i.", enabled);
367 [[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];
368 ITDebugLog(@"Done setting equalizer enabled to %i.", enabled);
372 - (NSArray *)eqPresets
375 long numPresets = [[ITAppleEventCenter sharedCenter] sendAEWithSendStringForNumber:@"kocl:type('cEQP'), '----':(), &subj:()" eventClass:@"core" eventID:@"cnte" appPSN:savedPSN];
376 NSMutableArray *presets = [[NSMutableArray alloc] initWithCapacity:numPresets];
377 ITDebugLog(@"Getting EQ presets");
378 for (i = 1; i <= numPresets; i++) {
379 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];
381 ITDebugLog(@"Adding preset %@", theObj);
382 [presets addObject:theObj];
385 ITDebugLog(@"Done getting EQ presets");
386 return [presets autorelease];
389 - (int)currentEQPresetIndex
392 ITDebugLog(@"Getting current EQ preset index.");
393 result = [[ITAppleEventCenter sharedCenter]
394 sendTwoTierAEWithRequestedKeyForNumber:@"pidx" fromObjectByKey:@"pEQP" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
395 ITDebugLog(@"Getting current EQ preset index done.");
401 ITDebugLog(@"Getting volume.");
402 ITDebugLog(@"Getting volume done.");
403 return (float)[[ITAppleEventCenter sharedCenter] sendAEWithRequestedKeyForNumber:@"pVol" eventClass:@"core" eventID:@"getd" appPSN:savedPSN] / 100;
406 - (BOOL)setVolume:(float)volume
408 ITDebugLog(@"Setting volume to %f.", volume);
409 [[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];
410 ITDebugLog(@"Setting volume to %f done.", volume);
414 - (BOOL)shuffleEnabled
416 ITDebugLog(@"Getting shuffle enabled status.");
418 int result = [[ITAppleEventCenter sharedCenter]
419 sendTwoTierAEWithRequestedKeyForNumber:@"pShf" fromObjectByKey:@"pPla" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
425 NSLog(@"shuffleEnabled: final = %i", final);
426 ITDebugLog(@"Getting shuffle enabled status done.");
430 - (BOOL)setShuffleEnabled:(BOOL)enabled
432 ITDebugLog(@"Set shuffle enabled to %i", enabled);
433 [[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];
434 ITDebugLog(@"Set shuffle enabled to %i done", enabled);
438 - (ITMTRemotePlayerRepeatMode)repeatMode
440 FourCharCode m00f = 0;
442 m00f = [[ITAppleEventCenter sharedCenter]
443 sendTwoTierAEWithRequestedKeyForNumber:@"pRpt" fromObjectByKey:@"pPla" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
444 ITDebugLog(@"Getting repeat mode.");
449 ITDebugLog(@"Repeat off");
450 result = ITMTRemotePlayerRepeatOff;
453 ITDebugLog(@"Repeat one");
454 result = ITMTRemotePlayerRepeatOne;
457 ITDebugLog(@"Repeat all");
458 result = ITMTRemotePlayerRepeatAll;
461 ITDebugLog(@"Getting repeat mode done.");
465 - (BOOL)setRepeatMode:(ITMTRemotePlayerRepeatMode)repeatMode
468 ITDebugLog(@"Setting repeat mode to %i", repeatMode);
471 case ITMTRemotePlayerRepeatOne:
474 case ITMTRemotePlayerRepeatAll:
477 case ITMTRemotePlayerRepeatOff:
482 [[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];
483 ITDebugLog(@"Setting repeat mode to %c done", m00f);
490 [[ITAppleEventCenter sharedCenter] sendAEWithEventClass:@"hook" eventID:@"Play" appPSN:savedPSN];
491 ITDebugLog(@"Play done");
497 ITDebugLog(@"Pause");
498 [[ITAppleEventCenter sharedCenter] sendAEWithEventClass:@"hook" eventID:@"Paus" appPSN:savedPSN];
499 ITDebugLog(@"Pause done");
505 ITDebugLog(@"Go to next track");
506 [[ITAppleEventCenter sharedCenter] sendAEWithEventClass:@"hook" eventID:@"Next" appPSN:savedPSN];
507 ITDebugLog(@"Go to next track done");
511 - (BOOL)goToPreviousSong
513 ITDebugLog(@"Go to previous track");
514 [[ITAppleEventCenter sharedCenter] sendAEWithEventClass:@"hook" eventID:@"Prev" appPSN:savedPSN];
515 ITDebugLog(@"Go to previous track done");
521 ITDebugLog(@"Fast forward action");
522 [[ITAppleEventCenter sharedCenter] sendAEWithEventClass:@"hook" eventID:@"Fast" appPSN:savedPSN];
523 ITDebugLog(@"Fast forward action done");
529 ITDebugLog(@"Rewind action");
530 [[ITAppleEventCenter sharedCenter] sendAEWithEventClass:@"hook" eventID:@"Rwnd" appPSN:savedPSN];
531 ITDebugLog(@"Rewind action done");
535 - (BOOL)switchToPlaylistAtIndex:(int)index
537 ITDebugLog(@"Switching to playlist at index %i", index);
538 [[ITAppleEventCenter sharedCenter] sendAEWithSendString:[NSString stringWithFormat:@"'----':obj { form:'indx', want:type('cPly'), seld:long(%lu), from:() }",index] eventClass:@"hook" eventID:@"Play" appPSN:savedPSN];
539 ITDebugLog(@"Done switching to playlist at index %i", index);
543 - (BOOL)switchToSongAtIndex:(int)index
545 ITDebugLog(@"Switching to track at index %i", index);
546 [[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];
547 ITDebugLog(@"Done switching to track at index %i", index);
551 - (BOOL)switchToEQAtIndex:(int)index
553 ITDebugLog(@"Switching to EQ preset at index %i", index);
554 // index should count from 0, but itunes counts from 1, so let's add 1.
555 [[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];
556 ITDebugLog(@"Done switching to EQ preset at index %i", index);
560 - (ProcessSerialNumber)iTunesPSN
562 /*NSArray *apps = [[NSWorkspace sharedWorkspace] launchedApplications];
563 ProcessSerialNumber number;
565 int count = [apps count];
567 number.highLongOfPSN = kNoProcess;
569 for (i = 0; i < count; i++)
571 NSDictionary *curApp = [apps objectAtIndex:i];
573 if ([[curApp objectForKey:@"NSApplicationName"] isEqualToString:@"iTunes"])
575 number.highLongOfPSN = [[curApp objectForKey:
576 @"NSApplicationProcessSerialNumberHigh"] intValue];
577 number.lowLongOfPSN = [[curApp objectForKey:
578 @"NSApplicationProcessSerialNumberLow"] intValue];
582 ProcessSerialNumber number;
583 number.highLongOfPSN = kNoProcess;
584 number.lowLongOfPSN = 0;
585 ITDebugLog(@"Getting iTunes' PSN.");
586 while ( (GetNextProcess(&number) == noErr) )
589 if ( (CopyProcessName(&number, &name) == noErr) )
591 if ([(NSString *)name isEqualToString:@"iTunes"])
593 ITDebugLog(@"iTunes' highLongOfPSN: %lu.", number.highLongOfPSN);
594 ITDebugLog(@"iTunes' lowLongOfPSN: %lu.", number.lowLongOfPSN);
595 ITDebugLog(@"Done getting iTunes' PSN.");
598 [(NSString *)name release];
601 ITDebugLog(@"Failed getting iTunes' PSN.");