More debugging of batch converter startup.
[dcpomatic.git] / src / lib / dcpomatic_time.cc
index 5344915c0c71c31639629ad58995ff6a3a96c25d..1d965993598c20d6b573ca653d92692b374ff472 100644 (file)
 
 #include "dcpomatic_time.h"
 
-ContentTime::ContentTime (DCPTime d, FrameRateChange f)
-       : Time (rint (d.get() * f.speed_up))
+using std::ostream;
+
+template <>
+Time<ContentTimeDifferentiator, DCPTimeDifferentiator>::Time (DCPTime d, FrameRateChange f)
+       : _t (llrint (d.get() * f.speed_up))
+{
+
+}
+
+template <>
+Time<DCPTimeDifferentiator, ContentTimeDifferentiator>::Time (ContentTime d, FrameRateChange f)
+       : _t (llrint (d.get() / f.speed_up))
+{
+
+}
+
+DCPTime
+min (DCPTime a, DCPTime b)
 {
+       if (a < b) {
+               return a;
+       }
+
+       return b;
+}
+
+DCPTime
+max (DCPTime a, DCPTime b)
+{
+       if (a > b) {
+               return a;
+       }
 
+       return b;
 }
 
-DCPTime min (DCPTime a, DCPTime b)
+ContentTime
+min (ContentTime a, ContentTime b)
 {
        if (a < b) {
                return a;
@@ -33,3 +64,34 @@ DCPTime min (DCPTime a, DCPTime b)
 
        return b;
 }
+
+ContentTime
+max (ContentTime a, ContentTime b)
+{
+       if (a > b) {
+               return a;
+       }
+
+       return b;
+}
+
+ostream &
+operator<< (ostream& s, ContentTime t)
+{
+       s << "[CONT " << t.get() << " " << t.seconds() << "s]";
+       return s;
+}
+
+ostream &
+operator<< (ostream& s, DCPTime t)
+{
+       s << "[DCP " << t.get() << " " << t.seconds() << "s]";
+       return s;
+}
+
+ostream &
+operator<< (ostream& s, DCPTimePeriod p)
+{
+       s << "[DCP " << p.from.get() << " " << p.from.seconds() << "s -> " << p.to.get() << " " << p.to.seconds() << "s]";
+       return s;
+}