Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(262)

Side by Side Diff: media/filters/ffmpeg_demuxer.h

Issue 784493002: Encrypted Media: Rename NeedKey to EncryptedMediaInitData. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: comments addressed Created 6 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « media/filters/chunk_demuxer_unittest.cc ('k') | media/filters/ffmpeg_demuxer.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 // Implements the Demuxer interface using FFmpeg's libavformat. At this time 5 // Implements the Demuxer interface using FFmpeg's libavformat. At this time
6 // will support demuxing any audio/video format thrown at it. The streams 6 // will support demuxing any audio/video format thrown at it. The streams
7 // output mime types audio/x-ffmpeg and video/x-ffmpeg and include an integer 7 // output mime types audio/x-ffmpeg and video/x-ffmpeg and include an integer
8 // key FFmpegCodecID which contains the CodecID enumeration value. The CodecIDs 8 // key FFmpegCodecID which contains the CodecID enumeration value. The CodecIDs
9 // can be used to create and initialize the corresponding FFmpeg decoder. 9 // can be used to create and initialize the corresponding FFmpeg decoder.
10 // 10 //
(...skipping 146 matching lines...) Expand 10 before | Expand all | Expand 10 after
157 std::string encryption_key_id_; 157 std::string encryption_key_id_;
158 bool fixup_negative_ogg_timestamps_; 158 bool fixup_negative_ogg_timestamps_;
159 159
160 DISALLOW_COPY_AND_ASSIGN(FFmpegDemuxerStream); 160 DISALLOW_COPY_AND_ASSIGN(FFmpegDemuxerStream);
161 }; 161 };
162 162
163 class MEDIA_EXPORT FFmpegDemuxer : public Demuxer { 163 class MEDIA_EXPORT FFmpegDemuxer : public Demuxer {
164 public: 164 public:
165 FFmpegDemuxer(const scoped_refptr<base::SingleThreadTaskRunner>& task_runner, 165 FFmpegDemuxer(const scoped_refptr<base::SingleThreadTaskRunner>& task_runner,
166 DataSource* data_source, 166 DataSource* data_source,
167 const NeedKeyCB& need_key_cb, 167 const EncryptedMediaInitDataCB& encrypted_media_init_data_cb,
168 const scoped_refptr<MediaLog>& media_log); 168 const scoped_refptr<MediaLog>& media_log);
169 ~FFmpegDemuxer() override; 169 ~FFmpegDemuxer() override;
170 170
171 // Demuxer implementation. 171 // Demuxer implementation.
172 void Initialize(DemuxerHost* host, 172 void Initialize(DemuxerHost* host,
173 const PipelineStatusCB& status_cb, 173 const PipelineStatusCB& status_cb,
174 bool enable_text_tracks) override; 174 bool enable_text_tracks) override;
175 void Stop() override; 175 void Stop() override;
176 void Seek(base::TimeDelta time, const PipelineStatusCB& cb) override; 176 void Seek(base::TimeDelta time, const PipelineStatusCB& cb) override;
177 base::Time GetTimelineOffset() const override; 177 base::Time GetTimelineOffset() const override;
178 DemuxerStream* GetStream(DemuxerStream::Type type) override; 178 DemuxerStream* GetStream(DemuxerStream::Type type) override;
179 base::TimeDelta GetStartTime() const override; 179 base::TimeDelta GetStartTime() const override;
180 180
181 // Calls |need_key_cb_| with the initialization data encountered in the file. 181 // Calls |encrypted_media_init_data_cb_| with the initialization data
182 void FireNeedKey(const std::string& init_data_type, 182 // encountered in the file.
183 const std::string& encryption_key_id); 183 void OnEncryptedMediaInitData(const std::string& init_data_type,
184 const std::string& encryption_key_id);
184 185
185 // Allow FFmpegDemuxerStream to notify us when there is updated information 186 // Allow FFmpegDemuxerStream to notify us when there is updated information
186 // about capacity and what buffered data is available. 187 // about capacity and what buffered data is available.
187 void NotifyCapacityAvailable(); 188 void NotifyCapacityAvailable();
188 void NotifyBufferingChanged(); 189 void NotifyBufferingChanged();
189 190
190 // The lowest demuxed timestamp. If negative, DemuxerStreams must use this to 191 // The lowest demuxed timestamp. If negative, DemuxerStreams must use this to
191 // adjust packet timestamps such that external clients see a zero-based 192 // adjust packet timestamps such that external clients see a zero-based
192 // timeline. 193 // timeline.
193 base::TimeDelta start_time() const { return start_time_; } 194 base::TimeDelta start_time() const { return start_time_; }
(...skipping 98 matching lines...) Expand 10 before | Expand all | Expand 10 after
292 bool text_enabled_; 293 bool text_enabled_;
293 294
294 // Set if we know duration of the audio stream. Used when processing end of 295 // Set if we know duration of the audio stream. Used when processing end of
295 // stream -- at this moment we definitely know duration. 296 // stream -- at this moment we definitely know duration.
296 bool duration_known_; 297 bool duration_known_;
297 298
298 // FFmpegURLProtocol implementation and corresponding glue bits. 299 // FFmpegURLProtocol implementation and corresponding glue bits.
299 scoped_ptr<BlockingUrlProtocol> url_protocol_; 300 scoped_ptr<BlockingUrlProtocol> url_protocol_;
300 scoped_ptr<FFmpegGlue> glue_; 301 scoped_ptr<FFmpegGlue> glue_;
301 302
302 const NeedKeyCB need_key_cb_; 303 const EncryptedMediaInitDataCB encrypted_media_init_data_cb_;
303 304
304 // NOTE: Weak pointers must be invalidated before all other member variables. 305 // NOTE: Weak pointers must be invalidated before all other member variables.
305 base::WeakPtrFactory<FFmpegDemuxer> weak_factory_; 306 base::WeakPtrFactory<FFmpegDemuxer> weak_factory_;
306 307
307 DISALLOW_COPY_AND_ASSIGN(FFmpegDemuxer); 308 DISALLOW_COPY_AND_ASSIGN(FFmpegDemuxer);
308 }; 309 };
309 310
310 } // namespace media 311 } // namespace media
311 312
312 #endif // MEDIA_FILTERS_FFMPEG_DEMUXER_H_ 313 #endif // MEDIA_FILTERS_FFMPEG_DEMUXER_H_
OLDNEW
« no previous file with comments | « media/filters/chunk_demuxer_unittest.cc ('k') | media/filters/ffmpeg_demuxer.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698