OLD | NEW |
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 #include "media/webm/webm_stream_parser.h" | 5 #include "media/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/logging.h" | 10 #include "base/logging.h" |
(...skipping 336 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
347 if (is_audio_encrypted) { | 347 if (is_audio_encrypted) { |
348 const AudioDecoderConfig& original_audio_config = | 348 const AudioDecoderConfig& original_audio_config = |
349 config_helper.audio_config(); | 349 config_helper.audio_config(); |
350 | 350 |
351 audio_config.Initialize(original_audio_config.codec(), | 351 audio_config.Initialize(original_audio_config.codec(), |
352 original_audio_config.bits_per_channel(), | 352 original_audio_config.bits_per_channel(), |
353 original_audio_config.channel_layout(), | 353 original_audio_config.channel_layout(), |
354 original_audio_config.samples_per_second(), | 354 original_audio_config.samples_per_second(), |
355 original_audio_config.extra_data(), | 355 original_audio_config.extra_data(), |
356 original_audio_config.extra_data_size(), | 356 original_audio_config.extra_data_size(), |
357 is_audio_encrypted, false); | 357 original_audio_config.sample_format(), |
| 358 is_audio_encrypted, |
| 359 false); |
358 | 360 |
359 FireNeedKey(tracks_parser.audio_encryption_key_id()); | 361 FireNeedKey(tracks_parser.audio_encryption_key_id()); |
360 } else { | 362 } else { |
361 audio_config.CopyFrom(config_helper.audio_config()); | 363 audio_config.CopyFrom(config_helper.audio_config()); |
362 } | 364 } |
363 | 365 |
364 // TODO(xhwang): Support decryption of audio (see http://crbug.com/123421). | 366 // TODO(xhwang): Support decryption of audio (see http://crbug.com/123421). |
365 bool is_video_encrypted = !tracks_parser.video_encryption_key_id().empty(); | 367 bool is_video_encrypted = !tracks_parser.video_encryption_key_id().empty(); |
366 | 368 |
367 VideoDecoderConfig video_config; | 369 VideoDecoderConfig video_config; |
(...skipping 94 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
462 | 464 |
463 void WebMStreamParser::FireNeedKey(const std::string& key_id) { | 465 void WebMStreamParser::FireNeedKey(const std::string& key_id) { |
464 int key_id_size = key_id.size(); | 466 int key_id_size = key_id.size(); |
465 DCHECK_GT(key_id_size, 0); | 467 DCHECK_GT(key_id_size, 0); |
466 scoped_array<uint8> key_id_array(new uint8[key_id_size]); | 468 scoped_array<uint8> key_id_array(new uint8[key_id_size]); |
467 memcpy(key_id_array.get(), key_id.data(), key_id_size); | 469 memcpy(key_id_array.get(), key_id.data(), key_id_size); |
468 need_key_cb_.Run(kWebMInitDataType, key_id_array.Pass(), key_id_size); | 470 need_key_cb_.Run(kWebMInitDataType, key_id_array.Pass(), key_id_size); |
469 } | 471 } |
470 | 472 |
471 } // namespace media | 473 } // namespace media |
OLD | NEW |