| 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..deba95e48b7f8912bf18dcfaf2f2a9b188d093cb 100644
|
| --- a/webkit/renderer/media/android/webmediaplayer_android.cc
|
| +++ b/webkit/renderer/media/android/webmediaplayer_android.cc
|
| @@ -150,11 +150,9 @@ 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;
|
|
|
| if (media_source)
|
| source_type = MediaPlayerAndroid::SOURCE_TYPE_MSE;
|
| @@ -187,22 +185,39 @@ void WebMediaPlayerAndroid::load(const WebURL& url,
|
| audio_renderer_->Start();
|
| }
|
| #endif
|
| + InitializeMediaPlayer(source_type);
|
| + } else {
|
| + info_loader_.reset(
|
| + new MediaInfoLoaderAndroid(
|
| + url_,
|
| + cors_mode,
|
| + base::Bind(&WebMediaPlayerAndroid::DidLoadMediaInfo,
|
| + base::Unretained(this))));
|
| + info_loader_->Start(frame_);
|
| + }
|
| + UpdateNetworkState(WebMediaPlayer::NetworkStateLoading);
|
| + UpdateReadyState(WebMediaPlayer::ReadyStateHaveNothing);
|
| +}
|
| +
|
| +void WebMediaPlayerAndroid::DidLoadMediaInfo(
|
| + MediaInfoLoaderAndroid::Status status) {
|
| + DCHECK(!media_source_delegate_);
|
| + if (status == MediaInfoLoaderAndroid::kFailed) {
|
| + info_loader_.reset();
|
| + return;
|
| }
|
|
|
| - InitializeMediaPlayer(url, source_type);
|
| + InitializeMediaPlayer(MediaPlayerAndroid::SOURCE_TYPE_URL);
|
| }
|
|
|
| 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 +389,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;
|
| }
|
|
|
| bool WebMediaPlayerAndroid::didPassCORSAccessCheck() const {
|
| + if (info_loader_)
|
| + return info_loader_->DidPassCORSAccessCheck();
|
| return false;
|
| }
|
|
|
|
|