Chromium Code Reviews| Index: webkit/renderer/media/android/webmediaplayer_android.cc |
| diff --git a/webkit/renderer/media/android/webmediaplayer_android.cc b/webkit/renderer/media/android/webmediaplayer_android.cc |
| index 4539f454faf6293b53b17a47e26fc18d92f765d6..8ad1199b7b0b8c9e654cd06e19ff9ee0502fdc75 100644 |
| --- a/webkit/renderer/media/android/webmediaplayer_android.cc |
| +++ b/webkit/renderer/media/android/webmediaplayer_android.cc |
| @@ -73,6 +73,8 @@ WebMediaPlayerAndroid::WebMediaPlayerAndroid( |
| needs_establish_peer_(true), |
| stream_texture_proxy_initialized_(false), |
| has_size_info_(false), |
| + has_media_metadata_(false), |
| + has_media_info_(false), |
| stream_texture_factory_(factory), |
| needs_external_surface_(false), |
| video_frame_provider_client_(NULL), |
| @@ -150,11 +152,11 @@ void WebMediaPlayerAndroid::load(const WebURL& url, CORSMode cors_mode) { |
| void WebMediaPlayerAndroid::load(const WebURL& url, |
| WebMediaSource* media_source, |
| CORSMode cors_mode) { |
| - if (cors_mode != CORSModeUnspecified) |
| - NOTIMPLEMENTED() << "No CORS support"; |
| - |
| MediaPlayerAndroid::SourceType source_type = |
| MediaPlayerAndroid::SOURCE_TYPE_URL; |
| + url_ = url; |
| + has_media_metadata_ = false; |
| + has_media_info_ = false; |
| if (media_source) |
| source_type = MediaPlayerAndroid::SOURCE_TYPE_MSE; |
| @@ -166,6 +168,7 @@ void WebMediaPlayerAndroid::load(const WebURL& url, |
| #endif |
| if (source_type != MediaPlayerAndroid::SOURCE_TYPE_URL) { |
| + has_media_info_ = true; |
| media_source_delegate_.reset( |
| new MediaSourceDelegate(proxy_, player_id_, media_log_)); |
| // |media_source_delegate_| is owned, so Unretained() is safe here. |
| @@ -187,22 +190,45 @@ void WebMediaPlayerAndroid::load(const WebURL& url, |
| audio_renderer_->Start(); |
| } |
| #endif |
| + } else { |
| + info_loader_.reset( |
| + new MediaInfoLoader( |
| + url_, |
| + cors_mode, |
| + base::Bind(&WebMediaPlayerAndroid::DidLoadMediaInfo, |
| + base::Unretained(this)))); |
| + info_loader_->Start(frame_); |
| } |
| + UpdateNetworkState(WebMediaPlayer::NetworkStateLoading); |
| + UpdateReadyState(WebMediaPlayer::ReadyStateHaveNothing); |
| + InitializeMediaPlayer(source_type); |
| +} |
| - InitializeMediaPlayer(url, source_type); |
| +void WebMediaPlayerAndroid::DidLoadMediaInfo( |
| + MediaInfoLoader::Status status) { |
| + DCHECK(!media_source_delegate_); |
| + if (status == MediaInfoLoader::kFailed) { |
| + info_loader_.reset(); |
| + UpdateNetworkState(WebMediaPlayer::NetworkStateNetworkError); |
| + return; |
| + } |
| + |
| + has_media_info_ = true; |
| + if (has_media_metadata_ && |
| + ready_state_ != WebMediaPlayer::ReadyStateHaveEnoughData) { |
| + UpdateReadyState(WebMediaPlayer::ReadyStateHaveMetadata); |
| + UpdateReadyState(WebMediaPlayer::ReadyStateHaveEnoughData); |
| + } |
| } |
| void WebMediaPlayerAndroid::InitializeMediaPlayer( |
| - const WebURL& url, |
| MediaPlayerAndroid::SourceType source_type) { |
| - url_ = url; |
| GURL first_party_url = frame_->document().firstPartyForCookies(); |
| - proxy_->Initialize(player_id_, url, source_type, first_party_url); |
| - if (manager_->IsInFullscreen(frame_)) |
| - proxy_->EnterFullscreen(player_id_); |
| - |
| - UpdateNetworkState(WebMediaPlayer::NetworkStateLoading); |
| - UpdateReadyState(WebMediaPlayer::ReadyStateHaveNothing); |
| + if (proxy_) { |
| + proxy_->Initialize(player_id_, url_, source_type, first_party_url); |
| + if (manager_->IsInFullscreen(frame_)) |
| + proxy_->EnterFullscreen(player_id_); |
| + } |
| } |
| void WebMediaPlayerAndroid::play() { |
| @@ -374,14 +400,14 @@ bool WebMediaPlayerAndroid::copyVideoTextureToPlatformTexture( |
| } |
| bool WebMediaPlayerAndroid::hasSingleSecurityOrigin() const { |
| - // TODO(qinmin): fix this for urls that are not file. |
| - // https://code.google.com/p/chromium/issues/detail?id=234710 |
| - if (url_.SchemeIsFile()) |
| - return true; |
| - return false; |
| + if (info_loader_) |
| + return info_loader_->HasSingleOrigin(); |
| + return true; |
|
scherkus (not reviewing)
2013/06/12 01:37:58
do we need to worry about the case where info_load
Sami
2013/06/12 13:59:31
Yes, I'll add a check for that.
|
| } |
| bool WebMediaPlayerAndroid::didPassCORSAccessCheck() const { |
| + if (info_loader_) |
| + return info_loader_->DidPassCORSAccessCheck(); |
| return false; |
| } |
| @@ -422,7 +448,9 @@ void WebMediaPlayerAndroid::OnMediaMetadataChanged( |
| if (url_.SchemeIs("file")) |
| UpdateNetworkState(WebMediaPlayer::NetworkStateLoaded); |
| - if (ready_state_ != WebMediaPlayer::ReadyStateHaveEnoughData) { |
| + has_media_metadata_ = true; |
| + if (has_media_info_ && |
| + ready_state_ != WebMediaPlayer::ReadyStateHaveEnoughData) { |
| UpdateReadyState(WebMediaPlayer::ReadyStateHaveMetadata); |
| UpdateReadyState(WebMediaPlayer::ReadyStateHaveEnoughData); |
| } |