+ 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];
+ current = [[ITAppleEventCenter sharedCenter]
+ sendAEWithRequestedKeyForNumber:@"pPos" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
+
+ final = duration - current;
+ if (final > 60) {
+ if (final > 3600) {
+ if (final > 216000) {
+ finalString = [NSString stringWithFormat:@"%i:%i:%i:%i",(final / 216000),((final % 216000) / 3600),(((final / 216000) % 3600) / 60),(((final / 216000) % 3600) % 60)];
+ } else {
+ finalString = [NSString stringWithFormat:@"%i:%i:%i",(final / 3600),((final % 3600) / 60),((final % 3600) % 60)];
+ }
+ } else {
+ finalString = [NSString stringWithFormat:@"%i:%i",(final / 60),(final % 60)];
+ }
+ } else {
+ finalString = [[NSNumber numberWithLong:final] stringValue];
+ }
+
+ ITDebugLog(@"Getting current song remaining time done.");
+
+ return finalString;
+}
+
+- (NSString *)currentSongElapsed
+{
+ long final;
+ NSString *finalString;
+
+ ITDebugLog(@"Getting current song elapsed time.");
+
+ final = [[ITAppleEventCenter sharedCenter]
+ sendAEWithRequestedKeyForNumber:@"pPos" eventClass:@"core" eventID:@"getd" appPSN:savedPSN];
+
+ if (final > 60) {
+ if (final > 3600) {
+ if (final > 216000) {
+ finalString = [NSString stringWithFormat:@"%i:%i:%i:%i",(final / 216000),((final % 216000) / 3600),(((final / 216000) % 3600) / 60),(((final / 216000) % 3600) % 60)];
+ } else {
+ finalString = [NSString stringWithFormat:@"%i:%i:%i",(final / 3600),((final % 3600) / 60),((final % 3600) % 60)];
+ }
+ } else {
+ finalString = [NSString stringWithFormat:@"%i:%i",(final / 60),(final % 60)];
+ }
+ } else {
+ finalString = [[NSNumber numberWithLong:final] stringValue];
+ }
+ ITDebugLog(@"Getting current song elapsed time done.");
+ return finalString;
+}
+
+- (float)currentSongRating
+{
+ 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
+{
+ 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];
+ ITDebugLog(@"Done getting equalizer enabled status.");
+ return thingy;
+}