+2016-09-22 Carl Hetherington <cth@carlh.net>
+
+ * Version 2.9.26 released.
+
+2016-09-21 Carl Hetherington <cth@carlh.net>
+
+ * Add confirm dialogue for job cancellation.
+
+ * Version 2.9.25 released.
+
2016-09-21 Carl Hetherington <cth@carlh.net>
* Version 2.9.24 released.
ffmpeg_options = {}
return (('ffmpeg-cdist', '1d4a1a4', ffmpeg_options),
- ('libdcp', 'd6fda12'),
+ ('libdcp', '0acd045'),
('libsub', '3db5052'))
def configure_options(target):
-dcpomatic (2.9.24-1) UNRELEASED; urgency=low
+dcpomatic (2.9.26-1) UNRELEASED; urgency=low
[ Carl Hetherington ]
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
+ * New upstream release.
+ * New upstream release.
- -- Carl Hetherington <carl@d1stkfactory> Wed, 21 Sep 2016 00:24:15 +0100
+ -- Carl Hetherington <carl@d1stkfactory> Thu, 22 Sep 2016 00:19:23 +0100
dcpomatic (0.87-1) UNRELEASED; urgency=low
using boost::dynamic_pointer_cast;
using dcp::raw_convert;
-int const DCPContentProperty::CAN_BE_PLAYED = 600;
-int const DCPContentProperty::REFERENCE_VIDEO = 601;
-int const DCPContentProperty::REFERENCE_AUDIO = 602;
-int const DCPContentProperty::REFERENCE_SUBTITLE = 603;
+int const DCPContentProperty::NEEDS_ASSETS = 600;
+int const DCPContentProperty::NEEDS_KDM = 601;
+int const DCPContentProperty::REFERENCE_VIDEO = 602;
+int const DCPContentProperty::REFERENCE_AUDIO = 603;
+int const DCPContentProperty::REFERENCE_SUBTITLE = 604;
DCPContent::DCPContent (shared_ptr<const Film> film, boost::filesystem::path p)
: Content (film)
void
DCPContent::examine (shared_ptr<Job> job)
{
- bool const could_be_played = can_be_played ();
+ bool const needed_assets = needs_assets ();
+ bool const needed_kdm = needs_kdm ();
job->set_progress_unknown ();
Content::examine (job);
_cpl = examiner->cpl ();
}
- if (could_be_played != can_be_played ()) {
- signal_changed (DCPContentProperty::CAN_BE_PLAYED);
+ if (needed_assets != needs_assets ()) {
+ signal_changed (DCPContentProperty::NEEDS_ASSETS);
+ }
+
+ if (needed_kdm != needs_kdm ()) {
+ signal_changed (DCPContentProperty::NEEDS_KDM);
}
video->set_frame_type (_three_d ? VIDEO_FRAME_TYPE_3D : VIDEO_FRAME_TYPE_2D);
class DCPContentProperty
{
public:
- static int const CAN_BE_PLAYED;
+ static int const NEEDS_KDM;
+ static int const NEEDS_ASSETS;
static int const REFERENCE_VIDEO;
static int const REFERENCE_AUDIO;
static int const REFERENCE_SUBTITLE;
#include <dcp/stereo_picture_asset.h>
#include <dcp/stereo_picture_asset_reader.h>
#include <dcp/stereo_picture_frame.h>
+#include <dcp/sound_asset.h>
+#include <dcp/sound_asset_reader.h>
+#include <dcp/subtitle_asset.h>
#include <dcp/reel_subtitle_asset.h>
#include <dcp/sound_asset.h>
#include <boost/foreach.hpp>
_encrypted = cpl->encrypted ();
_kdm_valid = true;
- /* Check that we can read the first picture frame */
+ /* Check that we can read the first picture, sound and subtitle frames of each reel */
try {
- if (!cpl->reels().empty ()) {
- shared_ptr<dcp::PictureAsset> asset = cpl->reels().front()->main_picture()->asset ();
- shared_ptr<dcp::MonoPictureAsset> mono = dynamic_pointer_cast<dcp::MonoPictureAsset> (asset);
- shared_ptr<dcp::StereoPictureAsset> stereo = dynamic_pointer_cast<dcp::StereoPictureAsset> (asset);
+ BOOST_FOREACH (shared_ptr<dcp::Reel> i, cpl->reels()) {
+ shared_ptr<dcp::PictureAsset> pic = i->main_picture()->asset ();
+ shared_ptr<dcp::MonoPictureAsset> mono = dynamic_pointer_cast<dcp::MonoPictureAsset> (pic);
+ shared_ptr<dcp::StereoPictureAsset> stereo = dynamic_pointer_cast<dcp::StereoPictureAsset> (pic);
if (mono) {
mono->start_read()->get_frame(0)->xyz_image ();
stereo->start_read()->get_frame(0)->xyz_image (dcp::EYE_LEFT);
}
+ if (i->main_sound()) {
+ shared_ptr<dcp::SoundAsset> sound = i->main_sound()->asset ();
+ i->main_sound()->asset()->start_read()->get_frame(0);
+ }
+
+ if (i->main_subtitle()) {
+ i->main_subtitle()->asset()->subtitles ();
+ }
}
} catch (dcp::DCPReadError& e) {
_kdm_valid = false;
property == ContentProperty::TRIM_END ||
property == ContentProperty::PATH ||
property == VideoContentProperty::FRAME_TYPE ||
- property == DCPContentProperty::CAN_BE_PLAYED ||
+ property == DCPContentProperty::NEEDS_ASSETS ||
+ property == DCPContentProperty::NEEDS_KDM ||
property == SubtitleContentProperty::COLOUR ||
property == SubtitleContentProperty::OUTLINE ||
property == SubtitleContentProperty::SHADOW ||
void
ContentPanel::film_content_changed (int property)
{
- if (property == ContentProperty::PATH || property == DCPContentProperty::CAN_BE_PLAYED) {
+ if (property == ContentProperty::PATH || property == DCPContentProperty::NEEDS_ASSETS || property == DCPContentProperty::NEEDS_KDM) {
setup ();
}
void
JobView::cancel_clicked (wxCommandEvent &)
{
- _job->cancel ();
+ if (confirm_dialog (_parent, _("Are you sure you want to cancel this job?"))) {
+ _job->cancel ();
+ }
}
void
from waflib import Logs, Context
APPNAME = 'dcpomatic'
-VERSION = '2.9.24devel'
+VERSION = '2.9.26devel'
def options(opt):
opt.load('compiler_cxx')