2 Copyright (C) 2013-2014 Carl Hetherington <cth@carlh.net>
4 This program is free software; you can redistribute it and/or modify
5 it under the terms of the GNU General Public License as published by
6 the Free Software Foundation; either version 2 of the License, or
7 (at your option) any later version.
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU General Public License for more details.
14 You should have received a copy of the GNU General Public License
15 along with this program; if not, write to the Free Software
16 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20 /** @file src/lib/content_factory.cc
21 * @brief Methods to create content objects.
24 #include <libcxml/cxml.h>
25 #include "ffmpeg_content.h"
26 #include "image_content.h"
27 #include "sndfile_content.h"
28 #include "subrip_content.h"
29 #include "dcp_content.h"
34 using boost::shared_ptr;
36 /** Create a Content object from an XML node.
37 * @param film Film that the content will be in.
38 * @param node XML description.
39 * @param version XML state version.
40 * @param notes A list to which is added descriptions of any non-critial warnings / messages.
41 * @return Content object, or 0 if no content was recognised in the XML.
44 content_factory (shared_ptr<const Film> film, cxml::NodePtr node, int version, list<string>& notes)
46 string const type = node->string_child ("Type");
48 boost::shared_ptr<Content> content;
50 if (type == "FFmpeg") {
51 content.reset (new FFmpegContent (film, node, version, notes));
52 } else if (type == "Image") {
53 content.reset (new ImageContent (film, node, version));
54 } else if (type == "Sndfile") {
55 content.reset (new SndfileContent (film, node, version));
56 } else if (type == "SubRip") {
57 content.reset (new SubRipContent (film, node, version));
58 } else if (type == "DCP") {
59 content.reset (new DCPContent (film, node, version));
65 /** Create a Content object from a file, depending on its extension.
66 * @param film Film that the content will be in.
67 * @param path File's path.
68 * @return Content object.
71 content_factory (shared_ptr<const Film> film, boost::filesystem::path path)
73 shared_ptr<Content> content;
75 string ext = path.extension().string ();
76 transform (ext.begin(), ext.end(), ext.begin(), ::tolower);
78 if (valid_image_file (path)) {
79 content.reset (new ImageContent (film, path));
80 } else if (SndfileContent::valid_file (path)) {
81 content.reset (new SndfileContent (film, path));
82 } else if (ext == ".srt") {
83 content.reset (new SubRipContent (film, path));
85 content.reset (new FFmpegContent (film, path));