summaryrefslogtreecommitdiffstats
path: root/macosx/HBStateFormatter+Private.m
diff options
context:
space:
mode:
authorDamiano Galassi <[email protected]>2016-02-26 09:50:16 +0100
committerDamiano Galassi <[email protected]>2016-03-11 13:51:17 +0100
commit7481df6459c9ab20c6aa68159243f492d113736b (patch)
treed09e6cc962458cd5f7c1f72c1b532bcc9bc63247 /macosx/HBStateFormatter+Private.m
parentd5535297783e8728e45c1d79e973287fead81788 (diff)
MacGui: move the objc libhb wrapper to a separate framework.
Diffstat (limited to 'macosx/HBStateFormatter+Private.m')
-rw-r--r--macosx/HBStateFormatter+Private.m160
1 files changed, 160 insertions, 0 deletions
diff --git a/macosx/HBStateFormatter+Private.m b/macosx/HBStateFormatter+Private.m
new file mode 100644
index 000000000..7c5f600ee
--- /dev/null
+++ b/macosx/HBStateFormatter+Private.m
@@ -0,0 +1,160 @@
+//
+// 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:
+#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