Made it so that the stupid client DISCONNECTS, with the side effect of
[MenuTunes.git] / iTunesRemote.m
index b13049e..68890d3 100755 (executable)
@@ -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";
 
 - (BOOL)begin
 {
+    ITDebugLog(@"iTunesRemote begun");
     savedPSN = [self iTunesPSN];
     return YES;
 }
 
 - (BOOL)halt
 {
+    ITDebugLog(@"iTunesRemote halted");
     return YES;
 }
 
 
 - (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
     
     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;
 }
 
         [playlists addObject:theObj];
     }
     return [playlists autorelease];
+    /*unsigned long i,k;
+    const signed long numSources = [[ITAppleEventCenter sharedCenter] sendAEWithSendStringForNumber:@"kocl:type('cSrc'), '----':()" eventClass:@"core" eventID:@"cnte" appPSN:savedPSN];
+    NSMutableArray *playlists = [[NSMutableArray alloc] initWithCapacity:1];
+    
+    ITDebugLog(@"Getting playlists.");
+    for (k = 1; k <= numSources ; k++) {
+        const signed long numPlaylists = [[ITAppleEventCenter sharedCenter] sendAEWithSendStringForNumber:[NSString stringWithFormat:@"kocl:type('cPly'), '----':obj { form:'indx', want:type('cSrc'), seld:long(%u), from:() }",k] eventClass:@"core" eventID:@"cnte" appPSN:savedPSN];
+        for (i = 1; i <= numPlaylists; i++) {
+            NSString *sendStr = [NSString stringWithFormat:@"'----':obj { form:'prop', want:type('prop'), seld:type('pnam'), from:obj { form:'indx', want:type('cPly'), seld:long(%u), from:obj { form:'indx', want:type('cSrc'), seld:long(%u), from:() } } }",i,k];
+            NSString *theObj = [[ITAppleEventCenter sharedCenter] sendAEWithSendString:sendStr eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
+            [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 'kShd':
+            ITDebugLog(@"Getting current source done. Source: Shared Library.");
+            return ITMTRemoteSharedLibrarySource;
+            break;
+        case 'kUnk':
+        case 'kLib':
+        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];
+    if ( [self currentPlaylistClass] == ITMTRemotePlayerRadioPlaylist ) { temp1 = 0; }
+    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];
+    if ( [self currentPlaylistClass] == ITMTRemotePlayerRadioPlaylist ) { temp1 = 0; }
+    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.");
+    if ( [self currentPlaylistClass] != ITMTRemotePlayerRadioPlaylist ) {
+        temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pArt" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
+    } else {
+        temp1 = @"";
+    }
+    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.");
+    if ( [self currentPlaylistClass] != ITMTRemotePlayerRadioPlaylist ) {
+        temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pAlb" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
+    } else {
+        temp1 = @"";
+    }
+    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];
+    int temp1;
+    NSString *temp2;
+    ITDebugLog(@"Getting current song length.");
+    temp1 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKeyForNumber:@"pcls" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
+    temp2 = [[ITAppleEventCenter sharedCenter] sendTwoTierAEWithRequestedKey:@"pTim" fromObjectByKey:@"pTrk" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
+    if ( ([self currentPlaylistClass] == ITMTRemotePlayerRadioPlaylist) || (temp1 == 'cURT') ) { temp2 = @"Continuous"; }
+    ITDebugLog(@"Getting current song length done.");
+    return temp2;
 }
 
 - (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];
+    
+    if ( [self currentPlaylistClass] == ITMTRemotePlayerRadioPlaylist ) { finalString = nil; }
+    
+    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;
+}
+
+- (NSImage *)currentSongAlbumArt
+{
+    return nil;
 }
 
 - (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);
+    if ( [self currentPlaylistClass] == ITMTRemotePlayerRadioPlaylist ) { temp1 = -1.0; }
+    ITDebugLog(@"Getting current song rating done.");
+    return temp1;
 }
 
 - (BOOL)setCurrentSongRating:(float)rating
 {
+    ITDebugLog(@"Setting current song rating to %f.", rating);
+    if ( [self currentPlaylistClass] == ITMTRemotePlayerRadioPlaylist ) { return NO; }
     [[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;
 }
 
     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;
 }
 
                 @"NSApplicationProcessSerialNumberLow"] intValue];
         }
     }
-    return number;*//*
+    return number;*/
     ProcessSerialNumber number;
     number.highLongOfPSN = kNoProcess;
     number.lowLongOfPSN = 0;
-    
+    ITDebugLog(@"Getting iTunes' PSN.");
     while ( (GetNextProcess(&number) == noErr) ) 
     {
         CFStringRef name;
         {
             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