C++11 tidying.
[dcpomatic.git] / src / lib / ffmpeg_audio_stream.h
index 5e455d18aa086f26d6ae9a644d07c2b5005ac0f5..a5ed90c972e46f0a6297ff31eb17810bd8026fa3 100644 (file)
@@ -1,57 +1,67 @@
 /*
-    Copyright (C) 2013-2014 Carl Hetherington <cth@carlh.net>
+    Copyright (C) 2013-2021 Carl Hetherington <cth@carlh.net>
 
-    This program is free software; you can redistribute it and/or modify
+    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.
 
-    This program is distributed in the hope that it will be useful,
+    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 this program; if not, write to the Free Software
-    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+    along with DCP-o-matic.  If not, see <http://www.gnu.org/licenses/>.
 
 */
 
-#include "ffmpeg_stream.h"
-#include "audio_mapping.h"
+
+#include "audio_stream.h"
 #include "dcpomatic_time.h"
+#include "ffmpeg_stream.h"
 
-class ffmpeg_pts_offset_test;
 
-class FFmpegAudioStream : public FFmpegStream
+struct ffmpeg_pts_offset_test;
+
+
+class FFmpegAudioStream : public FFmpegStream, public AudioStream
 {
 public:
-       FFmpegAudioStream (std::string n, int i, int f, int c)
-               : FFmpegStream (n, i)
-               , frame_rate (f)
-               , channels (c)
-               , mapping (c)
-       {
-               mapping.make_default ();
-       }
+       FFmpegAudioStream (std::string name, int id, int frame_rate, Frame length, int channels)
+               : FFmpegStream (name, id)
+               , AudioStream (frame_rate, length, channels)
+       {}
+
+       FFmpegAudioStream (std::string name, std::string codec_name_, int id, int frame_rate, Frame length, int channels)
+               : FFmpegStream (name, id)
+               , AudioStream (frame_rate, length, channels)
+               , codec_name (codec_name_)
+       {}
+
+       FFmpegAudioStream (std::string name, int id, int frame_rate, Frame length, AudioMapping mapping)
+               : FFmpegStream (name, id)
+               , AudioStream (frame_rate, length, mapping)
+       {}
 
        FFmpegAudioStream (cxml::ConstNodePtr, int);
 
        void as_xml (xmlpp::Node *) const;
 
-       int frame_rate;
-       int channels;
-       AudioMapping mapping;
-       boost::optional<ContentTime> first_audio;
+       /* XXX: should probably be locked */
+
+       boost::optional<dcpomatic::ContentTime> first_audio;
+       boost::optional<std::string> codec_name;
 
 private:
-       friend class ffmpeg_pts_offset_test;
+       friend struct ffmpeg_pts_offset_test;
 
        /* Constructor for tests */
        FFmpegAudioStream ()
                : FFmpegStream ("", 0)
-               , frame_rate (0)
-               , channels (0)
-               , mapping (1)
+               , AudioStream (0, 0, 0)
        {}
 };
+