// // HBStateFormatter+Private.m // HandBrake // // Created by Damiano Galassi on 24/02/16. // // #import "HBStateFormatter+Private.h" @implementation HBStateFormatter (Private) - (NSString *)stateToString:(hb_state_t)s { NSMutableString *string = [NSMutableString string]; switch (s.state) { #define p s.param.working case HB_STATE_SEARCHING: { [string appendFormat: NSLocalizedString(@"Searching for start point… : %.2f %%", nil), 100.0 * p.progress]; if (p.seconds > -1) { [string appendFormat:NSLocalizedString(@" (ETA %02dh%02dm%02ds)", nil), p.hours, p.minutes, p.seconds]; } break; } case HB_STATE_WORKING: { [string appendFormat:NSLocalizedString(@"Encoding %@ ", nil), self.title]; if (self.twoLines) { [string appendString:@"\n"]; } if (self.showPassNumber) { if (p.pass_id == HB_PASS_SUBTITLE) { [string appendFormat: NSLocalizedString(@"Pass %d %@ of %d, %.2f %%", nil), p.pass, NSLocalizedString(@"(subtitle scan)", nil), p.pass_count, 100.0 * p.progress]; } else { [string appendFormat: NSLocalizedString(@"Pass %d of %d, %.2f %%", nil), p.pass, p.pass_count, 100.0 * p.progress]; } } if (p.seconds > -1) { if (p.rate_cur > 0.0) { [string appendFormat: NSLocalizedString(@" (%.2f fps, avg %.2f fps, ETA %02dh%02dm%02ds)", nil), p.rate_cur, p.rate_avg, p.hours, p.minutes, p.seconds]; } else { [string appendFormat: NSLocalizedString(@" (ETA %02dh%02dm%02ds)", nil), p.hours, p.minutes, p.seconds]; } } break; } case HB_STATE_MUXING: { [string appendString:NSLocalizedString(@"Muxing…", nil)]; break; } case HB_STATE_PAUSED: { [string appendString:NSLocalizedString(@"Paused", nil)]; break; } #undef p case HB_STATE_SCANNING: { #define p s.param.scanning if (p.preview_cur) { [string appendFormat: NSLocalizedString(@"Scanning title %d of %d, preview %d…", nil), p.title_cur, p.title_count, p.preview_cur]; } else { [string appendFormat: NSLocalizedString(@"Scanning title %d of %d…", nil), p.title_cur, p.title_count]; } #undef p break; } default: break; } return string; } - (float)stateToPercentComplete:(hb_state_t)s { float progress = 0; switch (s.state) { case HB_STATE_WORKING: case HB_STATE_PAUSED: #define p s.param.working progress = (p.progress + p.pass - 1) / p.pass_count; #undef p break; case HB_STATE_SCANNING: #define p s.param.scanning progress = p.progress; #undef p break; case HB_STATE_MUXING: progress = 1; break; default: break; } if (progress < 0) { progress = 0; } else if (progress > 1) { progress = 1; } return progress; } @end