X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2Flib%2Ftypes.cc;h=fd4b8906ce19e5c67e2c8e349028369a277e3f27;hb=94d5ba335224db075a95a76654f732ef54a4eabd;hp=d052b2a9a71dd3c458bc9126785a15af263e8e6c;hpb=3e12c68dc0451e73b5bc1a84d1d70f4999f7b4b5;p=dcpomatic.git diff --git a/src/lib/types.cc b/src/lib/types.cc index d052b2a9a..fd4b8906c 100644 --- a/src/lib/types.cc +++ b/src/lib/types.cc @@ -1,89 +1,122 @@ /* - Copyright (C) 2013 Carl Hetherington + Copyright (C) 2013-2019 Carl Hetherington - This program is free software; you can redistribute it and/or modify + This file is part of DCP-o-matic. + + DCP-o-matic is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. - This program is distributed in the hope that it will be useful, + DCP-o-matic is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + along with DCP-o-matic. If not, see . */ +#include "types.h" +#include "compose.hpp" +#include "dcpomatic_assert.h" +#include +#include +#include +#include +#include +#include +LIBDCP_DISABLE_WARNINGS #include +LIBDCP_ENABLE_WARNINGS #include -#include -#include "types.h" + +#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) + +TextType +string_to_text_type (string s) { - return (a.left == b.left && a.right == b.right && a.top == b.top && a.bottom == b.bottom); + 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)); + } } -bool operator!= (Crop const & a, Crop const & b) +string +text_type_to_string (TextType t) { - return !(a == b); + 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); + } } -/** @param r Resolution. - * @return Untranslated string representation. - */ string -resolution_to_string (Resolution r) +text_type_to_name (TextType t) { - switch (r) { - case RESOLUTION_2K: - return "2K"; - case RESOLUTION_4K: - return "4K"; + 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); } - - assert (false); - return ""; } - -Resolution -string_to_resolution (string s) +CPLSummary::CPLSummary (boost::filesystem::path p) + : dcp_directory (p.leaf().string()) { - if (s == "2K") { - return RESOLUTION_2K; + 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)); + } } - if (s == "4K") { - return RESOLUTION_4K; + 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; + } + } } - assert (false); - return RESOLUTION_2K; + boost::system::error_code ec; + auto last_write = boost::filesystem::last_write_time (p, ec); + last_write_time = ec ? 0 : last_write; } -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)); -}