X-Git-Url: http://git.ithinksw.org/MenuTunes.git/blobdiff_plain/e8516aa003a65e030ec6f7c4007ed04efa351477..538382d5a1cd3e5f194c5354a5c9f07b774ab5bf:/iTunesRemote.m?ds=inline diff --git a/iTunesRemote.m b/iTunesRemote.m index b13049e..f197b97 100755 --- a/iTunesRemote.m +++ b/iTunesRemote.m @@ -7,404 +7,6 @@ return [[[iTunesRemote alloc] init] autorelease]; } -//What should this do? -- (NSString *)informationString:(ITMTRemoteInformationString)string -{ - return @""; -} - -- (NSImage *)icon -{ - return nil; -} - -- (BOOL)begin -{ - savedPSN = [self iTunesPSN]; - return YES; -} - -- (BOOL)halt -{ - return YES; -} - -- (BOOL)supportsControlAction:(ITMTRemoteControlAction)action -{ - switch (action) - { - case ITMTRemoteStop: - case ITMTRemotePause: - case ITMTRemotePlay: - case ITMTRemoteRewind: - case ITMTRemoteFastForward: - case ITMTRemotePreviousTrack: - case ITMTRemoteNextTrack: - return YES; - break; - default: - return NO; - break; - } -} - -- (BOOL)sendControlAction:(ITMTRemoteControlAction)action -{ - NSString *eventID; - switch (action) - { - case ITMTRemoteStop: - eventID = @"Stop"; - return NO; - break; - case ITMTRemotePause: - eventID = @"Paus"; - break; - case ITMTRemotePlay: - eventID = @"Play"; - break; - case ITMTRemoteRewind: - eventID = @"Rwnd"; - break; - case ITMTRemoteFastForward: - eventID = @"Fast"; - break; - case ITMTRemotePreviousTrack: - eventID = @"Prev"; - break; - case ITMTRemoteNextTrack: - eventID = @"Next"; - break; - default: - return NO; - break; - } - [[ITAppleEventCenter sharedCenter] sendAEWithEventClass:@"hook" eventID:eventID appPSN:savedPSN]; - return YES; -} - -- (ITMTRemoteControlState)controlState -{ - long result = [[ITAppleEventCenter sharedCenter] sendAEWithSendStringForNumber:@"'----':obj { form:'prop', want:type('prop'), seld:type('pPlS'), from:'null'() }" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; - - switch (result) - { - default: - case 'kPSS': - return ITMTRemotePlayerStopped; - case 'kPSP': - return ITMTRemotePlayerPlaying; - case 'kPSp': - return ITMTRemotePlayerPaused; - case 'kPSR': - return ITMTRemotePlayerRewinding; - case 'kPSF': - return ITMTRemotePlayerForwarding; - } - return ITMTRemotePlayerStopped; -} - -- (ITMTRemotePlaylistMode)playlistMode -{ - return ITMTRemoteLibraryAndPlaylists; -} - -- (NSArray *)playlistNames -{ - long i; - const signed long numPlaylists = [[ITAppleEventCenter sharedCenter] sendAEWithSendStringForNumber:@"kocl:type('cPly'), '----':()" eventClass:@"core" eventID:@"cnte" appPSN:savedPSN]; - NSMutableArray *playlists = [[NSMutableArray alloc] initWithCapacity:numPlaylists]; - - for (i = 1; i <= numPlaylists; i++) { - const long j = i; - 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]; - NSString *theObj = [[ITAppleEventCenter sharedCenter] sendAEWithSendString:sendStr eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; - [playlists addObject:theObj]; - } - return [playlists autorelease]; -} - -- (BOOL)switchToPlaylist:(int)playlistIndex -{ - [[ITAppleEventCenter sharedCenter] sendAEWithSendString:[NSString stringWithFormat:@"'----':obj { form:'indx', want:type('cPly'), seld:long(%lu), from:() }",index] eventClass:@"hook" eventID:@"Play" appPSN:savedPSN]; - return YES; -} - -- (BOOL)switchToTrackAtIndex:(int)index -{ - [[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]; - return YES; -} - -//What do this? -- (int)indexForTrack:(int)identifier inPlaylist:(int)playlistIndex -{ - return 0; -} - -//What do this? -- (int)identifierForTrackAtIndex:(int)index inPlaylist:(int)playlistIndex -{ - return 0; -} - -- (BOOL)supportsTrackProperty:(ITMTRemoteTrackProperty)property -{ - switch (property) - { - case ITMTRemoteTrackName: - case ITMTRemoteTrackArtist: - case ITMTRemoteTrackAlbum: - case ITMTRemoteTrackComposer: - case ITMTRemoteTrackNumber: - case ITMTRemoteTrackTotal: - case ITMTRemoteTrackComment: - case ITMTRemoteTrackGenre: - case ITMTRemoteTrackYear: - case ITMTRemoteTrackRating: - case ITMTRemoteTrackArt: - return YES; - break; - default: - return NO; - break; - } -} - -//Somebody else do this -- (id)trackProperty:(ITMTRemoteTrackProperty)property atIndex:(int)index -{ - switch (property) - { - case ITMTRemoteTrackName: - break; - case ITMTRemoteTrackArtist: - break; - case ITMTRemoteTrackAlbum: - break; - case ITMTRemoteTrackComposer: - break; - case ITMTRemoteTrackNumber: - break; - case ITMTRemoteTrackTotal: - break; - case ITMTRemoteTrackComment: - break; - case ITMTRemoteTrackGenre: - break; - case ITMTRemoteTrackYear: - break; - case ITMTRemoteTrackRating: - break; - case ITMTRemoteTrackArt: - break; - } - return nil; -} - -//Somebody else do this -- (BOOL)setTrackProperty:(ITMTRemoteTrackProperty)property toValue:(id)value atIndex:(int)index -{ - switch (property) - { - case ITMTRemoteTrackName: - break; - case ITMTRemoteTrackArtist: - break; - case ITMTRemoteTrackAlbum: - break; - case ITMTRemoteTrackComposer: - break; - case ITMTRemoteTrackNumber: - break; - case ITMTRemoteTrackTotal: - break; - case ITMTRemoteTrackComment: - break; - case ITMTRemoteTrackGenre: - break; - case ITMTRemoteTrackYear: - break; - case ITMTRemoteTrackRating: - break; - case ITMTRemoteTrackArt: - break; - } - return NO; -} - -- (BOOL)supportsShuffle -{ - return YES; -} - -//This doesn't work -- (BOOL)setShuffle:(BOOL)toggle -{ - [[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)toggle] eventClass:@"core" eventID:@"setd" appPSN:savedPSN]; - return YES; -} - -- (BOOL)shuffle -{ - int result = [[ITAppleEventCenter sharedCenter] - sendTwoTierAEWithRequestedKeyForNumber:@"pShf" fromObjectByKey:@"pPla" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; - return result; -} - -- (BOOL)supportsRepeatMode:(ITMTRemoteRepeatMode)repeatMode -{ - switch (repeatMode) - { - case ITMTRemoteRepeatNone: - case ITMTRemoteRepeatAll: - case ITMTRemoteRepeatOne: - return YES; - break; - default: - return NO; - break; - } -} - -- (BOOL)setRepeatMode:(ITMTRemoteRepeatMode)repeatMode -{ - char *m00f = NULL; - switch (repeatMode) - { - case ITMTRemoteRepeatNone: - m00f = "kRp0"; - break; - case ITMTRemoteRepeatOne: - m00f = "kRp1"; - break; - case ITMTRemoteRepeatAll: - m00f = "kRpA"; - break; - } - [[ITAppleEventCenter sharedCenter] sendAEWithSendString:[NSString stringWithFormat:@"data:type('%s') ----:obj { form:'prop', want:type('pRpt'), seld:type('pShf'), from:obj { form:'prop', want:type('prop'), seld:type('pPla'), from:'null'() } }",m00f] eventClass:@"core" eventID:@"setd" appPSN:savedPSN]; - return YES; -} - -- (BOOL)repeatMode -{ - FourCharCode m00f = 0; - int result = 0; - m00f = [[ITAppleEventCenter sharedCenter] - sendTwoTierAEWithRequestedKeyForNumber:@"pRpt" fromObjectByKey:@"pPla" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; - - switch (m00f) - { - case 'kRp0': - result = ITMTRemoteRepeatNone; - break; - case 'kRp1': - result = ITMTRemoteRepeatOne; - break; - case 'kRpA': - result = ITMTRemoteRepeatAll; - break; - } - return result; -} - -- (BOOL)supportsVolume -{ - return YES; -} - -- (BOOL)setVolume:(float)volume -{ - [[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]; - return NO; -} - -- (float)volume -{ - return (float)[[ITAppleEventCenter sharedCenter] sendAEWithRequestedKeyForNumber:@"pVol" eventClass:@"core" eventID:@"getd" appPSN:savedPSN] / 100; -} - -- (BOOL)supportsCustomEqualizer -{ - return YES; -} - -- (BOOL)showEqualizerWindow -{ - //Do this Alex, please :D - return YES; -} - -- (BOOL)supportsEqualizerPresets -{ - return YES; -} - -- (NSArray *)equalizerPresetNames -{ - int i; - long numPresets = [[ITAppleEventCenter sharedCenter] sendAEWithSendStringForNumber:@"kocl:type('cEQP'), '----':(), &subj:()" eventClass:@"core" eventID:@"cnte" appPSN:savedPSN]; - NSMutableArray *presets = [[NSMutableArray alloc] initWithCapacity:numPresets]; - - for (i = 1; i <= numPresets; i++) { - 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]; - if (theObj) { - [presets addObject:theObj]; - } - } - return [presets autorelease]; -} - -- (BOOL)switchToEqualizerPreset:(int)index -{ - [[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]; - return YES; -} - -- (BOOL)supportsExternalWindow -{ - return YES; -} - -- (NSString *)externalWindowName -{ - return @"iTunes"; -} - -- (BOOL)showExternalWindow -{ - //Do this Alex - return YES; -} - -- (ProcessSerialNumber)iTunesPSN -{ - ProcessSerialNumber number; - number.highLongOfPSN = kNoProcess; - number.lowLongOfPSN = 0; - - while ( (GetNextProcess(&number) == noErr) ) - { - CFStringRef name; - if ( (CopyProcessName(&number, &name) == noErr) ) - { - if ([(NSString *)name isEqualToString:@"iTunes"]) - { - return number; - } - [(NSString *)name release]; - } - } - return number; -} - -//Below is old -/* -+ (id)remote -{ - return [[[iTunesRemote alloc] init] autorelease]; -} - - (NSString *)remoteTitle { return @"iTunes Remote"; @@ -422,12 +24,14 @@ - (BOOL)begin { + ITDebugLog(@"iTunesRemote begun"); savedPSN = [self iTunesPSN]; return YES; } - (BOOL)halt { + ITDebugLog(@"iTunesRemote halted"); return YES; } @@ -460,15 +64,16 @@ - (BOOL)showPrimaryInterface { - // Make this into AppleEvents... shouldn't be too hard, I'm just too tired to do it right now. - [[ITAppleEventCenter sharedCenter] sendAEWithSendString:@"data:long(1), '----':obj { form:'prop', want:type('prop'), seld:type('pisf'), from:'null'() }" eventClass:@"core" eventID:@"setd" appPSN:savedPSN]; + ITDebugLog(@"Showing player primary interface."); // Still have to convert these to AEs: - // set visible of browser window 1 to true - [[ITAppleEventCenter sharedCenter] sendAEWithSendString:@"data:long(1), ----:obj { form:'prop', want:'prop', seld:'pvis', from:obj { form:'indx', want:'cBrW', seld:1, from:'null'() } }" eventClass:@"core" eventID:@"setd" appPSN:savedPSN]; // set minimized of browser window 1 to false - [[ITAppleEventCenter sharedCenter] sendAEWithSendString:@"data:long(0), ----:obj { form:'prop', want:'prop', seld:'pMin', from:obj { form:'indx', want:'cBrW', seld:1, from:'null'() } }" eventClass:@"core" eventID:@"setd" appPSN:savedPSN]; - - return NO; + [[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]; + // set visible of browser window 1 to true + [[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]; + // Make this into AppleEvents... shouldn't be too hard, I'm just too tired to do it right now. + [[ITAppleEventCenter sharedCenter] sendAEWithSendString:@"data:long(1), '----':obj { form:'prop', want:type('prop'), seld:type('pisf'), from:'null'() }" eventClass:@"core" eventID:@"setd" appPSN:savedPSN]; + ITDebugLog(@"Done showing player primary interface."); + return YES; } - (ITMTRemotePlayerRunningState)playerRunningState @@ -479,31 +84,42 @@ for (i = 0; i < count; i++) { if ([[[apps objectAtIndex:i] objectForKey:@"NSApplicationName"] isEqualToString:@"iTunes"]) { + ITDebugLog(@"Player running state: 1"); return ITMTRemotePlayerRunning; } } + ITDebugLog(@"Player running state: 0"); return ITMTRemotePlayerNotRunning; } - (ITMTRemotePlayerPlayingState)playerPlayingState { - long result = [[ITAppleEventCenter sharedCenter] sendAEWithSendStringForNumber:@"'----':obj { form:'prop', want:type('prop'), seld:type('pPlS'), from:'null'() }" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; + long result; + + ITDebugLog(@"Getting player playing state"); + + result = [[ITAppleEventCenter sharedCenter] sendAEWithSendStringForNumber:@"'----':obj { form:'prop', want:type('prop'), seld:type('pPlS'), from:'null'() }" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; switch (result) { - default: - case 'kPSS': - return ITMTRemotePlayerStopped; case 'kPSP': + ITDebugLog(@"Getting player playing state done. Player state: Playing"); return ITMTRemotePlayerPlaying; case 'kPSp': + ITDebugLog(@"Getting player playing state done. Player state: Paused"); return ITMTRemotePlayerPaused; case 'kPSR': + ITDebugLog(@"Getting player playing state done. Player state: Rewinding"); return ITMTRemotePlayerRewinding; case 'kPSF': + ITDebugLog(@"Getting player playing state done. Player state: Forwarding"); return ITMTRemotePlayerForwarding; + case 'kPSS': + default: + ITDebugLog(@"Getting player playing state done. Player state: Stopped"); + return ITMTRemotePlayerStopped; } - + ITDebugLog(@"Getting player playing state done. Player state: Stopped"); return ITMTRemotePlayerStopped; } @@ -513,172 +129,316 @@ const signed long numPlaylists = [[ITAppleEventCenter sharedCenter] sendAEWithSendStringForNumber:@"kocl:type('cPly'), '----':()" eventClass:@"core" eventID:@"cnte" appPSN:savedPSN]; NSMutableArray *playlists = [[NSMutableArray alloc] initWithCapacity:numPlaylists]; + ITDebugLog(@"Getting playlists."); + for (i = 1; i <= numPlaylists; i++) { const long j = i; 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]; NSString *theObj = [[ITAppleEventCenter sharedCenter] sendAEWithSendString:sendStr eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; + ITDebugLog(@"Adding playlist: %@", theObj); [playlists addObject:theObj]; } + ITDebugLog(@"Finished getting playlists."); return [playlists autorelease]; } - (int)numberOfSongsInPlaylistAtIndex:(int)index { - return [[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]; + int temp1; + ITDebugLog(@"Getting number of songs in playlist at index %i", index); + 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]; + ITDebugLog(@"Getting number of songs in playlist at index %i done", index); + return temp1; +} + +- (ITMTRemotePlayerSource)currentSource +{ + unsigned long fourcc; + + ITDebugLog(@"Getting current source."); + + 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]; + + switch (fourcc) { + case 'kTun': + ITDebugLog(@"Getting current source done. Source: Radio."); + return ITMTRemoteRadioSource; + break; + case 'kDev': + ITDebugLog(@"Getting current source done. Source: Generic Device."); + return ITMTRemoteGenericDeviceSource; + case 'kPod': + ITDebugLog(@"Getting current source done. Source: iPod."); + return ITMTRemoteiPodSource; //this is stupid + break; + case 'kMCD': + case 'kACD': + ITDebugLog(@"Getting current source done. Source: CD."); + return ITMTRemoteCDSource; + break; + case 'kUnk': + case 'kLib': + case 'kShd': + default: + ITDebugLog(@"Getting current source done. Source: Library."); + return ITMTRemoteLibrarySource; + break; + } } - (ITMTRemotePlayerPlaylistClass)currentPlaylistClass { int realResult = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pcls" fromObjectByKey:@"pPla" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; - + ITDebugLog(@"Getting current playlist class"); switch (realResult) { case 'cLiP': - return ITMTRemotePlayerLibraryPlaylist; - break; + ITDebugLog(@"Getting current playlist class done. Class: Library."); + return ITMTRemotePlayerLibraryPlaylist; + break; case 'cRTP': - return ITMTRemotePlayerRadioPlaylist; - break; + ITDebugLog(@"Getting current playlist class done. Class: Radio."); + return ITMTRemotePlayerRadioPlaylist; + break; default: - return ITMTRemotePlayerPlaylist; + ITDebugLog(@"Getting current playlist class done. Class: Standard playlist."); + return ITMTRemotePlayerPlaylist; } } - (int)currentPlaylistIndex -{ - return [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pidx" fromObjectByKey:@"pPla" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; +{ + int temp1; + ITDebugLog(@"Getting current playlist index."); + temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pidx" fromObjectByKey:@"pPla" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; + ITDebugLog(@"Getting current playlist index done."); + return temp1; } - (NSString *)songTitleAtIndex:(int)index { - return [[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]; + NSString *temp1; + ITDebugLog(@"Getting song title at index %i.", index); + 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]; + ITDebugLog(@"Getting song title at index %i done.", index); + return ( ([temp1 length]) ? temp1 : nil ) ; } - (int)currentAlbumTrackCount { - return [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pTrC" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; + int temp1; + ITDebugLog(@"Getting current album track count."); + temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pTrC" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; + ITDebugLog(@"Getting current album track count done."); + return temp1; } - (int)currentSongTrack { - return [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pTrN" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; + int temp1; + ITDebugLog(@"Getting current song track."); + temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pTrN" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; + ITDebugLog(@"Getting current song track done."); + return temp1; } -- (NSString *)currentSongUniqueIdentifier +- (NSString *)playerStateUniqueIdentifier { - return [NSString stringWithFormat:@"%i-%i", [self currentPlaylistIndex], [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pDID" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]]; + NSString *temp1; + ITDebugLog(@"Getting current unique identifier."); + temp1 = [NSString stringWithFormat:@"%i-%i", [self currentPlaylistIndex], [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pDID" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]]; + ITDebugLog(@"Getting current unique identifier done."); + return ( ([temp1 length]) ? temp1 : nil ) ; } - (int)currentSongIndex { - return [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pidx" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; + int temp1; + ITDebugLog(@"Getting current song index."); + temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pidx" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; + ITDebugLog(@"Getting current song index done."); + return temp1; } - (NSString *)currentSongTitle { - return [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pnam" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; + NSString *temp1; + ITDebugLog(@"Getting current song title."); + temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pnam" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; + ITDebugLog(@"Getting current song title done."); + return ( ([temp1 length]) ? temp1 : nil ) ; } - (NSString *)currentSongArtist { - return [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pArt" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; + NSString *temp1; + ITDebugLog(@"Getting current song artist."); + temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pArt" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; + ITDebugLog(@"Getting current song artist done."); + return ( ([temp1 length]) ? temp1 : nil ) ; } - (NSString *)currentSongAlbum { - return [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pAlb" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; + NSString *temp1; + ITDebugLog(@"Getting current song album."); + temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pAlb" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; + ITDebugLog(@"Getting current song album done."); + return ( ([temp1 length]) ? temp1 : nil ) ; } - (NSString *)currentSongGenre { - return [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pGen" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; + NSString *temp1; + ITDebugLog(@"Getting current song genre."); + temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pGen" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; + ITDebugLog(@"Getting current song genre done."); + return ( ([temp1 length]) ? temp1 : nil ) ; } - (NSString *)currentSongLength { - return [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pTim" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; + NSString *temp1; + ITDebugLog(@"Getting current song length."); + temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pTim" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; + ITDebugLog(@"Getting current song length done."); + return temp1; } - (NSString *)currentSongRemaining { - long duration = [[ITAppleEventCenter sharedCenter] + long duration; + long current; + long final; + NSString *finalString; + + ITDebugLog(@"Getting current song remaining time."); + + duration = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pDur" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; - long current = [[ITAppleEventCenter sharedCenter] + current = [[ITAppleEventCenter sharedCenter] sendAEWithRequestedKeyForNumber:@"pPos" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; + + final = duration - current; + finalString = [self formatTimeInSeconds:final]; + + ITDebugLog(@"Getting current song remaining time done."); + + return finalString; +} - return [[NSNumber numberWithLong:duration - current] stringValue]; +- (NSString *)currentSongElapsed +{ + long final; + NSString *finalString; + + ITDebugLog(@"Getting current song elapsed time."); + + final = [[ITAppleEventCenter sharedCenter] + sendAEWithRequestedKeyForNumber:@"pPos" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; + + finalString = [self formatTimeInSeconds:final]; + ITDebugLog(@"Getting current song elapsed time done."); + return finalString; } - (float)currentSongRating { - return (float)[[ITAppleEventCenter sharedCenter] - sendTwoTierAEWithRequestedKeyForNumber:@"pRte" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN] / 100.0; + float temp1; + ITDebugLog(@"Getting current song rating."); + temp1 = ((float)[[ITAppleEventCenter sharedCenter] + sendTwoTierAEWithRequestedKeyForNumber:@"pRte" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN] / 100.0); + ITDebugLog(@"Getting current song rating done."); + return temp1; } - (BOOL)setCurrentSongRating:(float)rating { + ITDebugLog(@"Setting current song rating to %f.", rating); [[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]; + ITDebugLog(@"Setting current song rating to %f done.", rating); return YES; } -/* - (BOOL)equalizerEnabled +- (BOOL)equalizerEnabled { + ITDebugLog(@"Getting equalizer enabled status."); int thingy = [[ITAppleEventCenter sharedCenter] sendAEWithSendStringForNumber:@"'----':obj { form:type('prop'), want:type('prop'), seld:type('pEQ '), from:() }" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; - NSLog(@"Debug equalizerEnabled: %i", thingy); + ITDebugLog(@"Done getting equalizer enabled status."); return thingy; } - (BOOL)setEqualizerEnabled:(BOOL)enabled { + ITDebugLog(@"Setting equalizer enabled to %i.", enabled); [[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]; + ITDebugLog(@"Done setting equalizer enabled to %i.", enabled); return YES; -} */ +} -/*- (NSArray *)eqPresets +- (NSArray *)eqPresets { int i; long numPresets = [[ITAppleEventCenter sharedCenter] sendAEWithSendStringForNumber:@"kocl:type('cEQP'), '----':(), &subj:()" eventClass:@"core" eventID:@"cnte" appPSN:savedPSN]; NSMutableArray *presets = [[NSMutableArray alloc] initWithCapacity:numPresets]; - + ITDebugLog(@"Getting EQ presets"); for (i = 1; i <= numPresets; i++) { 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]; 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 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pidx" fromObjectByKey:@"pEQP" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; + ITDebugLog(@"Getting current EQ preset index done."); return result; } - (float)volume { + ITDebugLog(@"Getting volume."); + ITDebugLog(@"Getting volume done."); return (float)[[ITAppleEventCenter sharedCenter] sendAEWithRequestedKeyForNumber:@"pVol" eventClass:@"core" eventID:@"getd" appPSN:savedPSN] / 100; } - (BOOL)setVolume:(float)volume { + ITDebugLog(@"Setting volume to %f.", volume); [[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]; - return NO; + ITDebugLog(@"Setting volume to %f done.", volume); + return YES; } - (BOOL)shuffleEnabled { + ITDebugLog(@"Getting shuffle enabled status."); + BOOL final; int result = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pShf" fromObjectByKey:@"pPla" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; - return result; + if (result != 0) { + final = YES; + } else { + final = NO; + } + ITDebugLog(@"Getting shuffle enabled status done."); + return final; } - (BOOL)setShuffleEnabled:(BOOL)enabled { - [[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]; + ITDebugLog(@"Set shuffle enabled to %i", enabled); + [[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]; + ITDebugLog(@"Set shuffle enabled to %i done", enabled); return YES; } @@ -688,95 +448,120 @@ int result = 0; m00f = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pRpt" fromObjectByKey:@"pPla" eventClass:@"core" eventID:@"getd" appPSN:savedPSN]; - + ITDebugLog(@"Getting repeat mode."); switch (m00f) - { - case 'kRp0': - result = ITMTRemotePlayerRepeatOff; - break; - case 'kRp1': - result = ITMTRemotePlayerRepeatOne; - break; - case 'kRpA': - result = ITMTRemotePlayerRepeatAll; - break; - } - + { + //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 = NULL; + char *m00f; + ITDebugLog(@"Setting repeat mode to %i", repeatMode); switch (repeatMode) - { - case ITMTRemotePlayerRepeatOff: - m00f = "kRp0"; - break; - case ITMTRemotePlayerRepeatOne: - m00f = "kRp1"; - break; - case ITMTRemotePlayerRepeatAll: - m00f = "kRpA"; - break; - } - - [[ITAppleEventCenter sharedCenter] sendAEWithSendString:[NSString stringWithFormat:@"data:type('%s') ----:obj { form:'prop', want:type('pRpt'), seld:type('pShf'), from:obj { form:'prop', want:type('prop'), seld:type('pPla'), from:'null'() } }",m00f] eventClass:@"core" eventID:@"setd" appPSN:savedPSN]; + { + case ITMTRemotePlayerRepeatOne: + m00f = "kRp1"; + break; + case ITMTRemotePlayerRepeatAll: + m00f = "kRpA"; + break; + case ITMTRemotePlayerRepeatOff: + default: + m00f = "kRp0"; + break; + } + [[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]; + ITDebugLog(@"Setting repeat mode to %c done", m00f); return YES; } - (BOOL)play { + ITDebugLog(@"Play"); [[ITAppleEventCenter sharedCenter] sendAEWithEventClass:@"hook" eventID:@"Play" appPSN:savedPSN]; + ITDebugLog(@"Play done"); return YES; } - (BOOL)pause { + ITDebugLog(@"Pause"); [[ITAppleEventCenter sharedCenter] sendAEWithEventClass:@"hook" eventID:@"Paus" appPSN:savedPSN]; + ITDebugLog(@"Pause done"); return YES; } - (BOOL)goToNextSong { + ITDebugLog(@"Go to next track"); [[ITAppleEventCenter sharedCenter] sendAEWithEventClass:@"hook" eventID:@"Next" appPSN:savedPSN]; + ITDebugLog(@"Go to next track done"); return YES; } - (BOOL)goToPreviousSong { + ITDebugLog(@"Go to previous track"); [[ITAppleEventCenter sharedCenter] sendAEWithEventClass:@"hook" eventID:@"Prev" appPSN:savedPSN]; + ITDebugLog(@"Go to previous track done"); return YES; } - (BOOL)forward { + ITDebugLog(@"Fast forward action"); [[ITAppleEventCenter sharedCenter] sendAEWithEventClass:@"hook" eventID:@"Fast" appPSN:savedPSN]; + ITDebugLog(@"Fast forward action done"); return YES; } - (BOOL)rewind { + ITDebugLog(@"Rewind action"); [[ITAppleEventCenter sharedCenter] sendAEWithEventClass:@"hook" eventID:@"Rwnd" appPSN:savedPSN]; + ITDebugLog(@"Rewind action done"); return YES; } - (BOOL)switchToPlaylistAtIndex:(int)index { + ITDebugLog(@"Switching to playlist at index %i", index); [[ITAppleEventCenter sharedCenter] sendAEWithSendString:[NSString stringWithFormat:@"'----':obj { form:'indx', want:type('cPly'), seld:long(%lu), from:() }",index] eventClass:@"hook" eventID:@"Play" appPSN:savedPSN]; + ITDebugLog(@"Done switching to playlist at index %i", index); return YES; } - (BOOL)switchToSongAtIndex:(int)index { + ITDebugLog(@"Switching to track at index %i", index); [[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]; + 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]; [[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]; + ITDebugLog(@"Done switching to EQ preset at index %i", index); return YES; } @@ -801,11 +586,11 @@ @"NSApplicationProcessSerialNumberLow"] intValue]; } } - return number;*//* + return number;*/ ProcessSerialNumber number; number.highLongOfPSN = kNoProcess; number.lowLongOfPSN = 0; - + ITDebugLog(@"Getting iTunes' PSN."); while ( (GetNextProcess(&number) == noErr) ) { CFStringRef name; @@ -813,12 +598,40 @@ { if ([(NSString *)name isEqualToString:@"iTunes"]) { + ITDebugLog(@"iTunes' highLongOfPSN: %lu.", number.highLongOfPSN); + ITDebugLog(@"iTunes' lowLongOfPSN: %lu.", number.lowLongOfPSN); + ITDebugLog(@"Done getting iTunes' PSN."); return number; } [(NSString *)name release]; } } + ITDebugLog(@"Failed getting iTunes' PSN."); return number; -}*/ +} + +- (NSString*)formatTimeInSeconds:(long)seconds { + long final = seconds; + NSString *finalString; + if (final > 60) { + if (final > 3600) { + finalString = [NSString stringWithFormat:@"%i:%@:%@",(final / 3600),[self zeroSixty:(int)((final % 3600) / 60)],[self zeroSixty:(int)((final % 3600) % 60)]]; + } else { + finalString = [NSString stringWithFormat:@"%i:%@",(final / 60),[self zeroSixty:(int)(final % 60)]]; + } + } else { + finalString = [NSString stringWithFormat:@"0:%@",[self zeroSixty:(int)final]]; + } + return finalString; +} +- (NSString*)zeroSixty:(int)seconds { + if ( (seconds < 10) && (seconds > 0) ) { + return [NSString stringWithFormat:@"0%i",seconds]; + } else if ( (seconds == 0) ) { + return [NSString stringWithFormat:@"00"]; + } else { + return [NSString stringWithFormat:@"%i",seconds]; + } +} @end