X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Ftypes.cc;h=840ee3aa8b5608fb9ff946f04efdffa22c4f6eb9;hb=1d2a51bdc8315fa7283be329669860e435a1513f;hp=e3bedd667f7a716daee156db5451e2b6b376cc9c;hpb=73654117144c6de0ec4efe39ddc88485df546cc9;p=dcpomatic.git diff --git a/src/lib/types.cc b/src/lib/types.cc index e3bedd667..840ee3aa8 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,27 @@ */ #include "types.h" +#include "compose.hpp" #include "dcpomatic_assert.h" +#include "warnings.h" #include +#include +#include +#include +#include +DCPOMATIC_DISABLE_WARNINGS #include +DCPOMATIC_ENABLE_WARNINGS #include +#include "i18n.h" + using std::max; using std::min; using std::string; -using boost::shared_ptr; +using std::list; +using std::shared_ptr; +using std::vector; using dcp::raw_convert; bool operator== (Crop const & a, Crop const & b) @@ -90,6 +102,50 @@ 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) { @@ -136,3 +192,68 @@ 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); + + vector notes; + dcp.read (¬es); + for (auto i: notes) { + if (i.code() != dcp::VerificationNote::Code::EXTERNAL_ASSET) { + /* It's not just a warning about this DCP being a VF */ + throw dcp::ReadError(dcp::note_to_string(i)); + } + } + + cpl_id = dcp.cpls().front()->id(); + cpl_annotation_text = dcp.cpls().front()->annotation_text(); + cpl_file = dcp.cpls().front()->file().get(); + + encrypted = false; + for (auto j: dcp.cpls()) { + for (auto k: j->reel_file_assets()) { + if (k->key_id()) { + encrypted = true; + } + } + } + + last_write_time = boost::filesystem::last_write_time (p); +} + + +bool operator== (NamedChannel const& a, NamedChannel const& b) +{ + return a.name == b.name && a.index == b.index; +} + + +string +video_range_to_string (VideoRange r) +{ + switch (r) { + case VideoRange::FULL: + return "full"; + case VideoRange::VIDEO: + return "video"; + default: + DCPOMATIC_ASSERT (false); + } +} + + +VideoRange +string_to_video_range (string s) +{ + if (s == "full") { + return VideoRange::FULL; + } else if (s == "video") { + return VideoRange::VIDEO; + } + + DCPOMATIC_ASSERT (false); + return VideoRange::FULL; +} +