Merge branch 'master' into 1.0
[dcpomatic.git] / src / lib / playlist.h
1 /*
2     Copyright (C) 2013 Carl Hetherington <cth@carlh.net>
3
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.
8
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.
13
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.
17
18 */
19
20 #include <list>
21 #include <boost/shared_ptr.hpp>
22 #include <boost/enable_shared_from_this.hpp>
23 #include "video_source.h"
24 #include "audio_source.h"
25 #include "video_sink.h"
26 #include "audio_sink.h"
27 #include "ffmpeg_content.h"
28 #include "audio_mapping.h"
29
30 class Content;
31 class FFmpegContent;
32 class FFmpegDecoder;
33 class ImageMagickContent;
34 class ImageMagickDecoder;
35 class SndfileContent;
36 class SndfileDecoder;
37 class Job;
38 class Film;
39
40 /** @class Playlist
41  *  @brief A set of content files (video and audio), with knowledge of how they should be arranged into
42  *  a DCP.
43  *
44  * This class holds Content objects, and it knows how they should be arranged.  At the moment
45  * the ordering is implicit; video content is placed sequentially, and audio content is taken
46  * from the video unless any sound-only files are present.  If sound-only files exist, they
47  * are played simultaneously (i.e. they can be split up into multiple files for different channels)
48  */
49     
50 class Playlist
51 {
52 public:
53         Playlist ();
54
55         void setup (ContentList);
56
57         ContentAudioFrame audio_length () const;
58         int audio_channels () const;
59         int audio_frame_rate () const;
60         bool has_audio () const;
61         
62         float video_frame_rate () const;
63         libdcp::Size video_size () const;
64         ContentVideoFrame video_length () const;
65
66         AudioMapping default_audio_mapping () const;
67         ContentVideoFrame content_length () const;
68
69         enum AudioFrom {
70                 AUDIO_FFMPEG,
71                 AUDIO_SNDFILE
72         };
73
74         AudioFrom audio_from () const {
75                 return _audio_from;
76         }
77
78         std::list<boost::shared_ptr<const VideoContent> > video () const {
79                 return _video;
80         }
81
82         std::list<boost::shared_ptr<const AudioContent> > audio () const {
83                 return _audio;
84         }
85
86         std::string audio_digest () const;
87         std::string video_digest () const;
88
89         mutable boost::signals2::signal<void ()> Changed;
90         mutable boost::signals2::signal<void (boost::weak_ptr<Content>, int)> ContentChanged;
91         
92 private:
93         void content_changed (boost::weak_ptr<Content>, int);
94
95         /** where we should get our audio from */
96         AudioFrom _audio_from;
97
98         /** all our content which contains video */
99         std::list<boost::shared_ptr<const VideoContent> > _video;
100         /** all our content which contains audio.  This may contain the same objects
101          *  as _video for FFmpegContent.
102          */
103         std::list<boost::shared_ptr<const AudioContent> > _audio;
104
105         std::list<boost::signals2::connection> _content_connections;
106 };