+2014-01-15 Carl Hetherington <cth@carlh.net>
+
+ * Hopefully fix badly-labelled MXFs when in Interop mode.
+
+2014-01-14 Carl Hetherington <cth@carlh.net>
+
+ * Version 1.63.2 released.
+
+2014-01-14 Carl Hetherington <cth@carlh.net>
+
+ * Fix problems with adding new soundtracks to FFmpeg content with
+ no audio track.
+
+ * Updated de_DE translation from Markus Raab.
+
+ * Version 1.63.1 released.
+
+2014-01-14 Carl Hetherington <cth@carlh.net>
+
+ * Try to fix subtitle problems when the video frame rate is being changed
+ from content to DCP.
+
+2014-01-13 Carl Hetherington <cth@carlh.net>
+
+ * Change 4:3 and 5:3 ratios to be precise rather than 1.33:1 and 1.66:1, and
+ also tweak 1.19:1 (#306).
+
+ * Version 1.63.0 released.
+
+2014-01-12 Carl Hetherington <cth@carlh.net>
+
+ * Fix crashes when using -3dB options in locales with a , decimal separator.
+
+ * Version 1.62.3 released.
+
+2014-01-11 Carl Hetherington <cth@carlh.net>
+
+ * Hopefully fix error on restarting a cancelled transcode job
+ on Windows.
+
+2014-01-10 Carl Hetherington <cth@carlh.net>
+
+ * Version 1.62.2 released.
+
+2014-01-10 Carl Hetherington <cth@carlh.net>
+
+ * Version 1.62.1 released.
+
+2014-01-10 Carl Hetherington <cth@carlh.net>
+
+ * Version 1.62.0 released.
+
+2014-01-10 Carl Hetherington <cth@carlh.net>
+
+ * Try to stop the queue of things to write filling up excessively
+ on fast CPUs.
+
+ * Try to fix double "are you sure" prompt on quitting with active jobs.
+
+ * Version 1.61.2 released.
+
2014-01-09 Carl Hetherington <cth@carlh.net>
* Version 1.61.1 released.
def dependencies(target):
return (('ffmpeg-cdist', '5ac3a6af077c10f07c31954c372a8f29e4e18e2a'),
- ('libdcp', '8803a19c6901ab3c3ff85c964343f08458e0824e'))
+ ('libdcp', '120bc84676be775e49a2ac94689ff33dce814f53'))
def build(target, options):
cmd = './waf configure --prefix=%s' % target.work_dir_cscript()
-dcpomatic (1.61.1-1) UNRELEASED; urgency=low
+dcpomatic (1.63.2-1) UNRELEASED; urgency=low
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
+ * New upstream release.
+ * New upstream release.
+ * New upstream release.
+ * New upstream release.
+ * New upstream release.
+ * New upstream release.
+ * New upstream release.
+ * New upstream release.
- -- Carl Hetherington <carl@d1stkfactory> Thu, 09 Jan 2014 21:22:14 +0000
+ -- Carl Hetherington <carl@d1stkfactory> Tue, 14 Jan 2014 22:41:33 +0000
dcpomatic (0.87-1) UNRELEASED; urgency=low
Encoder::~Encoder ()
{
terminate_threads ();
- if (_writer) {
- _writer->finish ();
- }
}
/** Add a worker thread for a each thread on a remote server. Caller must hold
return true;
}
- avcodec_get_frame_defaults (_frame);
-
shared_ptr<const Film> film = _film.lock ();
assert (film);
/* Subtitle PTS in seconds (within the source, not taking into account any of the
source that we may have chopped off for the DCP)
*/
+<<<<<<< HEAD
double const packet_time = (static_cast<double> (sub.pts ) / AV_TIME_BASE) + _pts_offset;
+=======
+ double const packet_time = (static_cast<double> (sub.pts ) / AV_TIME_BASE) + _video_pts_offset;
+
+>>>>>>> master
/* hence start time for this sub */
ContentTime const from = (packet_time + (double (sub.start_display_time) / 1e3)) * TIME_HZ;
ContentTime const to = (packet_time + (double (sub.end_display_time) / 1e3)) * TIME_HZ;
}
int frame_finished;
- avcodec_get_frame_defaults (_frame);
AVCodecContext* context = _format_context->streams[_packet.stream_index]->codec;
#else
log()->log ("libdcp built in optimised mode.");
#endif
+
+#ifdef DCPOMATIC_WINDOWS
+ OSVERSIONINFO info;
+ info.dwOSVersionInfoSize = sizeof (info);
+ GetVersionEx (&info);
+ log()->log (String::compose ("Windows version %1.%2.%3 SP %4", info.dwMajorVersion, info.dwMinorVersion, info.dwBuildNumber, info.szCSDVersion));
+#endif
+
log()->log (String::compose ("CPU: %1, %2 processors", cpu_info(), boost::thread::hardware_concurrency ()));
list<pair<string, string> > const m = mount_info ();
for (list<pair<string, string> >::const_iterator i = m.begin(); i != m.end(); ++i) {
pi->set_subtitle (_out_subtitle.image, _out_subtitle.position + container_offset);
}
+
#ifdef DCPOMATIC_DEBUG
_last_video = piece->content;
true
);
+<<<<<<< HEAD
_out_subtitle.from = _in_subtitle.subtitle->dcp_time;
_out_subtitle.to = _in_subtitle.subtitle->dcp_time_to;
+=======
+ /* XXX: hack */
+ Time from = _in_subtitle.from;
+ Time to = _in_subtitle.to;
+ shared_ptr<VideoContent> vc = dynamic_pointer_cast<VideoContent> (piece->content);
+ if (vc) {
+ from = rint (from * vc->video_frame_rate() / _film->video_frame_rate());
+ to = rint (to * vc->video_frame_rate() / _film->video_frame_rate());
+ }
+
+ _out_subtitle.from = from * piece->content->position ();
+ _out_subtitle.to = to + piece->content->position ();
+>>>>>>> master
}
/** Re-emit the last frame that was emitted, using current settings for crop, ratio, scaler and subtitles.
"Project-Id-Version: \n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2014-01-07 20:01+0000\n"
-"PO-Revision-Date: 2014-01-05 23:06+0100\n"
+"PO-Revision-Date: 2014-01-14 19:45+0100\n"
"Last-Translator: \n"
"Language-Team: LANGUAGE <LL@li.org>\n"
"Language: de\n"
#: src/lib/writer.cc:387
msgid "could not move audio MXF into the DCP (%1)"
-msgstr ""
+msgstr "Ton MXF kann nicht in das DCP verschoben werden (%1)"
#: src/lib/sndfile_decoder.cc:45
msgid "could not open audio file for reading"
void
Ratio::setup_ratios ()
{
- _ratios.push_back (new Ratio (float(1285) / 1080, "119", _("1.19"), "F"));
- _ratios.push_back (new Ratio (float(1436) / 1080, "133", _("4:3"), "F"));
+ _ratios.push_back (new Ratio (float(1290) / 1080, "119", _("1.19"), "F"));
+ _ratios.push_back (new Ratio (float(1440) / 1080, "133", _("4:3"), "F"));
_ratios.push_back (new Ratio (float(1480) / 1080, "137", _("Academy"), "F"));
_ratios.push_back (new Ratio (float(1485) / 1080, "138", _("1.375"), "F"));
- _ratios.push_back (new Ratio (float(1793) / 1080, "166", _("1.66"), "F"));
+ _ratios.push_back (new Ratio (float(1800) / 1080, "166", _("1.66"), "F"));
_ratios.push_back (new Ratio (float(1920) / 1080, "178", _("16:9"), "F"));
_ratios.push_back (new Ratio (float(1998) / 1080, "185", _("Flat"), "F"));
_ratios.push_back (new Ratio (float(2048) / 858, "239", _("Scope"), "S"));
_film->log()->log (N_("Transcode job completed successfully"));
- } catch (std::exception& e) {
-
+ } catch (...) {
set_progress (1);
set_state (FINISHED_ERROR);
- _film->log()->log (String::compose (N_("Transcode job failed (%1)"), e.what()));
-
+ _film->log()->log (N_("Transcode job failed or cancelled"));
+ _transcoder.reset ();
throw;
}
}
TranscodeJob::status () const
{
if (!_transcoder) {
- return _("0%");
+ return Job::status ();
}
float const fps = _transcoder->current_encoding_rate ();
using std::string;
using std::list;
using std::cout;
+using std::stringstream;
using boost::shared_ptr;
using boost::weak_ptr;
_picture_asset->set_edit_rate (_film->video_frame_rate ());
_picture_asset->set_size (fit_ratio_within (_film->container()->ratio(), _film->full_frame ()));
+ _picture_asset->set_interop (_film->interop ());
if (_film->encrypted ()) {
_picture_asset->set_key (_film->key ());
_picture_asset_writer = _picture_asset->start_write (_first_nonexistant_frame > 0);
- /* Write the sound asset into the film directory so that we leave the creation
- of the DCP directory until the last minute. Some versions of windows inexplicably
- don't like overwriting existing files here, so try to remove it using boost.
- */
- boost::system::error_code ec;
- boost::filesystem::remove (_film->file (_film->audio_mxf_filename ()), ec);
- if (ec) {
- _film->log()->log (String::compose ("Could not remove existing audio MXF file (%1)", ec.value ()));
- }
-
_sound_asset.reset (new libdcp::SoundAsset (_film->directory (), _film->audio_mxf_filename ()));
_sound_asset->set_edit_rate (_film->video_frame_rate ());
_sound_asset->set_channels (_film->audio_channels ());
_sound_asset->set_sampling_rate (_film->audio_frame_rate ());
+ _sound_asset->set_interop (_film->interop ());
if (_film->encrypted ()) {
_sound_asset->set_key (_film->key ());
}
+ /* Write the sound asset into the film directory so that we leave the creation
+ of the DCP directory until the last minute.
+ */
_sound_asset_writer = _sound_asset->start_write ();
_thread = new boost::thread (boost::bind (&Writer::thread, this));
job->sub (_("Encoding image data"));
}
+Writer::~Writer ()
+{
+ terminate_thread (false);
+}
+
void
Writer::write (shared_ptr<const EncodedData> encoded, int frame, Eyes eyes)
{
boost::mutex::scoped_lock lock (_mutex);
+ while (_queued_full_in_memory > _maximum_frames_in_memory) {
+ _full_condition.wait (lock);
+ }
+
QueueItem qi;
qi.type = QueueItem::FULL;
qi.encoded = encoded;
++_queued_full_in_memory;
}
- _condition.notify_all ();
+ _empty_condition.notify_all ();
}
void
{
boost::mutex::scoped_lock lock (_mutex);
+ while (_queued_full_in_memory > _maximum_frames_in_memory) {
+ _full_condition.wait (lock);
+ }
+
FILE* ifi = fopen_boost (_film->info_path (frame, eyes), "r");
libdcp::FrameInfo info (ifi);
fclose (ifi);
_queue.push_back (qi);
}
- _condition.notify_all ();
+ _empty_condition.notify_all ();
}
/** This method is not thread safe */
}
TIMING (N_("writer sleeps with a queue of %1"), _queue.size());
- _condition.wait (lock);
+ _empty_condition.wait (lock);
TIMING (N_("writer wakes with a queue of %1"), _queue.size());
}
qi.encoded.reset ();
--_queued_full_in_memory;
}
+
+ _full_condition.notify_all ();
}
}
catch (...)
}
void
-Writer::finish ()
+Writer::terminate_thread (bool can_throw)
{
- if (!_thread) {
+ boost::mutex::scoped_lock lock (_mutex);
+ if (_thread == 0) {
return;
}
- boost::mutex::scoped_lock lock (_mutex);
_finish = true;
- _condition.notify_all ();
+ _empty_condition.notify_all ();
+ _full_condition.notify_all ();
lock.unlock ();
- _thread->join ();
- rethrow ();
+ _thread->join ();
+ if (can_throw) {
+ rethrow ();
+ }
delete _thread;
_thread = 0;
+}
+
+void
+Writer::finish ()
+{
+ if (!_thread) {
+ return;
+ }
+
+ terminate_thread (true);
_picture_asset_writer->finalize ();
_sound_asset_writer->finalize ();
meta.set_issue_date_now ();
dcp.write_xml (_film->interop (), meta, _film->is_signed() ? make_signer () : shared_ptr<const libdcp::Signer> ());
- _film->log()->log (String::compose (N_("Wrote %1 FULL, %2 FAKE, %3 REPEAT; %4 pushed to disk"), _full_written, _fake_written, _repeat_written, _pushed_to_disk));
+ _film->log()->log (
+ String::compose (N_("Wrote %1 FULL, %2 FAKE, %3 REPEAT; %4 pushed to disk"), _full_written, _fake_written, _repeat_written, _pushed_to_disk)
+ );
}
/** Tell the writer that frame `f' should be a repeat of the frame before it */
{
boost::mutex::scoped_lock lock (_mutex);
+ while (_queued_full_in_memory > _maximum_frames_in_memory) {
+ _full_condition.wait (lock);
+ }
+
QueueItem qi;
qi.type = QueueItem::REPEAT;
qi.frame = f;
_queue.push_back (qi);
}
- _condition.notify_all ();
+ _empty_condition.notify_all ();
}
bool
{
public:
Writer (boost::shared_ptr<const Film>, boost::weak_ptr<Job>);
+ ~Writer ();
bool can_fake_write (int) const;
private:
void thread ();
+ void terminate_thread (bool);
void check_existing_picture_mxf ();
bool check_existing_picture_mxf_frame (FILE *, int, Eyes);
bool have_sequenced_image_at_queue_head ();
int _queued_full_in_memory;
/** mutex for thread state */
mutable boost::mutex _mutex;
- /** condition to manage thread wakeups */
- boost::condition _condition;
+ /** condition to manage thread wakeups when we have nothing to do */
+ boost::condition _empty_condition;
+ /** condition to manage thread wakeups when we have too much to do */
+ boost::condition _full_condition;
/** the data of the last written frame, or 0 if there isn't one */
boost::shared_ptr<const EncodedData> _last_written[EYES_COUNT];
/** the index of the last written frame */
void file_exit ()
{
- if (!should_close ()) {
- return;
- }
-
- maybe_save_then_delete_film ();
Close (true);
}
"Project-Id-Version: \n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2014-01-07 20:01+0000\n"
-"PO-Revision-Date: 2014-01-02 13:17+0100\n"
+"PO-Revision-Date: 2014-01-14 19:49+0100\n"
"Last-Translator: \n"
"Language-Team: LANGUAGE <LL@li.org>\n"
"Language: de\n"
#: src/tools/dcpomatic.cc:230
msgid "Check for updates"
-msgstr ""
+msgstr "Auf Updates überprüfen"
#: src/tools/dcpomatic.cc:638
msgid "Could not load film %1 (%2)"
msgstr "DCP-o-matic"
#: src/tools/dcpomatic.cc:229
-#, fuzzy
msgid "Encoding servers..."
msgstr "Encoding Server..."
"The DCP for this film will take up about %.1f Gb, and the disk that you are "
"using only has %.1f Gb available. Do you want to continue anyway?"
msgstr ""
+"Das DCP für diesen Film wird etwa %.1f GB groß. Auf dem ausgewählten "
+"Laufwerk sind aber nur %.1f GB frei. Möchten Sie trotzdem weitermachen ?"
#: src/tools/dcpomatic.cc:729
msgid "The DCP-o-matic download server could not be contacted."
-msgstr ""
+msgstr "Der DCP-o-matic Download Server ist nicht erreichbar."
#: src/tools/dcpomatic.cc:356
msgid ""
#: src/tools/dcpomatic.cc:724
msgid "There are no new versions of DCP-o-matic available."
-msgstr ""
+msgstr "Es ist keine neue Version des DCP-o-matic verfügbar."
#: src/tools/dcpomatic.cc:558
msgid "There are unfinished jobs; are you sure you want to quit?"
void Draw (wxGrid& grid, wxGridCellAttr &, wxDC& dc, const wxRect& rect, int row, int col, bool)
{
+ LocaleGuard lg;
+
dc.SetPen (*wxThePenList->FindOrCreatePen (wxColour (255, 255, 255), 1, wxPENSTYLE_SOLID));
dc.SetBrush (*wxTheBrushList->FindOrCreateBrush (wxColour (255, 255, 255), wxBRUSHSTYLE_SOLID));
dc.DrawRectangle (rect);
void
AudioMappingView::update_cells ()
{
+ LocaleGuard lg;
+
if (_grid->GetNumberRows ()) {
_grid->DeleteRows (0, _grid->GetNumberRows ());
}
overall_sizer->Layout ();
overall_sizer->SetSizeHints (this);
+
+ _name->SetFocus ();
}
NewFilmDialog::~NewFilmDialog ()
"Project-Id-Version: \n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2014-01-07 20:01+0000\n"
-"PO-Revision-Date: 2014-01-05 23:08+0100\n"
+"PO-Revision-Date: 2014-01-14 20:00+0100\n"
"Last-Translator: \n"
"Language-Team: LANGUAGE <LL@li.org>\n"
"Language: de\n"
#: src/wx/audio_mapping_view.cc:133
msgid "-3dB"
-msgstr ""
+msgstr "-3dB"
#: src/wx/colour_conversion_editor.cc:83
msgid "1 / "
#: src/wx/update_dialog.cc:34
msgid "A new version of DCP-o-matic is available."
-msgstr ""
+msgstr "Es ist eine neue Version von DCP-o-matic verfügbar."
#: src/wx/about_dialog.cc:30
msgid "About DCP-o-matic"
msgid ""
"Audio will be passed from content channel %d to DCP channel %d unaltered."
msgstr ""
+"Der Ton von Kanal %d wird ohne Veränderung an das DCP Kanal %d weitergegeben."
#: src/wx/audio_mapping_view.cc:324
#, c-format
"Audio will be passed from content channel %d to DCP channel %d with gain "
"%.1fdB."
msgstr ""
+"Der Ton von Kanal %d wird wird an das DCP Kanal %d mit %.1fdB Pegel "
+"weitergegeben."
#: src/wx/job_wrapper.cc:38
#, c-format
msgstr "Abbrechen"
#: src/wx/audio_gain_dialog.cc:26
-#, fuzzy
msgid "Channel gain"
-msgstr "Kanäle"
+msgstr "Kanal Pegel"
#: src/wx/audio_dialog.cc:44
msgid "Channels"
#: src/wx/config_dialog.cc:143
msgid "Check for testing updates as well as stable ones"
-msgstr ""
+msgstr "Überprüfung auf Updates auch für Test-Versionen."
#: src/wx/config_dialog.cc:139
msgid "Check for updates on startup"
-msgstr ""
+msgstr "Beim Starten auf Updates überprüfen."
#: src/wx/content_menu.cc:182
msgid "Choose a file"
msgstr "Bearbeiten..."
#: src/wx/cinema_dialog.cc:35
-#, fuzzy
msgid "Email address for KDM delivery"
-msgstr "Von Adresse für KDM Emails"
+msgstr "Email Adresse für KDM Zustellung"
#: src/wx/servers_list_dialog.cc:30
msgid "Encoding Servers"
#: src/wx/audio_mapping_view.cc:132
msgid "Full"
-msgstr ""
+msgstr "Ein"
#: src/wx/timing_panel.cc:42
msgid "Full length"
#: src/wx/audio_gain_dialog.cc:31
#, c-format
msgid "Gain for content channel %d in DCP channel %d"
-msgstr ""
+msgstr "Pegel des Kanals %d im DCP Kanal %d"
#: src/wx/properties_dialog.cc:57
msgid "Gb"
#: src/wx/update_dialog.cc:36
msgid "New versions of DCP-o-matic are available."
-msgstr ""
+msgstr "Eine neue Version von DCP-o-matic ist verfügbar."
#: src/wx/audio_mapping_view.cc:319
#, c-format
msgid "No audio will be passed from content channel %d to DCP channel %d."
-msgstr ""
+msgstr "Der Ton von Kanal %d wird nicht an das DCP Kanal %d weitergegeben."
#: src/wx/video_panel.cc:198
msgid "No stretch"
#: src/wx/audio_mapping_view.cc:131
msgid "Off"
-msgstr ""
+msgstr "Aus"
#: src/wx/config_dialog.cc:119
msgid "Outgoing mail server"
#: src/wx/audio_mapping_view.cc:327
msgid "Right click to change gain."
-msgstr ""
+msgstr "Rechtsklick für Pegeländerung"
#: src/wx/video_panel.cc:101
msgid "Right crop"
msgstr "Einschnappen"
#: src/wx/update_dialog.cc:43
-#, fuzzy
msgid "Stable version "
-msgstr "Inhalt Version"
+msgstr "Stabile Version"
#: src/wx/film_editor.cc:185
msgid "Standard"
msgstr "Gebiet (z.B. UK)"
#: src/wx/update_dialog.cc:48
-#, fuzzy
msgid "Test version "
-msgstr "Inhalt Version"
+msgstr "Test Version"
#: src/wx/content_menu.cc:223
msgid ""
#: src/wx/update_dialog.cc:27
msgid "Update"
-msgstr ""
+msgstr "Update"
#: src/wx/film_editor.cc:126
msgid "Use DCI name"
msgstr "Bild"
#: src/wx/timing_panel.cc:56
-#, fuzzy
msgid "Video frame rate"
-msgstr "Bild Rate"
+msgstr "Bildwiederholrate"
#: src/wx/subtitle_panel.cc:39
msgid "With Subtitles"
r = Ratio::from_id ("133");
BOOST_CHECK (r);
- BOOST_CHECK_EQUAL (fit_ratio_within (r->ratio(), libdcp::Size (2048, 1080)), libdcp::Size (1436, 1080));
+ BOOST_CHECK_EQUAL (fit_ratio_within (r->ratio(), libdcp::Size (2048, 1080)), libdcp::Size (1440, 1080));
r = Ratio::from_id ("137");
BOOST_CHECK (r);
r = Ratio::from_id ("166");
BOOST_CHECK (r);
- BOOST_CHECK_EQUAL (fit_ratio_within (r->ratio(), libdcp::Size (2048, 1080)), libdcp::Size (1793, 1080));
+ BOOST_CHECK_EQUAL (fit_ratio_within (r->ratio(), libdcp::Size (2048, 1080)), libdcp::Size (1800, 1080));
r = Ratio::from_id ("178");
BOOST_CHECK (r);
import sys
APPNAME = 'dcpomatic'
-VERSION = '1.61.2pre'
+VERSION = '1.63.2devel'
def options(opt):
opt.load('compiler_cxx')