diff options
| author | Carl Hetherington <cth@carlh.net> | 2019-07-25 11:37:52 +0100 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2019-07-25 11:37:52 +0100 |
| commit | 57f112a2bd073123a686141be6c16ba997349056 (patch) | |
| tree | ef4e181329049b447ae977157872029691b64f85 /src/lib/decoder_factory.cc | |
| parent | 122111f680dc186f936960394f0720374d7d5dca (diff) | |
Optimise decoder_factory for DCPDecoder by offering the old decoder
(if available) to recover the list of reels from, rather than having
to scan the filesystem again.
Diffstat (limited to 'src/lib/decoder_factory.cc')
| -rw-r--r-- | src/lib/decoder_factory.cc | 18 |
1 files changed, 15 insertions, 3 deletions
diff --git a/src/lib/decoder_factory.cc b/src/lib/decoder_factory.cc index 4b2a594e1..5d758956d 100644 --- a/src/lib/decoder_factory.cc +++ b/src/lib/decoder_factory.cc @@ -1,5 +1,5 @@ /* - Copyright (C) 2016 Carl Hetherington <cth@carlh.net> + Copyright (C) 2016-2019 Carl Hetherington <cth@carlh.net> This file is part of DCP-o-matic. @@ -30,14 +30,26 @@ #include "dcp_subtitle_decoder.h" #include "video_mxf_content.h" #include "video_mxf_decoder.h" +#include "timer.h" #include <boost/foreach.hpp> using std::list; using boost::shared_ptr; using boost::dynamic_pointer_cast; +template <class T> +shared_ptr<T> +maybe_cast (shared_ptr<Decoder> d) +{ + if (!d) { + return shared_ptr<T> (); + } + return dynamic_pointer_cast<T> (d); +} + +/** @param old_decoder A `used' decoder that has been previously made for this piece of content, or 0 */ shared_ptr<Decoder> -decoder_factory (shared_ptr<const Film> film, shared_ptr<const Content> content, bool fast) +decoder_factory (shared_ptr<const Film> film, shared_ptr<const Content> content, bool fast, shared_ptr<Decoder> old_decoder) { shared_ptr<const FFmpegContent> fc = dynamic_pointer_cast<const FFmpegContent> (content); if (fc) { @@ -47,7 +59,7 @@ decoder_factory (shared_ptr<const Film> film, shared_ptr<const Content> content, shared_ptr<const DCPContent> dc = dynamic_pointer_cast<const DCPContent> (content); if (dc) { try { - return shared_ptr<Decoder> (new DCPDecoder(film, dc, fast)); + return shared_ptr<Decoder> (new DCPDecoder(film, dc, fast, maybe_cast<DCPDecoder>(old_decoder))); } catch (KDMError& e) { /* This will be found and reported to the user when the content is examined */ return shared_ptr<Decoder>(); |
