Try to clean up some aspects of video/audio/video-audio content; fixes crash with...
[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
68         enum AudioFrom {
69                 AUDIO_FFMPEG,
70                 AUDIO_SNDFILE
71         };
72
73         AudioFrom audio_from () const {
74                 return _audio_from;
75         }
76
77         std::list<boost::shared_ptr<const VideoContent> > video () const {
78                 return _video;
79         }
80
81         std::list<boost::shared_ptr<const AudioContent> > audio () const {
82                 return _audio;
83         }
84
85         std::string audio_digest () const;
86         std::string video_digest () const;
87
88         mutable boost::signals2::signal<void ()> Changed;
89         mutable boost::signals2::signal<void (boost::weak_ptr<Content>, int)> ContentChanged;
90         
91 private:
92         void content_changed (boost::weak_ptr<Content>, int);
93
94         /** where we should get our audio from */
95         AudioFrom _audio_from;
96
97         /** all our content which contains video */
98         std::list<boost::shared_ptr<const VideoContent> > _video;
99         /** all our content which contains audio.  This may contain the same objects
100          *  as _video for FFmpegContent.
101          */
102         std::list<boost::shared_ptr<const AudioContent> > _audio;
103
104         std::list<boost::signals2::connection> _content_connections;
105 };