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];
164 ITDebugLog(@"Getting current source done. Source: Radio.");
165 return ITMTRemoteRadioSource;
168 ITDebugLog(@"Getting current source done. Source: Generic Device.");
169 return ITMTRemoteGenericDeviceSource;
171 ITDebugLog(@"Getting current source done. Source: iPod.");
172 return ITMTRemoteiPodSource; //this is stupid
176 ITDebugLog(@"Getting current source done. Source: CD.");
177 return ITMTRemoteCDSource;
183 ITDebugLog(@"Getting current source done. Source: Library.");
184 return ITMTRemoteLibrarySource;
189 - (ITMTRemotePlayerPlaylistClass)currentPlaylistClass
191 int realResult = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pcls" fromObjectByKey:@"pPla" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
193 ITDebugLog(@"Getting current playlist class");
197 ITDebugLog(@"Getting current playlist class done. Class: Library.");
198 return ITMTRemotePlayerLibraryPlaylist;
201 ITDebugLog(@"Getting current playlist class done. Class: Radio.");
202 return ITMTRemotePlayerRadioPlaylist;
205 ITDebugLog(@"Getting current playlist class done. Class: Standard playlist.");
206 return ITMTRemotePlayerPlaylist;
210 - (int)currentPlaylistIndex
213 ITDebugLog(@"Getting current playlist index.");
214 temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pidx" fromObjectByKey:@"pPla" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
215 ITDebugLog(@"Getting current playlist index done.");
219 - (NSString *)songTitleAtIndex:(int)index
222 ITDebugLog(@"Getting song title at index %i.", index);
223 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];
224 ITDebugLog(@"Getting song title at index %i done.", index);
228 - (int)currentAlbumTrackCount
231 ITDebugLog(@"Getting current album track count.");
232 temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pTrC" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
233 ITDebugLog(@"Getting current album track count done.");
237 - (int)currentSongTrack
240 ITDebugLog(@"Getting current song track.");
241 temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pTrN" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
242 ITDebugLog(@"Getting current song track done.");
246 - (NSString *)playerStateUniqueIdentifier
249 ITDebugLog(@"Getting current unique identifier.");
250 temp1 = [NSString stringWithFormat:@"%i-%i", [self currentPlaylistIndex], [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pDID" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]];
251 ITDebugLog(@"Getting current unique identifier done.");
255 - (int)currentSongIndex
258 ITDebugLog(@"Getting current song index.");
259 temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pidx" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
260 ITDebugLog(@"Getting current song index done.");
264 - (NSString *)currentSongTitle
267 ITDebugLog(@"Getting current song title.");
268 temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pnam" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
269 ITDebugLog(@"Getting current song title done.");
273 - (NSString *)currentSongArtist
276 ITDebugLog(@"Getting current song artist.");
277 temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pArt" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
278 ITDebugLog(@"Getting current song artist done.");
282 - (NSString *)currentSongAlbum
285 ITDebugLog(@"Getting current song album.");
286 temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pAlb" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
287 ITDebugLog(@"Getting current song album done.");
291 - (NSString *)currentSongGenre
294 ITDebugLog(@"Getting current song genre.");
295 temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pGen" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
296 ITDebugLog(@"Getting current song genre done.");
300 - (NSString *)currentSongLength
303 ITDebugLog(@"Getting current song length.");
304 temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pTim" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
305 ITDebugLog(@"Getting current song length done.");
309 - (NSString *)currentSongRemaining
314 ITDebugLog(@"Getting current song remaining time.");
316 duration = [[ITAppleEventCenter sharedCenter]
317 sendTwoTierAEWithRequestedKeyForNumber:@"pDur" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
318 current = [[ITAppleEventCenter sharedCenter]
319 sendAEWithRequestedKeyForNumber:@"pPos" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
320 ITDebugLog(@"Getting current song remaining time done.");
321 return [[NSNumber numberWithLong:duration - current] stringValue];
324 - (NSString *)currentSongElapsed
328 ITDebugLog(@"Getting current song elapsed time.");
330 current = [[ITAppleEventCenter sharedCenter]
331 sendAEWithRequestedKeyForNumber:@"pPos" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
332 ITDebugLog(@"Getting current song elapsed time done.");
333 return [[NSNumber numberWithLong:current] stringValue];
336 - (float)currentSongRating
339 ITDebugLog(@"Getting current song rating.");
340 temp1 = ((float)[[ITAppleEventCenter sharedCenter]
341 sendTwoTierAEWithRequestedKeyForNumber:@"pRte" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN] / 100.0);
342 ITDebugLog(@"Getting current song rating done.");
346 - (BOOL)setCurrentSongRating:(float)rating
348 ITDebugLog(@"Setting current song rating to %f.", rating);
349 [[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];
350 ITDebugLog(@"Setting current song rating to %f done.", rating);
354 - (BOOL)equalizerEnabled
356 ITDebugLog(@"Getting equalizer enabled status.");
357 int thingy = [[ITAppleEventCenter sharedCenter] sendAEWithSendStringForNumber:@"'----':obj { form:type('prop'), want:type('prop'), seld:type('pEQ '), from:() }" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
358 ITDebugLog(@"Done getting equalizer enabled status.");
362 - (BOOL)setEqualizerEnabled:(BOOL)enabled
364 ITDebugLog(@"Setting equalizer enabled to %i.", enabled);
365 [[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];
366 ITDebugLog(@"Done setting equalizer enabled to %i.", enabled);
370 - (NSArray *)eqPresets
373 long numPresets = [[ITAppleEventCenter sharedCenter] sendAEWithSendStringForNumber:@"kocl:type('cEQP'), '----':(), &subj:()" eventClass:@"core" eventID:@"cnte" appPSN:savedPSN];
374 NSMutableArray *presets = [[NSMutableArray alloc] initWithCapacity:numPresets];
375 ITDebugLog(@"Getting EQ presets");
376 for (i = 1; i <= numPresets; i++) {
377 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];
379 ITDebugLog(@"Adding preset %@", theObj);
380 [presets addObject:theObj];
383 ITDebugLog(@"Done getting EQ presets");
384 return [presets autorelease];
387 - (int)currentEQPresetIndex
390 ITDebugLog(@"Getting current EQ preset index.");
391 result = [[ITAppleEventCenter sharedCenter]
392 sendTwoTierAEWithRequestedKeyForNumber:@"pidx" fromObjectByKey:@"pEQP" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
393 ITDebugLog(@"Getting current EQ preset index done.");
399 ITDebugLog(@"Getting volume.");
400 ITDebugLog(@"Getting volume done.");
401 return (float)[[ITAppleEventCenter sharedCenter] sendAEWithRequestedKeyForNumber:@"pVol" eventClass:@"core" eventID:@"getd" appPSN:savedPSN] / 100;
404 - (BOOL)setVolume:(float)volume
406 ITDebugLog(@"Setting volume to %f.", volume);
407 [[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];
408 ITDebugLog(@"Setting volume to %f done.", volume);
412 - (BOOL)shuffleEnabled
414 ITDebugLog(@"Getting shuffle enabled status.");
416 int result = [[ITAppleEventCenter sharedCenter]
417 sendTwoTierAEWithRequestedKeyForNumber:@"pShf" fromObjectByKey:@"pPla" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
423 NSLog(@"shuffleEnabled: final = %i", final);
424 ITDebugLog(@"Getting shuffle enabled status done.");
428 - (BOOL)setShuffleEnabled:(BOOL)enabled
430 ITDebugLog(@"Set shuffle enabled to %i", enabled);
431 [[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];
432 ITDebugLog(@"Set shuffle enabled to %i done", enabled);
436 - (ITMTRemotePlayerRepeatMode)repeatMode
438 FourCharCode m00f = 0;
440 m00f = [[ITAppleEventCenter sharedCenter]
441 sendTwoTierAEWithRequestedKeyForNumber:@"pRpt" fromObjectByKey:@"pPla" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
442 ITDebugLog(@"Getting repeat mode.");
447 ITDebugLog(@"Repeat off");
448 result = ITMTRemotePlayerRepeatOff;
451 ITDebugLog(@"Repeat one");
452 result = ITMTRemotePlayerRepeatOne;
455 ITDebugLog(@"Repeat all");
456 result = ITMTRemotePlayerRepeatAll;
459 ITDebugLog(@"Getting repeat mode done.");
463 - (BOOL)setRepeatMode:(ITMTRemotePlayerRepeatMode)repeatMode
466 ITDebugLog(@"Setting repeat mode to %i", repeatMode);
469 case ITMTRemotePlayerRepeatOne:
472 case ITMTRemotePlayerRepeatAll:
475 case ITMTRemotePlayerRepeatOff:
480 [[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];
481 ITDebugLog(@"Setting repeat mode to %c done", m00f);
488 [[ITAppleEventCenter sharedCenter] sendAEWithEventClass:@"hook" eventID:@"Play" appPSN:savedPSN];
489 ITDebugLog(@"Play done");
495 ITDebugLog(@"Pause");
496 [[ITAppleEventCenter sharedCenter] sendAEWithEventClass:@"hook" eventID:@"Paus" appPSN:savedPSN];
497 ITDebugLog(@"Pause done");
503 ITDebugLog(@"Go to next track");
504 [[ITAppleEventCenter sharedCenter] sendAEWithEventClass:@"hook" eventID:@"Next" appPSN:savedPSN];
505 ITDebugLog(@"Go to next track done");
509 - (BOOL)goToPreviousSong
511 ITDebugLog(@"Go to previous track");
512 [[ITAppleEventCenter sharedCenter] sendAEWithEventClass:@"hook" eventID:@"Prev" appPSN:savedPSN];
513 ITDebugLog(@"Go to previous track done");
519 ITDebugLog(@"Fast forward action");
520 [[ITAppleEventCenter sharedCenter] sendAEWithEventClass:@"hook" eventID:@"Fast" appPSN:savedPSN];
521 ITDebugLog(@"Fast forward action done");
527 ITDebugLog(@"Rewind action");
528 [[ITAppleEventCenter sharedCenter] sendAEWithEventClass:@"hook" eventID:@"Rwnd" appPSN:savedPSN];
529 ITDebugLog(@"Rewind action done");
533 - (BOOL)switchToPlaylistAtIndex:(int)index
535 ITDebugLog(@"Switching to playlist at index %i", index);
536 [[ITAppleEventCenter sharedCenter] sendAEWithSendString:[NSString stringWithFormat:@"'----':obj { form:'indx', want:type('cPly'), seld:long(%lu), from:() }",index] eventClass:@"hook" eventID:@"Play" appPSN:savedPSN];
537 ITDebugLog(@"Done switching to playlist at index %i", index);
541 - (BOOL)switchToSongAtIndex:(int)index
543 ITDebugLog(@"Switching to track at index %i", index);
544 [[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];
545 ITDebugLog(@"Done switching to track at index %i", index);
549 - (BOOL)switchToEQAtIndex:(int)index
551 ITDebugLog(@"Switching to EQ preset at index %i", index);
552 // index should count from 0, but itunes counts from 1, so let's add 1.
553 [[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];
554 ITDebugLog(@"Done switching to EQ preset at index %i", index);
558 - (ProcessSerialNumber)iTunesPSN
560 /*NSArray *apps = [[NSWorkspace sharedWorkspace] launchedApplications];
561 ProcessSerialNumber number;
563 int count = [apps count];
565 number.highLongOfPSN = kNoProcess;
567 for (i = 0; i < count; i++)
569 NSDictionary *curApp = [apps objectAtIndex:i];
571 if ([[curApp objectForKey:@"NSApplicationName"] isEqualToString:@"iTunes"])
573 number.highLongOfPSN = [[curApp objectForKey:
574 @"NSApplicationProcessSerialNumberHigh"] intValue];
575 number.lowLongOfPSN = [[curApp objectForKey:
576 @"NSApplicationProcessSerialNumberLow"] intValue];
580 ProcessSerialNumber number;
581 number.highLongOfPSN = kNoProcess;
582 number.lowLongOfPSN = 0;
583 ITDebugLog(@"Getting iTunes' PSN.");
584 while ( (GetNextProcess(&number) == noErr) )
587 if ( (CopyProcessName(&number, &name) == noErr) )
589 if ([(NSString *)name isEqualToString:@"iTunes"])
591 ITDebugLog(@"iTunes' highLongOfPSN: %lu.", number.highLongOfPSN);
592 ITDebugLog(@"iTunes' lowLongOfPSN: %lu.", number.lowLongOfPSN);
593 ITDebugLog(@"Done getting iTunes' PSN.");
596 [(NSString *)name release];
599 ITDebugLog(@"Failed getting iTunes' PSN.");