Missing includes.
[libdcp.git] / src / metadata.cc
index 7e900e5006cab7991ec9d9949fd0151784da15ad..acbc3b2ed36fb7bcdc07084d5cd684f28cdb3451 100644 (file)
  *  @brief Metadata for writing to the DCP.
  */
 
+#include <sstream>
+#include <iomanip>
 #include <time.h>
+#ifdef LIBDCP_WINDOWS
+#include <windows.h>
+#endif
 #include "metadata.h"
+#include "util.h"
 
 using namespace std;
 using namespace libdcp;
 
-Metadata* Metadata::_instance = 0;
-
-/** Construct a Metadata object with some default values */
-Metadata::Metadata ()
+MXFMetadata::MXFMetadata ()
        : company_name ("libdcp")
        , product_name ("libdcp")
        , product_version (LIBDCP_VERSION)
-       , issuer ("libdcp" LIBDCP_VERSION)
-       , creator ("libdcp" LIBDCP_VERSION)
 {
-       char buffer[64];
-       time_t now;
-       time (&now);
-       struct tm* tm = localtime (&now);
-       strftime (buffer, 64, "%Y-%m-%dT%I:%M:%S+00:00", tm);
-       issue_date = string (buffer);
+
 }
 
-/** @return Singleton Metadata instance */
-Metadata *
-Metadata::instance ()
+
+XMLMetadata::XMLMetadata ()
+       : issuer ("libdcp" LIBDCP_VERSION)
+       , creator ("libdcp" LIBDCP_VERSION)
 {
-       if (_instance == 0) {
-               _instance = new Metadata;
-       }
+       set_issue_date_now ();
+}
 
-       return _instance;
+void
+XMLMetadata::set_issue_date_now ()
+{
+       time_t now = time (0);
+       struct tm* tm = localtime (&now);
+       issue_date = tm_to_string (tm);
 }
-