X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Ftypes.cc;h=9806c99712eb8d1a6c87e43cab4f39aeb530921f;hb=e0b2ef3dbac6fc4900cad6fea4395c212578602b;hp=ce50814644de70bd866d6a3d6bd11803f80d8cf7;hpb=1daaa67c21d4d28757cdcb06c5e26aec3817867c;p=dcpomatic.git diff --git a/src/lib/types.cc b/src/lib/types.cc index ce5081464..9806c9971 100644 --- a/src/lib/types.cc +++ b/src/lib/types.cc @@ -1,5 +1,5 @@ /* - Copyright (C) 2013 Carl Hetherington + Copyright (C) 2013-2019 Carl Hetherington This file is part of DCP-o-matic. @@ -19,15 +19,25 @@ */ #include "types.h" +#include "compose.hpp" #include "dcpomatic_assert.h" -#include "raw_convert.h" +#include +#include +#include +#include +#include #include #include +#include + +#include "i18n.h" using std::max; using std::min; using std::string; +using std::list; using boost::shared_ptr; +using dcp::raw_convert; bool operator== (Crop const & a, Crop const & b) { @@ -89,12 +99,58 @@ Crop::as_xml (xmlpp::Node* node) const node->add_child("BottomCrop")->add_child_text (raw_convert (bottom)); } +TextType +string_to_text_type (string s) +{ + if (s == "unknown") { + return TEXT_UNKNOWN; + } else if (s == "open-subtitle") { + return TEXT_OPEN_SUBTITLE; + } else if (s == "closed-caption") { + return TEXT_CLOSED_CAPTION; + } else { + throw MetadataError (String::compose ("Unknown text type %1", s)); + } +} + +string +text_type_to_string (TextType t) +{ + switch (t) { + case TEXT_UNKNOWN: + return "unknown"; + case TEXT_OPEN_SUBTITLE: + return "open-subtitle"; + case TEXT_CLOSED_CAPTION: + return "closed-caption"; + default: + DCPOMATIC_ASSERT (false); + } +} + +string +text_type_to_name (TextType t) +{ + switch (t) { + case TEXT_UNKNOWN: + return _("Timed text"); + case TEXT_OPEN_SUBTITLE: + return _("Open subtitles"); + case TEXT_CLOSED_CAPTION: + return _("Closed captions"); + default: + DCPOMATIC_ASSERT (false); + } +} + string video_frame_type_to_string (VideoFrameType t) { switch (t) { case VIDEO_FRAME_TYPE_2D: return "2d"; + case VIDEO_FRAME_TYPE_3D: + return "3d"; case VIDEO_FRAME_TYPE_3D_LEFT_RIGHT: return "3d-left-right"; case VIDEO_FRAME_TYPE_3D_TOP_BOTTOM: @@ -117,6 +173,8 @@ string_to_video_frame_type (string s) { if (s == "2d") { return VIDEO_FRAME_TYPE_2D; + } else if (s == "3d") { + return VIDEO_FRAME_TYPE_3D; } else if (s == "3d-left-right") { return VIDEO_FRAME_TYPE_3D_LEFT_RIGHT; } else if (s == "3d-top-bottom") { @@ -131,3 +189,29 @@ string_to_video_frame_type (string s) DCPOMATIC_ASSERT (false); } + +CPLSummary::CPLSummary (boost::filesystem::path p) + : dcp_directory (p.leaf().string()) +{ + dcp::DCP dcp (p); + list notes; + dcp.read (¬es); + if (!notes.empty()) { + throw dcp::DCPReadError(dcp::note_to_string(notes.front())); + } + + cpl_id = dcp.cpls().front()->id(); + cpl_annotation_text = dcp.cpls().front()->annotation_text(); + cpl_file = dcp.cpls().front()->file().get(); + + encrypted = false; + BOOST_FOREACH (shared_ptr j, dcp.cpls()) { + BOOST_FOREACH (shared_ptr k, j->reel_mxfs()) { + if (k->key_id()) { + encrypted = true; + } + } + } + + last_write_time = boost::filesystem::last_write_time (p); +}