Use dcp::file_to_string().
[dcpomatic.git] / src / lib / dcpomatic_time.cc
index f96688979c9504646437846b438738e719d5689f..ac797f8f4205589c5ad605dc768deb83bbfed54e 100644 (file)
@@ -1,5 +1,5 @@
 /*
-    Copyright (C) 2014 Carl Hetherington <cth@carlh.net>
+    Copyright (C) 2014-2021 Carl Hetherington <cth@carlh.net>
 
     This file is part of DCP-o-matic.
 
 
 */
 
+
 #include "dcpomatic_time.h"
+#include <inttypes.h>
+
+
+using std::string;
+using namespace dcpomatic;
 
-using std::ostream;
 
 template <>
 Time<ContentTimeDifferentiator, DCPTimeDifferentiator>::Time (DCPTime d, FrameRateChange f)
-       : _t (llrint (d.get() * f.speed_up))
+       : _t (llrint(d.get() * f.speed_up))
 {
 
 }
 
+
 template <>
 Time<DCPTimeDifferentiator, ContentTimeDifferentiator>::Time (ContentTime d, FrameRateChange f)
-       : _t (llrint (d.get() / f.speed_up))
+       : _t (llrint(d.get() / f.speed_up))
 {
 
 }
 
+
 DCPTime
-min (DCPTime a, DCPTime b)
+dcpomatic::min (DCPTime a, DCPTime b)
 {
        if (a < b) {
                return a;
@@ -46,8 +53,9 @@ min (DCPTime a, DCPTime b)
        return b;
 }
 
+
 DCPTime
-max (DCPTime a, DCPTime b)
+dcpomatic::max (DCPTime a, DCPTime b)
 {
        if (a > b) {
                return a;
@@ -56,8 +64,9 @@ max (DCPTime a, DCPTime b)
        return b;
 }
 
+
 ContentTime
-min (ContentTime a, ContentTime b)
+dcpomatic::min (ContentTime a, ContentTime b)
 {
        if (a < b) {
                return a;
@@ -66,8 +75,9 @@ min (ContentTime a, ContentTime b)
        return b;
 }
 
+
 ContentTime
-max (ContentTime a, ContentTime b)
+dcpomatic::max (ContentTime a, ContentTime b)
 {
        if (a > b) {
                return a;
@@ -76,23 +86,41 @@ max (ContentTime a, ContentTime b)
        return b;
 }
 
-ostream &
-operator<< (ostream& s, ContentTime t)
+
+string
+dcpomatic::to_string (ContentTime t)
 {
-       s << "[CONT " << t.get() << " " << t.seconds() << "s]";
-       return s;
+       char buffer[64];
+#ifdef DCPOMATIC_WINDOWS
+       __mingw_snprintf (buffer, sizeof(buffer), "[CONT %" PRId64 " %fs]", t.get(), t.seconds());
+#else
+       snprintf (buffer, sizeof(buffer), "[CONT %" PRId64 " %fs]", t.get(), t.seconds());
+#endif
+       return buffer;
 }
 
-ostream &
-operator<< (ostream& s, DCPTime t)
+
+string
+dcpomatic::to_string (DCPTime t)
 {
-       s << "[DCP " << t.get() << " " << t.seconds() << "s]";
-       return s;
+       char buffer[64];
+#ifdef DCPOMATIC_WINDOWS
+       __mingw_snprintf (buffer, sizeof(buffer), "[DCP %" PRId64 " %fs]", t.get(), t.seconds());
+#else
+       snprintf (buffer, sizeof(buffer), "[DCP %" PRId64 " %fs]", t.get(), t.seconds());
+#endif
+       return buffer;
 }
 
-ostream &
-operator<< (ostream& s, DCPTimePeriod p)
+
+string
+dcpomatic::to_string (DCPTimePeriod p)
 {
-       s << "[DCP " << p.from.get() << " " << p.from.seconds() << "s -> " << p.to.get() << " " << p.to.seconds() << "s]";
-       return s;
+       char buffer[64];
+#ifdef DCPOMATIC_WINDOWS
+       __mingw_snprintf (buffer, sizeof(buffer), "[DCP %" PRId64 " %fs -> %" PRId64 " %fs]", p.from.get(), p.from.seconds(), p.to.get(), p.to.seconds());
+#else
+       snprintf (buffer, sizeof(buffer), "[DCP %" PRId64 " %fs -> %" PRId64 " %fs]", p.from.get(), p.from.seconds(), p.to.get(), p.to.seconds());
+#endif
+       return buffer;
 }