| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 #include "media/formats/webm/webm_stream_parser.h" | 5 #include "media/formats/webm/webm_stream_parser.h" |
| 6 | 6 |
| 7 #include <string> | 7 #include <string> |
| 8 | 8 |
| 9 #include "base/callback.h" | 9 #include "base/callback.h" |
| 10 #include "base/callback_helpers.h" | 10 #include "base/callback_helpers.h" |
| 11 #include "base/logging.h" | 11 #include "base/logging.h" |
| 12 #include "media/formats/webm/webm_cluster_parser.h" | 12 #include "media/formats/webm/webm_cluster_parser.h" |
| 13 #include "media/formats/webm/webm_constants.h" | 13 #include "media/formats/webm/webm_constants.h" |
| 14 #include "media/formats/webm/webm_content_encodings.h" | 14 #include "media/formats/webm/webm_content_encodings.h" |
| 15 #include "media/formats/webm/webm_crypto_helpers.h" | 15 #include "media/formats/webm/webm_crypto_helpers.h" |
| 16 #include "media/formats/webm/webm_info_parser.h" | 16 #include "media/formats/webm/webm_info_parser.h" |
| 17 #include "media/formats/webm/webm_tracks_parser.h" | 17 #include "media/formats/webm/webm_tracks_parser.h" |
| 18 | 18 |
| 19 namespace media { | 19 namespace media { |
| 20 | 20 |
| 21 WebMStreamParser::WebMStreamParser() | 21 WebMStreamParser::WebMStreamParser() |
| 22 : state_(kWaitingForInit), | 22 : state_(kWaitingForInit), |
| 23 unknown_segment_size_(false) { | 23 unknown_segment_size_(false) { |
| 24 } | 24 } |
| 25 | 25 |
| 26 WebMStreamParser::~WebMStreamParser() { | 26 WebMStreamParser::~WebMStreamParser() { |
| 27 } | 27 } |
| 28 | 28 |
| 29 void WebMStreamParser::Init(const InitCB& init_cb, | 29 void WebMStreamParser::Init( |
| 30 const NewConfigCB& config_cb, | 30 const InitCB& init_cb, |
| 31 const NewBuffersCB& new_buffers_cb, | 31 const NewConfigCB& config_cb, |
| 32 bool ignore_text_tracks, | 32 const NewBuffersCB& new_buffers_cb, |
| 33 const NeedKeyCB& need_key_cb, | 33 bool ignore_text_tracks, |
| 34 const NewMediaSegmentCB& new_segment_cb, | 34 const EncryptedMediaInitDataCB& encrypted_media_init_data_cb, |
| 35 const base::Closure& end_of_segment_cb, | 35 const NewMediaSegmentCB& new_segment_cb, |
| 36 const LogCB& log_cb) { | 36 const base::Closure& end_of_segment_cb, |
| 37 const LogCB& log_cb) { |
| 37 DCHECK_EQ(state_, kWaitingForInit); | 38 DCHECK_EQ(state_, kWaitingForInit); |
| 38 DCHECK(init_cb_.is_null()); | 39 DCHECK(init_cb_.is_null()); |
| 39 DCHECK(!init_cb.is_null()); | 40 DCHECK(!init_cb.is_null()); |
| 40 DCHECK(!config_cb.is_null()); | 41 DCHECK(!config_cb.is_null()); |
| 41 DCHECK(!new_buffers_cb.is_null()); | 42 DCHECK(!new_buffers_cb.is_null()); |
| 42 DCHECK(!need_key_cb.is_null()); | 43 DCHECK(!encrypted_media_init_data_cb.is_null()); |
| 43 DCHECK(!new_segment_cb.is_null()); | 44 DCHECK(!new_segment_cb.is_null()); |
| 44 DCHECK(!end_of_segment_cb.is_null()); | 45 DCHECK(!end_of_segment_cb.is_null()); |
| 45 | 46 |
| 46 ChangeState(kParsingHeaders); | 47 ChangeState(kParsingHeaders); |
| 47 init_cb_ = init_cb; | 48 init_cb_ = init_cb; |
| 48 config_cb_ = config_cb; | 49 config_cb_ = config_cb; |
| 49 new_buffers_cb_ = new_buffers_cb; | 50 new_buffers_cb_ = new_buffers_cb; |
| 50 ignore_text_tracks_ = ignore_text_tracks; | 51 ignore_text_tracks_ = ignore_text_tracks; |
| 51 need_key_cb_ = need_key_cb; | 52 encrypted_media_init_data_cb_ = encrypted_media_init_data_cb; |
| 52 new_segment_cb_ = new_segment_cb; | 53 new_segment_cb_ = new_segment_cb; |
| 53 end_of_segment_cb_ = end_of_segment_cb; | 54 end_of_segment_cb_ = end_of_segment_cb; |
| 54 log_cb_ = log_cb; | 55 log_cb_ = log_cb; |
| 55 } | 56 } |
| 56 | 57 |
| 57 void WebMStreamParser::Flush() { | 58 void WebMStreamParser::Flush() { |
| 58 DCHECK_NE(state_, kWaitingForInit); | 59 DCHECK_NE(state_, kWaitingForInit); |
| 59 | 60 |
| 60 byte_queue_.Reset(); | 61 byte_queue_.Reset(); |
| 61 if (cluster_parser_) | 62 if (cluster_parser_) |
| (...skipping 147 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 209 !info_parser.date_utc().is_null()) { | 210 !info_parser.date_utc().is_null()) { |
| 210 params.liveness = DemuxerStream::LIVENESS_LIVE; | 211 params.liveness = DemuxerStream::LIVENESS_LIVE; |
| 211 } else if (info_parser.duration() >= 0) { | 212 } else if (info_parser.duration() >= 0) { |
| 212 params.liveness = DemuxerStream::LIVENESS_RECORDED; | 213 params.liveness = DemuxerStream::LIVENESS_RECORDED; |
| 213 } else { | 214 } else { |
| 214 params.liveness = DemuxerStream::LIVENESS_UNKNOWN; | 215 params.liveness = DemuxerStream::LIVENESS_UNKNOWN; |
| 215 } | 216 } |
| 216 | 217 |
| 217 const AudioDecoderConfig& audio_config = tracks_parser.audio_decoder_config(); | 218 const AudioDecoderConfig& audio_config = tracks_parser.audio_decoder_config(); |
| 218 if (audio_config.is_encrypted()) | 219 if (audio_config.is_encrypted()) |
| 219 FireNeedKey(tracks_parser.audio_encryption_key_id()); | 220 OnEncryptedMediaInitData(tracks_parser.audio_encryption_key_id()); |
| 220 | 221 |
| 221 const VideoDecoderConfig& video_config = tracks_parser.video_decoder_config(); | 222 const VideoDecoderConfig& video_config = tracks_parser.video_decoder_config(); |
| 222 if (video_config.is_encrypted()) | 223 if (video_config.is_encrypted()) |
| 223 FireNeedKey(tracks_parser.video_encryption_key_id()); | 224 OnEncryptedMediaInitData(tracks_parser.video_encryption_key_id()); |
| 224 | 225 |
| 225 if (!config_cb_.Run(audio_config, | 226 if (!config_cb_.Run(audio_config, |
| 226 video_config, | 227 video_config, |
| 227 tracks_parser.text_tracks())) { | 228 tracks_parser.text_tracks())) { |
| 228 DVLOG(1) << "New config data isn't allowed."; | 229 DVLOG(1) << "New config data isn't allowed."; |
| 229 return -1; | 230 return -1; |
| 230 } | 231 } |
| 231 | 232 |
| 232 cluster_parser_.reset(new WebMClusterParser( | 233 cluster_parser_.reset(new WebMClusterParser( |
| 233 info_parser.timecode_scale(), | 234 info_parser.timecode_scale(), |
| (...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 268 } | 269 } |
| 269 | 270 |
| 270 if (cluster_ended) { | 271 if (cluster_ended) { |
| 271 ChangeState(kParsingHeaders); | 272 ChangeState(kParsingHeaders); |
| 272 end_of_segment_cb_.Run(); | 273 end_of_segment_cb_.Run(); |
| 273 } | 274 } |
| 274 | 275 |
| 275 return bytes_parsed; | 276 return bytes_parsed; |
| 276 } | 277 } |
| 277 | 278 |
| 278 void WebMStreamParser::FireNeedKey(const std::string& key_id) { | 279 void WebMStreamParser::OnEncryptedMediaInitData(const std::string& key_id) { |
| 279 std::vector<uint8> key_id_vector(key_id.begin(), key_id.end()); | 280 std::vector<uint8> key_id_vector(key_id.begin(), key_id.end()); |
| 280 need_key_cb_.Run(kWebMInitDataType, key_id_vector); | 281 encrypted_media_init_data_cb_.Run(kWebMInitDataType, key_id_vector); |
| 281 } | 282 } |
| 282 | 283 |
| 283 } // namespace media | 284 } // namespace media |
| OLD | NEW |