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 "chrome/renderer/chrome_content_renderer_client.h" | 5 #include "chrome/renderer/chrome_content_renderer_client.h" |
6 | 6 |
7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
8 #include "base/debug/crash_logging.h" | 8 #include "base/debug/crash_logging.h" |
9 #include "base/logging.h" | 9 #include "base/logging.h" |
10 #include "base/metrics/field_trial.h" | 10 #include "base/metrics/field_trial.h" |
(...skipping 323 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
334 return std::string(); | 334 return std::string(); |
335 } | 335 } |
336 #endif | 336 #endif |
337 | 337 |
338 #if defined(ENABLE_EXTENSIONS) | 338 #if defined(ENABLE_EXTENSIONS) |
339 bool IsStandaloneExtensionProcess() { | 339 bool IsStandaloneExtensionProcess() { |
340 return base::CommandLine::ForCurrentProcess()->HasSwitch( | 340 return base::CommandLine::ForCurrentProcess()->HasSwitch( |
341 extensions::switches::kExtensionProcess); | 341 extensions::switches::kExtensionProcess); |
342 } | 342 } |
343 #endif | 343 #endif |
344 | |
345 // Defers media player loading in background pages until they're visible. | |
346 class MediaLoadDeferrer : public content::RenderFrameObserver { | |
347 public: | |
348 MediaLoadDeferrer(content::RenderFrame* render_frame, | |
349 const base::Closure& continue_loading_cb) | |
350 : content::RenderFrameObserver(render_frame), | |
351 continue_loading_cb_(continue_loading_cb) {} | |
352 ~MediaLoadDeferrer() override {} | |
353 | |
354 private: | |
355 // content::RenderFrameObserver implementation: | |
356 void WasShown() override { | |
357 continue_loading_cb_.Run(); | |
358 delete this; | |
359 } | |
360 | |
361 // TODO(dalecurtis): Include an idle listener too. http://crbug.com/509135 | |
362 | |
363 const base::Closure continue_loading_cb_; | |
364 | |
365 DISALLOW_COPY_AND_ASSIGN(MediaLoadDeferrer); | |
366 }; | |
367 | |
344 } // namespace | 368 } // namespace |
345 | 369 |
346 ChromeContentRendererClient::ChromeContentRendererClient() { | 370 ChromeContentRendererClient::ChromeContentRendererClient() { |
347 g_current_client = this; | 371 g_current_client = this; |
348 | 372 |
349 #if defined(ENABLE_EXTENSIONS) | 373 #if defined(ENABLE_EXTENSIONS) |
350 extensions::ExtensionsClient::Set( | 374 extensions::ExtensionsClient::Set( |
351 extensions::ChromeExtensionsClient::GetInstance()); | 375 extensions::ChromeExtensionsClient::GetInstance()); |
352 extensions::ExtensionsRendererClient::Set( | 376 extensions::ExtensionsRendererClient::Set( |
353 ChromeExtensionsRendererClient::GetInstance()); | 377 ChromeExtensionsRendererClient::GetInstance()); |
(...skipping 328 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
682 } | 706 } |
683 | 707 |
684 void ChromeContentRendererClient::DeferMediaLoad( | 708 void ChromeContentRendererClient::DeferMediaLoad( |
685 content::RenderFrame* render_frame, | 709 content::RenderFrame* render_frame, |
686 const base::Closure& closure) { | 710 const base::Closure& closure) { |
687 #if defined(OS_ANDROID) | 711 #if defined(OS_ANDROID) |
688 // Chromium for Android doesn't support prerender yet. | 712 // Chromium for Android doesn't support prerender yet. |
689 closure.Run(); | 713 closure.Run(); |
690 return; | 714 return; |
691 #else | 715 #else |
692 if (!prerender::PrerenderHelper::IsPrerendering(render_frame)) { | 716 if (prerender::PrerenderHelper::IsPrerendering(render_frame)) { |
717 // Lifetime is tied to |render_frame| via content::RenderFrameObserver. | |
718 new prerender::PrerenderMediaLoadDeferrer(render_frame, closure); | |
719 return; | |
720 } | |
721 | |
722 // TODO(dalecurtis): Include an idle check too. http://crbug.com/509135 | |
723 if (!render_frame->IsHidden()) { | |
Lei Zhang
2015/08/13 19:11:47
nit, how about we structure this block consistentl
DaleCurtis
2015/08/13 21:44:48
Done.
| |
693 closure.Run(); | 724 closure.Run(); |
694 return; | 725 return; |
695 } | 726 } |
696 | 727 |
697 // Lifetime is tied to |render_frame| via content::RenderFrameObserver. | 728 // Lifetime is tied to |render_frame| via content::RenderFrameObserver. |
698 new prerender::PrerenderMediaLoadDeferrer(render_frame, closure); | 729 new MediaLoadDeferrer(render_frame, closure); |
699 #endif | 730 #endif |
700 } | 731 } |
701 | 732 |
702 #if defined(ENABLE_PLUGINS) | 733 #if defined(ENABLE_PLUGINS) |
703 WebPlugin* ChromeContentRendererClient::CreatePlugin( | 734 WebPlugin* ChromeContentRendererClient::CreatePlugin( |
704 content::RenderFrame* render_frame, | 735 content::RenderFrame* render_frame, |
705 blink::WebLocalFrame* frame, | 736 blink::WebLocalFrame* frame, |
706 const WebPluginParams& original_params, | 737 const WebPluginParams& original_params, |
707 const ChromeViewHostMsg_GetPluginInfo_Output& output) { | 738 const ChromeViewHostMsg_GetPluginInfo_Output& output) { |
708 const WebPluginInfo& info = output.plugin; | 739 const WebPluginInfo& info = output.plugin; |
(...skipping 915 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1624 WebString header_key(ASCIIToUTF16( | 1655 WebString header_key(ASCIIToUTF16( |
1625 data_reduction_proxy::chrome_proxy_header())); | 1656 data_reduction_proxy::chrome_proxy_header())); |
1626 if (!response.httpHeaderField(header_key).isNull() && | 1657 if (!response.httpHeaderField(header_key).isNull() && |
1627 response.httpHeaderField(header_key).utf8().find( | 1658 response.httpHeaderField(header_key).utf8().find( |
1628 data_reduction_proxy::chrome_proxy_lo_fi_directive()) != | 1659 data_reduction_proxy::chrome_proxy_lo_fi_directive()) != |
1629 std::string::npos) { | 1660 std::string::npos) { |
1630 (*properties)[data_reduction_proxy::chrome_proxy_header()] = | 1661 (*properties)[data_reduction_proxy::chrome_proxy_header()] = |
1631 data_reduction_proxy::chrome_proxy_lo_fi_directive(); | 1662 data_reduction_proxy::chrome_proxy_lo_fi_directive(); |
1632 } | 1663 } |
1633 } | 1664 } |
OLD | NEW |