<feed xmlns='http://www.w3.org/2005/Atom'>
<title>dcpomatic/src, branch v2.16.84</title>
<subtitle>DCP-o-matic DCP tools</subtitle>
<id>https://git.carlh.net/cgit/dcpomatic/atom?h=v2.16.84</id>
<link rel='self' href='https://git.carlh.net/cgit/dcpomatic/atom?h=v2.16.84'/>
<link rel='alternate' type='text/html' href='https://git.carlh.net/cgit/dcpomatic/'/>
<updated>2024-05-16T07:26:00Z</updated>
<entry>
<title>Supporters update.</title>
<updated>2024-05-16T07:26:00Z</updated>
<author>
<name>Carl Hetherington</name>
<email>cth@carlh.net</email>
</author>
<published>2024-05-16T07:26:00Z</published>
<link rel='alternate' type='text/html' href='https://git.carlh.net/cgit/dcpomatic/commit/?id=7a9cadc6fe86c74035dd971685b1acdc8f32d3fc'/>
<id>urn:sha1:7a9cadc6fe86c74035dd971685b1acdc8f32d3fc</id>
<content type='text'>
</content>
</entry>
<entry>
<title>Update DCP encoder progress on all passe()es, not just when audio is emitted.</title>
<updated>2024-05-15T21:49:51Z</updated>
<author>
<name>Carl Hetherington</name>
<email>cth@carlh.net</email>
</author>
<published>2024-05-12T13:38:31Z</published>
<link rel='alternate' type='text/html' href='https://git.carlh.net/cgit/dcpomatic/commit/?id=61130610f6d01fe6b1682d91933eb7dbbb1eac76'/>
<id>urn:sha1:61130610f6d01fe6b1682d91933eb7dbbb1eac76</id>
<content type='text'>
</content>
</entry>
<entry>
<title>Get DCP transcode progress from the player (#2804).</title>
<updated>2024-05-15T21:49:51Z</updated>
<author>
<name>Carl Hetherington</name>
<email>cth@carlh.net</email>
</author>
<published>2024-05-12T13:22:28Z</published>
<link rel='alternate' type='text/html' href='https://git.carlh.net/cgit/dcpomatic/commit/?id=26678a922a1808db33954e002c165678d8191fc6'/>
<id>urn:sha1:26678a922a1808db33954e002c165678d8191fc6</id>
<content type='text'>
</content>
</entry>
<entry>
<title>Fix warning cause by previous libdcp bump.</title>
<updated>2024-05-13T22:02:54Z</updated>
<author>
<name>Carl Hetherington</name>
<email>cth@carlh.net</email>
</author>
<published>2024-05-13T22:02:54Z</published>
<link rel='alternate' type='text/html' href='https://git.carlh.net/cgit/dcpomatic/commit/?id=bcf0f131281399f93fe2ca57c99d1046b3a2fb44'/>
<id>urn:sha1:bcf0f131281399f93fe2ca57c99d1046b3a2fb44</id>
<content type='text'>
</content>
</entry>
<entry>
<title>Don't bother decoding audio if none of it is mapped (#2809).</title>
<updated>2024-05-13T21:03:04Z</updated>
<author>
<name>Carl Hetherington</name>
<email>cth@carlh.net</email>
</author>
<published>2024-05-12T23:20:27Z</published>
<link rel='alternate' type='text/html' href='https://git.carlh.net/cgit/dcpomatic/commit/?id=e2ea739fcaa8077975a8559f267a1b1377b7e100'/>
<id>urn:sha1:e2ea739fcaa8077975a8559f267a1b1377b7e100</id>
<content type='text'>
On a test adding subs from an MKV to an existing DCP this reduces
the processing time from ~2h to ~1m because it doesn't resample the
audio from the whole of the MKV, only to discard it.
</content>
</entry>
<entry>
<title>Fix link icon width again.</title>
<updated>2024-05-11T08:57:01Z</updated>
<author>
<name>Carl Hetherington</name>
<email>cth@carlh.net</email>
</author>
<published>2024-05-11T08:57:01Z</published>
<link rel='alternate' type='text/html' href='https://git.carlh.net/cgit/dcpomatic/commit/?id=63fd3d143387bc0dbbbe228955421a59239dbe5c'/>
<id>urn:sha1:63fd3d143387bc0dbbbe228955421a59239dbe5c</id>
<content type='text'>
Seems to be different on wxWidgets 3.1.x vs 3.2.x.
</content>
</entry>
<entry>
<title>Work around deadlock when destroying J2KEncoder with a full writer queue (#2784).</title>
<updated>2024-05-07T23:33:41Z</updated>
<author>
<name>Carl Hetherington</name>
<email>cth@carlh.net</email>
</author>
<published>2024-05-05T19:34:29Z</published>
<link rel='alternate' type='text/html' href='https://git.carlh.net/cgit/dcpomatic/commit/?id=32d04ddb5c583938f470ed74bda8a50cc2ec9960'/>
<id>urn:sha1:32d04ddb5c583938f470ed74bda8a50cc2ec9960</id>
<content type='text'>
This feels like a hack, but I can't think of a nicer way to do it.

The interruption disable makes sense because when we destroy encoder threads
during a DCP encode (because a remote server goes away, for example) we don't
want any frames to be lost due to the encode thread being interrupted between
taking the frame off the queue and sending it to the writer.

When we're destroying the encoder we don't care about this, but I can't see
how you'd differentiate.

Maybe the encoder queue could have two lists: to-do and in-progress;
the encoder thread atomically moves a frame from to-do to in-progress,
but then how do you know when the in-progress ones are orphaned and need
to be re-added to the main queue.

You could make the writer return saying "no" if the queue is full (rather
than blocking and waiting for the queue to empty) but that seems wasteful
as then the frame would be re-encoded.
</content>
</entry>
<entry>
<title>Add some missing includes.</title>
<updated>2024-05-07T23:33:28Z</updated>
<author>
<name>Carl Hetherington</name>
<email>cth@carlh.net</email>
</author>
<published>2024-05-05T19:34:22Z</published>
<link rel='alternate' type='text/html' href='https://git.carlh.net/cgit/dcpomatic/commit/?id=f5e08d6f36161a980682dd3cb9b0678d44adadfd'/>
<id>urn:sha1:f5e08d6f36161a980682dd3cb9b0678d44adadfd</id>
<content type='text'>
</content>
</entry>
<entry>
<title>Supporters update.</title>
<updated>2024-05-07T22:33:13Z</updated>
<author>
<name>Carl Hetherington</name>
<email>cth@carlh.net</email>
</author>
<published>2024-05-07T22:33:13Z</published>
<link rel='alternate' type='text/html' href='https://git.carlh.net/cgit/dcpomatic/commit/?id=4541d4d553b5903b63753f22254a6471c73337da'/>
<id>urn:sha1:4541d4d553b5903b63753f22254a6471c73337da</id>
<content type='text'>
</content>
</entry>
<entry>
<title>Remove in-place translations support.</title>
<updated>2024-05-03T22:19:02Z</updated>
<author>
<name>Carl Hetherington</name>
<email>cth@carlh.net</email>
</author>
<published>2024-05-03T22:19:00Z</published>
<link rel='alternate' type='text/html' href='https://git.carlh.net/cgit/dcpomatic/commit/?id=f8a0f78aaeb113cbf952d48b8d61bffc8bd2ee6d'/>
<id>urn:sha1:f8a0f78aaeb113cbf952d48b8d61bffc8bd2ee6d</id>
<content type='text'>
It feels like there have been too many failed attempts and not
enough (maybe zero?) successes so it's just too confusing.
</content>
</entry>
</feed>
