X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Ftypes.cc;h=3ac3690c0bd8dfccb567b67ae693a389d63e6d71;hb=eae7b9001d7978d206626995e94c3bb6311cee77;hp=ce50814644de70bd866d6a3d6bd11803f80d8cf7;hpb=1daaa67c21d4d28757cdcb06c5e26aec3817867c;p=dcpomatic.git diff --git a/src/lib/types.cc b/src/lib/types.cc index ce5081464..3ac3690c0 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,115 +19,60 @@ */ #include "types.h" +#include "compose.hpp" #include "dcpomatic_assert.h" -#include "raw_convert.h" +#include +#include +#include +#include +#include +#include +LIBDCP_DISABLE_WARNINGS #include +LIBDCP_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) -{ - 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) +CPLSummary::CPLSummary (boost::filesystem::path p) + : dcp_directory (p.leaf().string()) { - return !(a == b); -} - -/** @param r Resolution. - * @return Untranslated string representation. - */ -string -resolution_to_string (Resolution r) -{ - switch (r) { - case RESOLUTION_2K: - return "2K"; - case RESOLUTION_4K: - return "4K"; - } - - DCPOMATIC_ASSERT (false); - return ""; -} - - -Resolution -string_to_resolution (string s) -{ - if (s == "2K") { - return RESOLUTION_2K; - } - - if (s == "4K") { - return RESOLUTION_4K; + 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)); + } } - DCPOMATIC_ASSERT (false); - return RESOLUTION_2K; -} - -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)); -} - -string -video_frame_type_to_string (VideoFrameType t) -{ - switch (t) { - case VIDEO_FRAME_TYPE_2D: - return "2d"; - case VIDEO_FRAME_TYPE_3D_LEFT_RIGHT: - return "3d-left-right"; - case VIDEO_FRAME_TYPE_3D_TOP_BOTTOM: - return "3d-top-bottom"; - case VIDEO_FRAME_TYPE_3D_ALTERNATE: - return "3d-alternate"; - case VIDEO_FRAME_TYPE_3D_LEFT: - return "3d-left"; - case VIDEO_FRAME_TYPE_3D_RIGHT: - return "3d-right"; - default: - DCPOMATIC_ASSERT (false); + 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->encrypted()) { + encrypted = true; + } + } } - 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; } -VideoFrameType -string_to_video_frame_type (string s) -{ - if (s == "2d") { - return VIDEO_FRAME_TYPE_2D; - } else if (s == "3d-left-right") { - return VIDEO_FRAME_TYPE_3D_LEFT_RIGHT; - } else if (s == "3d-top-bottom") { - return VIDEO_FRAME_TYPE_3D_TOP_BOTTOM; - } else if (s == "3d-alternate") { - return VIDEO_FRAME_TYPE_3D_ALTERNATE; - } else if (s == "3d-left") { - return VIDEO_FRAME_TYPE_3D_LEFT; - } else if (s == "3d-right") { - return VIDEO_FRAME_TYPE_3D_RIGHT; - } - DCPOMATIC_ASSERT (false); -}