Chromium Code Reviews| Index: chrome/renderer/prerender/prerender_webmediaplayer.cc |
| diff --git a/chrome/renderer/prerender/prerender_webmediaplayer.cc b/chrome/renderer/prerender/prerender_webmediaplayer.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..0ab9bbb00bdee7f12cbf38a17786a6096ea0f8fc |
| --- /dev/null |
| +++ b/chrome/renderer/prerender/prerender_webmediaplayer.cc |
| @@ -0,0 +1,89 @@ |
| +// Copyright (c) 2011 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "chrome/renderer/prerender/prerender_webmediaplayer.h" |
| + |
| +#include "chrome/common/render_messages.h" |
| +#include "content/renderer/render_view.h" |
| +#include "media/base/filter_collection.h" |
| +#include "media/base/media_log.h" |
| +#include "media/base/pipeline_impl.h" |
| +#include "third_party/WebKit/Source/WebKit/chromium/public/WebURL.h" |
| + |
| +namespace prerender { |
| + |
| +PrerenderWebMediaPlayer::PrerenderWebMediaPlayer( |
| + RenderView* render_view, |
| + WebKit::WebMediaPlayerClient* client, |
| + media::FilterCollection* collection, |
| + media::MessageLoopFactory* message_loop_factory, |
| + webkit_glue::MediaStreamClient* media_stream_client, |
| + media::MediaLog* media_log) |
| + : RenderViewObserver(render_view), |
|
scherkus (not reviewing)
2011/10/03 18:19:45
indent by 2 more spaces
Shishir
2011/10/04 23:02:39
Done.
|
| + WebMediaPlayerImpl(client, |
| + collection, |
| + message_loop_factory, |
| + media_stream_client, |
| + media_log), |
| + is_prerendering_(true), |
| + should_play_(false) { |
| +} |
| + |
| +PrerenderWebMediaPlayer::~PrerenderWebMediaPlayer() { |
|
scherkus (not reviewing)
2011/10/03 18:19:45
nit: collapse empty methods to {}
Shishir
2011/10/04 23:02:39
Done.
|
| +} |
| + |
| +void PrerenderWebMediaPlayer::load(const WebKit::WebURL& url) { |
| + if (is_prerendering_) { |
| + url_to_load_.reset(new WebKit::WebURL(url)); |
| + return; |
| + } |
| + WebMediaPlayerImpl::load(url); |
| +} |
| + |
| +void PrerenderWebMediaPlayer::cancelLoad() { |
| + if (is_prerendering_) { |
| + url_to_load_.reset(NULL); |
| + return; |
| + } |
| + WebMediaPlayerImpl::cancelLoad(); |
| +} |
| + |
| +void PrerenderWebMediaPlayer::play() { |
|
scherkus (not reviewing)
2011/10/03 18:19:45
is it possible to receive play if we never finish
Shishir
2011/10/04 23:02:39
Looks like you are correct. I dug into the webkit
|
| + if (is_prerendering_) { |
| + should_play_ = true; |
| + return; |
| + } |
| + WebMediaPlayerImpl::play(); |
| +} |
| + |
| +void PrerenderWebMediaPlayer::pause() { |
|
scherkus (not reviewing)
2011/10/03 18:19:45
ditto
Shishir
2011/10/04 23:02:39
removed.
|
| + if (is_prerendering_) { |
| + should_play_ = false; |
| + return; |
| + } |
| + WebMediaPlayerImpl::pause(); |
| +} |
| + |
| +bool PrerenderWebMediaPlayer::OnMessageReceived(const IPC::Message& message) { |
| + IPC_BEGIN_MESSAGE_MAP(PrerenderWebMediaPlayer, message) |
| + IPC_MESSAGE_HANDLER(ChromeViewMsg_SetIsPrerendering, OnSetIsPrerendering) |
| + IPC_END_MESSAGE_MAP() |
| + |
| + return false; |
| +} |
| + |
| +void PrerenderWebMediaPlayer::OnSetIsPrerendering(bool is_prerendering) { |
| + // Prerendering can only be enabled prior to a RenderView's first |
| + // navigation, so no PrerenderWebMediaPlayer should see the notification |
| + // that enables prerendering. |
|
scherkus (not reviewing)
2011/10/03 18:19:45
I haven't looked at prerendering before, but why h
Shishir
2011/10/04 23:02:39
It can be set to true. The argument here is that i
|
| + DCHECK(!is_prerendering); |
| + if (is_prerendering_ && !is_prerendering) { |
| + is_prerendering_ = false; |
| + load(*url_to_load_); |
|
scherkus (not reviewing)
2011/10/03 18:19:45
is it possible to have this IPC called before we g
Shishir
2011/10/04 23:02:39
Thanks for the catch. Fixed.
|
| + if (should_play_) |
| + play(); |
| + } |
| +} |
| + |
| +} // namespace prerender |