X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fffmpeg_audio_stream.h;h=a5ed90c972e46f0a6297ff31eb17810bd8026fa3;hb=f41d6c693c1cd5816bef2f1651ed017c8564213c;hp=84882e89c89c3a9f1057368c35da603b1d708edb;hpb=e60bb3e51bd1508b149e6b8f6608f09b5196ae26;p=dcpomatic.git diff --git a/src/lib/ffmpeg_audio_stream.h b/src/lib/ffmpeg_audio_stream.h index 84882e89c..a5ed90c97 100644 --- a/src/lib/ffmpeg_audio_stream.h +++ b/src/lib/ffmpeg_audio_stream.h @@ -1,35 +1,49 @@ /* - Copyright (C) 2013-2014 Carl Hetherington + Copyright (C) 2013-2021 Carl Hetherington - 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 . */ -#include "ffmpeg_stream.h" -#include "audio_mapping.h" + #include "audio_stream.h" #include "dcpomatic_time.h" +#include "ffmpeg_stream.h" + struct ffmpeg_pts_offset_test; + class FFmpegAudioStream : public FFmpegStream, public AudioStream { public: - FFmpegAudioStream (std::string name, int id, int frame_rate, int channels) + FFmpegAudioStream (std::string name, int id, int frame_rate, Frame length, int channels) : FFmpegStream (name, id) - , AudioStream (frame_rate, channels) + , 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); @@ -38,7 +52,8 @@ public: /* XXX: should probably be locked */ - boost::optional first_audio; + boost::optional first_audio; + boost::optional codec_name; private: friend struct ffmpeg_pts_offset_test; @@ -46,6 +61,7 @@ private: /* Constructor for tests */ FFmpegAudioStream () : FFmpegStream ("", 0) - , AudioStream (0, 0) + , AudioStream (0, 0, 0) {} }; +