| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 "content/browser/wake_lock/wake_lock_service_context.h" | 5 #include "content/browser/wake_lock/wake_lock_service_context.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "build/build_config.h" | 10 #include "build/build_config.h" |
| (...skipping 20 matching lines...) Expand all Loading... |
| 31 render_process_id, render_frame_id), | 31 render_process_id, render_frame_id), |
| 32 std::move(request)); | 32 std::move(request)); |
| 33 } | 33 } |
| 34 | 34 |
| 35 void WakeLockServiceContext::RenderFrameDeleted( | 35 void WakeLockServiceContext::RenderFrameDeleted( |
| 36 RenderFrameHost* render_frame_host) { | 36 RenderFrameHost* render_frame_host) { |
| 37 CancelWakeLock(render_frame_host->GetProcess()->GetID(), | 37 CancelWakeLock(render_frame_host->GetProcess()->GetID(), |
| 38 render_frame_host->GetRoutingID()); | 38 render_frame_host->GetRoutingID()); |
| 39 } | 39 } |
| 40 | 40 |
| 41 void WakeLockServiceContext::WebContentsDestroyed() { | |
| 42 #if defined(OS_ANDROID) | |
| 43 view_weak_factory_.reset(); | |
| 44 #endif | |
| 45 } | |
| 46 | |
| 47 void WakeLockServiceContext::RequestWakeLock(int render_process_id, | 41 void WakeLockServiceContext::RequestWakeLock(int render_process_id, |
| 48 int render_frame_id) { | 42 int render_frame_id) { |
| 49 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 43 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 50 if (!RenderFrameHost::FromID(render_process_id, render_frame_id)) | 44 if (!RenderFrameHost::FromID(render_process_id, render_frame_id)) |
| 51 return; | 45 return; |
| 52 | 46 |
| 53 frames_requesting_lock_.insert( | 47 frames_requesting_lock_.insert( |
| 54 std::pair<int, int>(render_process_id, render_frame_id)); | 48 std::pair<int, int>(render_process_id, render_frame_id)); |
| 55 UpdateWakeLock(); | 49 UpdateWakeLock(); |
| 56 } | 50 } |
| (...skipping 16 matching lines...) Expand all Loading... |
| 73 device::PowerSaveBlocker::kPowerSaveBlockPreventDisplaySleep, | 67 device::PowerSaveBlocker::kPowerSaveBlockPreventDisplaySleep, |
| 74 device::PowerSaveBlocker::kReasonOther, "Wake Lock API", | 68 device::PowerSaveBlocker::kReasonOther, "Wake Lock API", |
| 75 BrowserThread::GetTaskRunnerForThread(BrowserThread::UI), | 69 BrowserThread::GetTaskRunnerForThread(BrowserThread::UI), |
| 76 BrowserThread::GetTaskRunnerForThread(BrowserThread::FILE))); | 70 BrowserThread::GetTaskRunnerForThread(BrowserThread::FILE))); |
| 77 | 71 |
| 78 #if defined(OS_ANDROID) | 72 #if defined(OS_ANDROID) |
| 79 // On Android, additionaly associate the blocker with this WebContents. | 73 // On Android, additionaly associate the blocker with this WebContents. |
| 80 DCHECK(web_contents()); | 74 DCHECK(web_contents()); |
| 81 | 75 |
| 82 if (web_contents()->GetNativeView()) { | 76 if (web_contents()->GetNativeView()) { |
| 83 view_weak_factory_.reset(new base::WeakPtrFactory<ui::ViewAndroid>( | 77 wake_lock_.get()->InitDisplaySleepBlocker(web_contents()->GetNativeView()); |
| 84 web_contents()->GetNativeView())); | |
| 85 wake_lock_.get()->InitDisplaySleepBlocker(view_weak_factory_->GetWeakPtr()); | |
| 86 } | 78 } |
| 87 #endif | 79 #endif |
| 88 } | 80 } |
| 89 | 81 |
| 90 void WakeLockServiceContext::RemoveWakeLock() { | 82 void WakeLockServiceContext::RemoveWakeLock() { |
| 91 DCHECK(wake_lock_); | 83 DCHECK(wake_lock_); |
| 92 wake_lock_.reset(); | 84 wake_lock_.reset(); |
| 93 } | 85 } |
| 94 | 86 |
| 95 void WakeLockServiceContext::UpdateWakeLock() { | 87 void WakeLockServiceContext::UpdateWakeLock() { |
| 96 if (!frames_requesting_lock_.empty()) { | 88 if (!frames_requesting_lock_.empty()) { |
| 97 if (!wake_lock_) | 89 if (!wake_lock_) |
| 98 CreateWakeLock(); | 90 CreateWakeLock(); |
| 99 } else { | 91 } else { |
| 100 if (wake_lock_) | 92 if (wake_lock_) |
| 101 RemoveWakeLock(); | 93 RemoveWakeLock(); |
| 102 } | 94 } |
| 103 } | 95 } |
| 104 | 96 |
| 105 } // namespace content | 97 } // namespace content |
| OLD | NEW |