diff options
| author | Carl Hetherington <cth@carlh.net> | 2013-09-18 08:18:40 +0100 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2013-09-18 08:18:40 +0100 |
| commit | 56782052e43a1e010f7f07cbc0dbaed5b6cb50a3 (patch) | |
| tree | 8f8396e2ae07b3ab6b5cfeeb85d7d9d35e404c38 /src | |
| parent | 29a7edbc3d4a92bd1bf66948d3553d4b88f2d291 (diff) | |
Separate time -> string functions out.
Diffstat (limited to 'src')
| -rw-r--r-- | src/metadata.cc | 41 | ||||
| -rw-r--r-- | src/metadata.h | 5 | ||||
| -rw-r--r-- | src/util.cc | 44 | ||||
| -rw-r--r-- | src/util.h | 3 |
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 (); +} @@ -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 |
