X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Ftypes.cc;h=3ac3690c0bd8dfccb567b67ae693a389d63e6d71;hb=1c73379ed8483dcf71c5ccfc459c2c22516a9aef;hp=3586cdb935b67bc065a55a99592611967eb13706;hpb=8fedaaa75c4586a4cc7ffb393bd71d1fdb091dc8;p=dcpomatic.git diff --git a/src/lib/types.cc b/src/lib/types.cc index 3586cdb93..3ac3690c0 100644 --- a/src/lib/types.cc +++ b/src/lib/types.cc @@ -21,15 +21,15 @@ #include "types.h" #include "compose.hpp" #include "dcpomatic_assert.h" -#include "warnings.h" -#include #include #include -#include +#include #include -DCPOMATIC_DISABLE_WARNINGS +#include +#include +LIBDCP_DISABLE_WARNINGS #include -DCPOMATIC_ENABLE_WARNINGS +LIBDCP_ENABLE_WARNINGS #include #include "i18n.h" @@ -42,156 +42,6 @@ using std::shared_ptr; using std::vector; using dcp::raw_convert; -bool operator== (Crop const & a, Crop const & b) -{ - return (a.left == b.left && a.right == b.right && a.top == b.top && a.bottom == b.bottom); -} - -bool operator!= (Crop const & a, Crop const & b) -{ - return !(a == b); -} - -/** @param r Resolution. - * @return Untranslated string representation. - */ -string -resolution_to_string (Resolution r) -{ - switch (r) { - case Resolution::TWO_K: - return "2K"; - case Resolution::FOUR_K: - return "4K"; - } - - DCPOMATIC_ASSERT (false); - return ""; -} - - -Resolution -string_to_resolution (string s) -{ - if (s == "2K") { - return Resolution::TWO_K; - } - - if (s == "4K") { - return Resolution::FOUR_K; - } - - DCPOMATIC_ASSERT (false); - return Resolution::TWO_K; -} - -Crop::Crop (shared_ptr node) -{ - left = node->number_child ("LeftCrop"); - right = node->number_child ("RightCrop"); - top = node->number_child ("TopCrop"); - bottom = node->number_child ("BottomCrop"); -} - -void -Crop::as_xml (xmlpp::Node* node) const -{ - node->add_child("LeftCrop")->add_child_text (raw_convert (left)); - node->add_child("RightCrop")->add_child_text (raw_convert (right)); - node->add_child("TopCrop")->add_child_text (raw_convert (top)); - node->add_child("BottomCrop")->add_child_text (raw_convert (bottom)); -} - -TextType -string_to_text_type (string s) -{ - if (s == "unknown") { - return TextType::UNKNOWN; - } else if (s == "open-subtitle") { - return TextType::OPEN_SUBTITLE; - } else if (s == "closed-caption") { - return TextType::CLOSED_CAPTION; - } else { - throw MetadataError (String::compose ("Unknown text type %1", s)); - } -} - -string -text_type_to_string (TextType t) -{ - switch (t) { - case TextType::UNKNOWN: - return "unknown"; - case TextType::OPEN_SUBTITLE: - return "open-subtitle"; - case TextType::CLOSED_CAPTION: - return "closed-caption"; - default: - DCPOMATIC_ASSERT (false); - } -} - -string -text_type_to_name (TextType t) -{ - switch (t) { - case TextType::UNKNOWN: - return _("Timed text"); - case TextType::OPEN_SUBTITLE: - return _("Open subtitles"); - case TextType::CLOSED_CAPTION: - return _("Closed captions"); - default: - DCPOMATIC_ASSERT (false); - } -} - -string -video_frame_type_to_string (VideoFrameType t) -{ - switch (t) { - case VideoFrameType::TWO_D: - return "2d"; - case VideoFrameType::THREE_D: - return "3d"; - case VideoFrameType::THREE_D_LEFT_RIGHT: - return "3d-left-right"; - case VideoFrameType::THREE_D_TOP_BOTTOM: - return "3d-top-bottom"; - case VideoFrameType::THREE_D_ALTERNATE: - return "3d-alternate"; - case VideoFrameType::THREE_D_LEFT: - return "3d-left"; - case VideoFrameType::THREE_D_RIGHT: - return "3d-right"; - default: - DCPOMATIC_ASSERT (false); - } - - DCPOMATIC_ASSERT (false); -} - -VideoFrameType -string_to_video_frame_type (string s) -{ - if (s == "2d") { - return VideoFrameType::TWO_D; - } else if (s == "3d") { - return VideoFrameType::THREE_D; - } else if (s == "3d-left-right") { - return VideoFrameType::THREE_D_LEFT_RIGHT; - } else if (s == "3d-top-bottom") { - return VideoFrameType::THREE_D_TOP_BOTTOM; - } else if (s == "3d-alternate") { - return VideoFrameType::THREE_D_ALTERNATE; - } else if (s == "3d-left") { - return VideoFrameType::THREE_D_LEFT; - } else if (s == "3d-right") { - return VideoFrameType::THREE_D_RIGHT; - } - - DCPOMATIC_ASSERT (false); -} CPLSummary::CPLSummary (boost::filesystem::path p) : dcp_directory (p.leaf().string()) @@ -214,46 +64,15 @@ CPLSummary::CPLSummary (boost::filesystem::path p) encrypted = false; for (auto j: dcp.cpls()) { for (auto k: j->reel_file_assets()) { - if (k->key_id()) { + if (k->encrypted()) { 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); - } + boost::system::error_code ec; + auto last_write = boost::filesystem::last_write_time (p, ec); + last_write_time = ec ? 0 : last_write; } -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; -} -