123456789101112131415161718192021222324252627282930313233343536373839404142434445464748 |
- From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
- From: Cheng Zhao <[email protected]>
- Date: Thu, 20 Sep 2018 17:45:47 -0700
- Subject: disable_hidden.patch
- Electron uses this to disable background throttling for hidden windows.
- diff --git a/content/browser/renderer_host/render_widget_host_impl.cc b/content/browser/renderer_host/render_widget_host_impl.cc
- index ff4e181fae1849772b699bf83e0f7e9556dbd71e..84b3bcbfb4f52098efad6f2b8ab8e8445d8fe13a 100644
- --- a/content/browser/renderer_host/render_widget_host_impl.cc
- +++ b/content/browser/renderer_host/render_widget_host_impl.cc
- @@ -824,6 +824,9 @@ void RenderWidgetHostImpl::WasHidden() {
- if (is_hidden_)
- return;
-
- + if (disable_hidden_)
- + return;
- +
- RejectMouseLockOrUnlockIfNecessary(
- blink::mojom::PointerLockResult::kWrongDocument);
-
- diff --git a/content/browser/renderer_host/render_widget_host_impl.h b/content/browser/renderer_host/render_widget_host_impl.h
- index 6ea55a22496a5186513963d06fa700cb82758177..bbcff3ff49234e2f6b9fcdaa1409678189d91b67 100644
- --- a/content/browser/renderer_host/render_widget_host_impl.h
- +++ b/content/browser/renderer_host/render_widget_host_impl.h
- @@ -894,6 +894,9 @@ class CONTENT_EXPORT RenderWidgetHostImpl
- cc::BrowserControlsState current,
- bool animate);
-
- + // Electron: Prevents the widget from getting hidden.
- + bool disable_hidden_ = false;
- +
- protected:
- // |routing_id| must not be MSG_ROUTING_NONE.
- // If this object outlives |delegate|, DetachDelegate() must be called when
- diff --git a/content/browser/renderer_host/render_widget_host_view_aura.cc b/content/browser/renderer_host/render_widget_host_view_aura.cc
- index 8b712a21e7ee1d2375c28af6a2f8d7279220138c..96c24edf6e4044a3ced0a87ecbd7a56f36f5d3d3 100644
- --- a/content/browser/renderer_host/render_widget_host_view_aura.cc
- +++ b/content/browser/renderer_host/render_widget_host_view_aura.cc
- @@ -604,7 +604,7 @@ void RenderWidgetHostViewAura::HideImpl() {
- DCHECK(visibility_ == Visibility::HIDDEN ||
- visibility_ == Visibility::OCCLUDED);
-
- - if (!host()->is_hidden()) {
- + if (!host()->is_hidden() && !host()->disable_hidden_) {
- host()->WasHidden();
- aura::WindowTreeHost* host = window_->GetHost();
- aura::Window* parent = window_->parent();
|