+- (BOOL)setCurrentSongRating:(float)rating
+{
+ ITDebugLog(@"Setting current song rating to %f.", rating);
+ if ( [self currentPlaylistClass] == ITMTRemotePlayerRadioPlaylist ) { return NO; }
+ ITSendAEWithString([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]], 'core', 'setd', &savedPSN);
+ ITDebugLog(@"Setting current song rating to %f done.", rating);
+ return YES;
+}
+
+- (BOOL)equalizerEnabled
+{
+ ITDebugLog(@"Getting equalizer enabled status.");
+ int thingy = (int)[ITSendAEWithKey('pEQ ', 'core', 'getd', &savedPSN) int32Value];
+ ITDebugLog(@"Done getting equalizer enabled status.");
+ return (thingy != 0) ? YES : NO;
+}
+
+- (BOOL)setEqualizerEnabled:(BOOL)enabled
+{
+ ITDebugLog(@"Setting equalizer enabled to %i.", enabled);
+ ITSendAEWithString([NSString stringWithFormat:@"data:long(%lu), '----':obj { form:'prop', want:type('prop'), seld:type('pEQ '), from:'null'() }", enabled], 'core', 'setd', &savedPSN);
+ ITDebugLog(@"Done setting equalizer enabled to %i.", enabled);
+ return YES;
+}
+
+- (NSArray *)eqPresets
+{
+ int i;
+ SInt32 numPresets = [ITSendAEWithString(@"kocl:type('cEQP'), '----':(), &subj:()", 'core', 'cnte', &savedPSN) int32Value];
+ NSMutableArray *presets = [[NSMutableArray alloc] initWithCapacity:numPresets];
+ ITDebugLog(@"Getting EQ presets");
+ for (i = 1; i <= numPresets; i++) {
+ NSString *theObj = [ITSendAEWithString([NSString stringWithFormat:@"'----':obj { form:'prop', want:type('prop'), seld:type('pnam'), from:obj { form:'indx', want:type('cEQP'), seld:long(%lu), from:'null'() } }", i], 'core', 'getd', &savedPSN) stringValue];
+ if (theObj) {
+ ITDebugLog(@"Adding preset %@", theObj);
+ [presets addObject:theObj];
+ }
+ }
+ ITDebugLog(@"Done getting EQ presets");
+ return [presets autorelease];
+}
+
+- (int)currentEQPresetIndex
+{
+ int result;
+ ITDebugLog(@"Getting current EQ preset index.");
+ result = (int)[ITSendAEWithString(@"'----':obj { form:'prop', want:type('prop'), seld:type('pidx'), from:obj { form:'prop', want:type('prop'), seld:type('pEQP'), from:'null'() } }", 'core', 'getd', &savedPSN) int32Value];
+ ITDebugLog(@"Getting current EQ preset index done.");
+ return result;
+}
+
+- (float)volume
+{
+ ITDebugLog(@"Getting volume.");
+ ITDebugLog(@"Getting volume done.");
+ return (float)[ITSendAEWithKey('pVol', 'core', 'getd', &savedPSN) int32Value] / 100;
+}
+
+- (BOOL)setVolume:(float)volume
+{
+ ITDebugLog(@"Setting volume to %f.", volume);
+ ITSendAEWithString([NSString stringWithFormat:@"data:long(%lu), '----':obj { form:'prop', want:type('prop'), seld:type('pVol'), from:'null'() }", (long)(volume * 100)], 'core', 'setd', &savedPSN);
+ ITDebugLog(@"Setting volume to %f done.", volume);
+ return YES;
+}
+
+- (BOOL)shuffleEnabled
+{
+ ITDebugLog(@"Getting shuffle enabled status.");
+ BOOL final;
+ int result = (int)[ITSendAEWithString(@"'----':obj { form:'prop', want:type('prop'), seld:type('pShf'), from:obj { form:'prop', want:type('pPla'), seld:type('pEQP'), from:'null'() } }", 'core', 'getd', &savedPSN) int32Value];
+ if (result != 0) {
+ final = YES;
+ } else {
+ final = NO;
+ }
+ ITDebugLog(@"Getting shuffle enabled status done.");
+ return final;
+}
+
+- (BOOL)setShuffleEnabled:(BOOL)enabled
+{
+ ITDebugLog(@"Set shuffle enabled to %i", enabled);
+ ITSendAEWithString([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], 'core', 'setd', &savedPSN);
+ ITDebugLog(@"Set shuffle enabled to %i done", enabled);
+ return YES;
+}
+
+- (ITMTRemotePlayerRepeatMode)repeatMode
+{
+ FourCharCode m00f = 0;
+ int result = 0;
+ m00f = (FourCharCode)[ITSendAEWithString(@"'----':obj { form:'prop', want:type('prop'), seld:type('pRpt'), from:obj { form:'prop', want:type('pPla'), seld:type('pEQP'), from:'null'() } }", 'core', 'getd', &savedPSN) int32Value];
+ ITDebugLog(@"Getting repeat mode.");
+ switch (m00f)
+ {
+ //case 'kRp0':
+ case 1800564815:
+ ITDebugLog(@"Repeat off");
+ result = ITMTRemotePlayerRepeatOff;
+ break;
+ case 'kRp1':
+ ITDebugLog(@"Repeat one");
+ result = ITMTRemotePlayerRepeatOne;
+ break;
+ case 'kRpA':
+ ITDebugLog(@"Repeat all");
+ result = ITMTRemotePlayerRepeatAll;
+ break;
+ }
+ ITDebugLog(@"Getting repeat mode done.");
+ return result;
+}
+
+- (BOOL)setRepeatMode:(ITMTRemotePlayerRepeatMode)repeatMode
+{
+ char *m00f;
+ ITDebugLog(@"Setting repeat mode to %i", repeatMode);
+ switch (repeatMode)
+ {
+ case ITMTRemotePlayerRepeatOne:
+ m00f = "kRp1";
+ break;
+ case ITMTRemotePlayerRepeatAll:
+ m00f = "kRpA";
+ break;
+ case ITMTRemotePlayerRepeatOff:
+ default:
+ m00f = "kRp0";
+ break;
+ }
+ ITSendAEWithString([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], 'core', 'setd', &savedPSN);
+ ITDebugLog(@"Setting repeat mode to %c done", m00f);
+ return YES;
+}
+
+- (BOOL)play
+{
+ ITDebugLog(@"Play");
+ ITSendAE('hook', 'Play', &savedPSN);
+ ITDebugLog(@"Play done");
+ return YES;
+}
+
+- (BOOL)pause
+{
+ ITDebugLog(@"Pause");
+ ITSendAE('hook', 'Paus', &savedPSN);
+ ITDebugLog(@"Pause done");
+ return YES;
+}
+
+- (BOOL)goToNextSong
+{
+ ITDebugLog(@"Go to next track");
+ ITSendAE('hook', 'Next', &savedPSN);
+ ITDebugLog(@"Go to next track done");
+ return YES;
+}
+
+- (BOOL)goToPreviousSong
+{
+ ITDebugLog(@"Go to previous track");
+ ITSendAE('hook', 'Back', &savedPSN);
+ ITDebugLog(@"Go to previous track done");
+ return YES;
+}
+
+- (BOOL)forward
+{
+ ITDebugLog(@"Fast forward action");
+ ITSendAE('hook', 'Fast', &savedPSN);
+ ITDebugLog(@"Fast forward action done");
+ return YES;
+}
+
+- (BOOL)rewind
+{
+ ITDebugLog(@"Rewind action");
+ ITSendAE('hook', 'Rwnd', &savedPSN);
+ ITDebugLog(@"Rewind action done");
+ return YES;
+}
+
+- (BOOL)switchToPlaylistAtIndex:(int)index
+{
+ ITDebugLog(@"Switching to playlist at index %i", index);
+ ITSendAEWithString([NSString stringWithFormat:@"'----':obj { form:'indx', want:type('cPly'), seld:long(%lu), from:() }", index], 'hook', 'Play', &savedPSN);
+ ITDebugLog(@"Done switching to playlist at index %i", index);
+ return YES;
+}
+
+- (BOOL)switchToPlaylistAtIndex:(int)index ofSourceAtIndex:(int)index2
+{
+ ITDebugLog(@"Switching to playlist at index %i of source %i", index, index2);
+ ITSendAEWithString([NSString stringWithFormat:@"'----':obj { form:'indx', want:type('cPly'), seld:long(%lu), from: obj { form:'indx', want:type('cSrc'), seld:long(%lu), from:'null'() } }", index - 1, index2 + 1], 'hook', 'Play', &savedPSN);
+ ITDebugLog(@"Done switching to playlist at index %i of source %i", index, index2);
+ return YES;
+}
+
+- (BOOL)switchToSongAtIndex:(int)index
+{
+ ITDebugLog(@"Switching to track at index %i", index);
+ ITSendAEWithString([NSString stringWithFormat:@"'----':obj { form:'indx', want:type('cTrk'), seld:long(%lu), from:obj { form:'prop', want:type('prop'), seld:type('pPla'), from:() } }", index], 'hook' ,'Play', &savedPSN);
+ ITDebugLog(@"Done switching to track at index %i", index);
+ return YES;
+}
+
+- (BOOL)switchToEQAtIndex:(int)index
+{
+ ITDebugLog(@"Switching to EQ preset at index %i", index);
+ // index should count from 0, but itunes counts from 1, so let's add 1.
+ [self setEqualizerEnabled:YES];
+ ITSendAEWithString([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)], 'core', 'setd', &savedPSN);
+ ITDebugLog(@"Done switching to EQ preset at index %i", index);
+ return YES;
+}
+
+- (BOOL)makePlaylistWithTerm:(NSString *)term ofType:(int)type
+{
+ int i;
+
+ //Get fixed indexing status
+ BOOL fixed = [ITSendAEWithString(@"'----':obj { form:'prop', want:type('prop'), seld:type('pFix'), from:'null'() }", 'core', 'getd', &savedPSN) booleanValue];
+
+ //Enabled fixed indexing
+ ITSendAEWithString(@"data:long(1), '----':obj { form:'prop', want:type('prop'), seld:type('pFix'), from:'null'() }", 'core', 'setd', &savedPSN);
+
+ //Search for the term
+ NSAppleEventDescriptor *searchResults = ITSendAEWithString([NSString stringWithFormat:@"pTrm:\"%@\", pAre:'%@', '----':obj { form:'indx', want:type('cPly'), seld:long(1), from:obj { form:'indx', want:type('cSrc'), seld:long(1), from:'null'() } }", term, ((type == 1) ? @"kSrR" : @"kSrL")], 'hook', 'Srch', &savedPSN);
+
+ //If MenuTunes playlist exists
+ if ([ITSendAEWithString(@"'----':obj { form:'name', want:type('cPly'), seld:\"MenuTunes\", from:'null'() }", 'core', 'doex', &savedPSN) booleanValue]) {
+ //Clear old MenuTunes playlist
+ int numSongs = [ITSendAEWithString(@"kocl:type('cTrk'), '----':obj { form:'name', want:type('cPly'), seld:\"MenuTunes\", from:'null'() }", 'core', 'cnte', &savedPSN) int32Value];
+ for (i = 1; i <= numSongs; i++) {
+ ITSendAEWithString(@"'----':obj { form:'indx', want:type('cTrk'), seld:long(1), from:obj { form:'name', want:type('cPly'), seld:\"MenuTunes\", from:'null'() } }", 'core', 'delo', &savedPSN);
+ }
+ } else {
+ //Create MenuTunes playlist
+ ITSendAEWithString(@"prdt:{ pnam:\"MenuTunes\" }, kocl:type('cPly'), &subj:()", 'core', 'crel', &savedPSN);
+ }
+
+ //Duplicate search results to playlist
+ for (i = 1; i <= [searchResults numberOfItems]; i++) {
+ //NSLog(@"%@", ITSendAEWithStringAndParameter(@"'----':obj { form:'prop', want:type('prop'), seld:prop('pnam'), from:aevt(@) }", *[[searchResults descriptorAtIndex:i] aeDesc], 'core', 'getd', &savedPSN));
+ ITSendAEWithStringAndObject(@"insh:obj { form:'name', want:type('cPly'), seld:\"MenuTunes\", from:'null'() }", [[searchResults descriptorAtIndex:i] aeDesc], 'core', 'clon', &savedPSN);
+ }
+ //Reset fixed indexing
+ ITSendAEWithString([NSString stringWithFormat:@"data:long(%i), '----':obj { form:'prop', want:type('prop'), seld:type('pFix'), from:'null'() }", fixed], 'core', 'setd', &savedPSN);
+
+ //Play MenuTunes playlist
+ ITSendAEWithString(@"'----':obj { form:'name', want:type('cPly'), seld:\"MenuTunes\", from:'null'() }", 'hook', 'Play', &savedPSN);
+
+ return YES;
+}
+
+- (BOOL)isPlaying
+{
+ return ([ITSendAEWithString(@"'----':obj { form:'prop', want:type('prop'), seld:type('pcls'), from:obj { form:'prop', want:type('prop'), seld:type('pTrk'), from:'null'() } }", 'core', 'getd', &savedPSN) int32Value] != 'prop');
+}
+
+- (void)notificationHandler:(NSNotification *)note
+{
+ ITDebugLog(@"Received notification: %@", note);
+ [[NSNotificationCenter defaultCenter] postNotificationName:@"ITMTTrackChanged" object:self userInfo:[note userInfo]];
+ ITDebugLog(@"Handled notification.");