summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2013-09-18 08:18:40 +0100
committerCarl Hetherington <cth@carlh.net>2013-09-18 08:18:40 +0100
commit56782052e43a1e010f7f07cbc0dbaed5b6cb50a3 (patch)
tree8f8396e2ae07b3ab6b5cfeeb85d7d9d35e404c38 /src
parent29a7edbc3d4a92bd1bf66948d3553d4b88f2d291 (diff)
Separate time -> string functions out.
Diffstat (limited to 'src')
-rw-r--r--src/metadata.cc41
-rw-r--r--src/metadata.h5
-rw-r--r--src/util.cc44
-rw-r--r--src/util.h3
4 files changed, 49 insertions, 44 deletions
diff --git a/src/metadata.cc b/src/metadata.cc
index bcf5d76c..acbc3b2e 100644
--- a/src/metadata.cc
+++ b/src/metadata.cc
@@ -28,6 +28,7 @@
#include <windows.h>
#endif
#include "metadata.h"
+#include "util.h"
using namespace std;
using namespace libdcp;
@@ -51,45 +52,7 @@ XMLMetadata::XMLMetadata ()
void
XMLMetadata::set_issue_date_now ()
{
- char buffer[64];
time_t now = time (0);
struct tm* tm = localtime (&now);
- strftime (buffer, 64, "%Y-%m-%dT%I:%M:%S", tm);
-
- int offset = 0;
-
-#ifdef LIBDCP_POSIX
-
- offset = tm->tm_gmtoff / 60;
-
-#else
- TIME_ZONE_INFORMATION tz;
- GetTimeZoneInformation (&tz);
- offset = tz.Bias;
-#endif
-
- issue_date = string (buffer) + utc_offset_to_string (offset);
-}
-
-/** @param b Offset from UTC to local time in minutes.
- * @return string of the form e.g. -01:00.
- */
-string
-XMLMetadata::utc_offset_to_string (int b)
-{
- bool const negative = (b < 0);
- b = negative ? -b : b;
-
- int const hours = b / 60;
- int const minutes = b % 60;
-
- stringstream o;
- if (negative) {
- o << "-";
- } else {
- o << "+";
- }
-
- o << setw(2) << setfill('0') << hours << ":" << setw(2) << setfill('0') << minutes;
- return o.str ();
+ issue_date = tm_to_string (tm);
}
diff --git a/src/metadata.h b/src/metadata.h
index d71537fd..b4c0896d 100644
--- a/src/metadata.h
+++ b/src/metadata.h
@@ -51,11 +51,6 @@ public:
std::string issuer;
std::string creator;
std::string issue_date;
-
-private:
- friend class ::utc_offset_to_string_test;
-
- static std::string utc_offset_to_string (int);
};
}
diff --git a/src/util.cc b/src/util.cc
index d7b4f980..4035ffd1 100644
--- a/src/util.cc
+++ b/src/util.cc
@@ -50,6 +50,8 @@ using std::stringstream;
using std::min;
using std::max;
using std::list;
+using std::setw;
+using std::setfill;
using boost::shared_ptr;
using boost::lexical_cast;
using namespace libdcp;
@@ -368,3 +370,45 @@ libdcp::base64_decode (string const & in, unsigned char* out, int out_length)
return N;
}
+
+string
+libdcp::tm_to_string (struct tm* tm)
+{
+ char buffer[64];
+ strftime (buffer, 64, "%Y-%m-%dT%I:%M:%S", tm);
+
+ int offset = 0;
+
+#ifdef LIBDCP_POSIX
+ offset = tm->tm_gmtoff / 60;
+#else
+ TIME_ZONE_INFORMATION tz;
+ GetTimeZoneInformation (&tz);
+ offset = tz.Bias;
+#endif
+
+ return string (buffer) + utc_offset_to_string (offset);
+}
+
+/** @param b Offset from UTC to local time in minutes.
+ * @return string of the form e.g. -01:00.
+ */
+string
+libdcp::utc_offset_to_string (int b)
+{
+ bool const negative = (b < 0);
+ b = negative ? -b : b;
+
+ int const hours = b / 60;
+ int const minutes = b % 60;
+
+ stringstream o;
+ if (negative) {
+ o << "-";
+ } else {
+ o << "+";
+ }
+
+ o << setw(2) << setfill('0') << hours << ":" << setw(2) << setfill('0') << minutes;
+ return o.str ();
+}
diff --git a/src/util.h b/src/util.h
index 586d197f..80015593 100644
--- a/src/util.h
+++ b/src/util.h
@@ -75,6 +75,9 @@ extern void add_signer (xmlpp::Element* parent, CertificateChain const & certifi
extern int base64_decode (std::string const & in, unsigned char* out, int out_length);
+extern std::string tm_to_string (struct tm *);
+extern std::string utc_offset_to_string (int);
+
}
#endif