From b0f078d851e2a84d2f9d2ae085f6aad837747eb1 Mon Sep 17 00:00:00 2001 From: Carl Hetherington Date: Thu, 26 May 2016 10:57:06 +0100 Subject: Factor out decoder creation to a factory method. --- src/lib/decoder_factory.cc | 86 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 86 insertions(+) create mode 100644 src/lib/decoder_factory.cc (limited to 'src/lib/decoder_factory.cc') diff --git a/src/lib/decoder_factory.cc b/src/lib/decoder_factory.cc new file mode 100644 index 000000000..7f53c9a4b --- /dev/null +++ b/src/lib/decoder_factory.cc @@ -0,0 +1,86 @@ +/* + Copyright (C) 2016 Carl Hetherington + + 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. + + 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 DCP-o-matic. If not, see . + +*/ + +#include "ffmpeg_content.h" +#include "ffmpeg_decoder.h" +#include "dcp_content.h" +#include "dcp_decoder.h" +#include "image_content.h" +#include "image_decoder.h" +#include "text_subtitle_content.h" +#include "text_subtitle_decoder.h" +#include "dcp_subtitle_content.h" +#include "dcp_subtitle_decoder.h" +#include "video_mxf_content.h" +#include "video_mxf_decoder.h" +#include + +using std::list; +using boost::shared_ptr; +using boost::dynamic_pointer_cast; + +shared_ptr +decoder_factory (shared_ptr content, list > old_image_decoders, shared_ptr log, bool fast) +{ + shared_ptr fc = dynamic_pointer_cast (content); + if (fc) { + return shared_ptr (new FFmpegDecoder (fc, log, fast)); + } + + shared_ptr dc = dynamic_pointer_cast (content); + if (dc) { + return shared_ptr (new DCPDecoder (dc, log, fast)); + } + + shared_ptr ic = dynamic_pointer_cast (content); + if (ic) { + shared_ptr decoder; + + /* See if we can re-use an old ImageDecoder */ + BOOST_FOREACH (shared_ptr i, old_image_decoders) { + if (i->content() == ic) { + decoder = i; + } + } + + if (!decoder) { + decoder.reset (new ImageDecoder (ic, log)); + } + + return decoder; + } + + shared_ptr rc = dynamic_pointer_cast (content); + if (rc) { + return shared_ptr (new TextSubtitleDecoder (rc)); + } + + shared_ptr dsc = dynamic_pointer_cast (content); + if (dsc) { + return shared_ptr (new DCPSubtitleDecoder (dsc)); + } + + shared_ptr vmc = dynamic_pointer_cast (content); + if (vmc) { + return shared_ptr (new VideoMXFDecoder (vmc, log)); + } + + return shared_ptr (); +} -- cgit v1.2.3