 Chromium Code Reviews
 Chromium Code Reviews Issue 2003803002:
  Remove dependency of power_save_blocker_android on various content bits  (Closed) 
  Base URL: https://chromium.googlesource.com/chromium/src.git@power-save-task-runners
    
  
    Issue 2003803002:
  Remove dependency of power_save_blocker_android on various content bits  (Closed) 
  Base URL: https://chromium.googlesource.com/chromium/src.git@power-save-task-runners| 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 "base/android/jni_android.h" | 5 #include "base/android/jni_android.h" | 
| 6 #include "base/bind.h" | |
| 7 #include "base/location.h" | |
| 6 #include "base/logging.h" | 8 #include "base/logging.h" | 
| 7 #include "base/macros.h" | 9 #include "base/macros.h" | 
| 8 #include "content/browser/android/content_view_core_impl.h" | |
| 9 #include "content/browser/power_save_blocker_impl.h" | 10 #include "content/browser/power_save_blocker_impl.h" | 
| 10 #include "content/browser/web_contents/web_contents_impl.h" | |
| 11 #include "content/public/browser/android/content_view_core.h" | |
| 12 #include "content/public/browser/web_contents_observer.h" | |
| 13 #include "jni/PowerSaveBlocker_jni.h" | 11 #include "jni/PowerSaveBlocker_jni.h" | 
| 14 #include "ui/android/view_android.h" | 12 #include "ui/android/view_android.h" | 
| 15 | 13 | 
| 16 namespace content { | 14 namespace content { | 
| 17 | 15 | 
| 18 using base::android::AttachCurrentThread; | 16 using base::android::AttachCurrentThread; | 
| 19 | 17 | 
| 20 class PowerSaveBlockerImpl::Delegate | 18 class PowerSaveBlockerImpl::Delegate | 
| 21 : public base::RefCountedThreadSafe<PowerSaveBlockerImpl::Delegate>, | 19 : public base::RefCountedThreadSafe<PowerSaveBlockerImpl::Delegate> { | 
| 22 public WebContentsObserver { | |
| 23 public: | 20 public: | 
| 24 Delegate(WebContents* web_contents, | 21 Delegate(base::WeakPtr<ui::ViewAndroid> view_android, | 
| 25 scoped_refptr<base::SequencedTaskRunner> ui_task_runner); | 22 scoped_refptr<base::SequencedTaskRunner> ui_task_runner); | 
| 26 | 23 | 
| 27 // Does the actual work to apply or remove the desired power save block. | 24 // Does the actual work to apply or remove the desired power save block. | 
| 28 void ApplyBlock(); | 25 void ApplyBlock(); | 
| 29 void RemoveBlock(); | 26 void RemoveBlock(); | 
| 30 | 27 | 
| 31 private: | 28 private: | 
| 32 friend class base::RefCountedThreadSafe<Delegate>; | 29 friend class base::RefCountedThreadSafe<Delegate>; | 
| 33 ~Delegate() override; | 30 ~Delegate(); | 
| 34 | 31 | 
| 35 base::android::ScopedJavaLocalRef<jobject> GetContentViewCore(); | 32 base::WeakPtr<ui::ViewAndroid> view_android_; | 
| 36 | 33 | 
| 37 base::android::ScopedJavaGlobalRef<jobject> java_power_save_blocker_; | 34 base::android::ScopedJavaGlobalRef<jobject> java_power_save_blocker_; | 
| 38 | 35 | 
| 39 scoped_refptr<base::SequencedTaskRunner> ui_task_runner_; | 36 scoped_refptr<base::SequencedTaskRunner> ui_task_runner_; | 
| 40 | 37 | 
| 41 DISALLOW_COPY_AND_ASSIGN(Delegate); | 38 DISALLOW_COPY_AND_ASSIGN(Delegate); | 
| 42 }; | 39 }; | 
| 43 | 40 | 
| 44 PowerSaveBlockerImpl::Delegate::Delegate( | 41 PowerSaveBlockerImpl::Delegate::Delegate( | 
| 45 WebContents* web_contents, | 42 base::WeakPtr<ui::ViewAndroid> view_android, | 
| 46 scoped_refptr<base::SequencedTaskRunner> ui_task_runner) | 43 scoped_refptr<base::SequencedTaskRunner> ui_task_runner) | 
| 47 : WebContentsObserver(web_contents), ui_task_runner_(ui_task_runner) { | 44 : view_android_(view_android), ui_task_runner_(ui_task_runner) { | 
| 48 JNIEnv* env = AttachCurrentThread(); | 45 JNIEnv* env = AttachCurrentThread(); | 
| 49 java_power_save_blocker_.Reset(Java_PowerSaveBlocker_create(env)); | 46 java_power_save_blocker_.Reset(Java_PowerSaveBlocker_create(env)); | 
| 50 } | 47 } | 
| 51 | 48 | 
| 52 PowerSaveBlockerImpl::Delegate::~Delegate() { | 49 PowerSaveBlockerImpl::Delegate::~Delegate() { | 
| 53 } | 50 } | 
| 54 | 51 | 
| 55 void PowerSaveBlockerImpl::Delegate::ApplyBlock() { | 52 void PowerSaveBlockerImpl::Delegate::ApplyBlock() { | 
| 56 DCHECK(ui_task_runner_->RunsTasksOnCurrentThread()); | 53 DCHECK(ui_task_runner_->RunsTasksOnCurrentThread()); | 
| 57 base::android::ScopedJavaLocalRef<jobject> java_content_view_core = | |
| 58 GetContentViewCore(); | |
| 59 if (java_content_view_core.is_null()) | |
| 60 return; | |
| 61 | 54 | 
| 62 ScopedJavaLocalRef<jobject> obj(java_power_save_blocker_); | 55 ScopedJavaLocalRef<jobject> obj(java_power_save_blocker_); | 
| 63 JNIEnv* env = AttachCurrentThread(); | 56 JNIEnv* env = AttachCurrentThread(); | 
| 64 Java_PowerSaveBlocker_applyBlock(env, obj.obj(), | 57 if (view_android_) { | 
| 65 java_content_view_core.obj()); | 58 Java_PowerSaveBlocker_applyBlock( | 
| 59 env, obj.obj(), view_android_->GetViewAndroidDelegate().obj()); | |
| 60 } | |
| 66 } | 61 } | 
| 67 | 62 | 
| 68 void PowerSaveBlockerImpl::Delegate::RemoveBlock() { | 63 void PowerSaveBlockerImpl::Delegate::RemoveBlock() { | 
| 69 DCHECK(ui_task_runner_->RunsTasksOnCurrentThread()); | 64 DCHECK(ui_task_runner_->RunsTasksOnCurrentThread()); | 
| 70 base::android::ScopedJavaLocalRef<jobject> java_content_view_core = | |
| 71 GetContentViewCore(); | |
| 72 if (java_content_view_core.is_null()) | |
| 73 return; | |
| 74 | |
| 75 ScopedJavaLocalRef<jobject> obj(java_power_save_blocker_); | 65 ScopedJavaLocalRef<jobject> obj(java_power_save_blocker_); | 
| 76 JNIEnv* env = AttachCurrentThread(); | 66 JNIEnv* env = AttachCurrentThread(); | 
| 77 Java_PowerSaveBlocker_removeBlock(env, obj.obj(), | 67 if (view_android_) { | 
| 78 java_content_view_core.obj()); | 68 Java_PowerSaveBlocker_removeBlock( | 
| 79 } | 69 env, obj.obj(), view_android_->GetViewAndroidDelegate().obj()); | 
| 80 | 70 } | 
| 81 base::android::ScopedJavaLocalRef<jobject> | |
| 82 PowerSaveBlockerImpl::Delegate::GetContentViewCore() { | |
| 83 if (!web_contents()) | |
| 84 return base::android::ScopedJavaLocalRef<jobject>(); | |
| 85 | |
| 86 ContentViewCoreImpl* content_view_core_impl = | |
| 87 ContentViewCoreImpl::FromWebContents(web_contents()); | |
| 88 if (!content_view_core_impl) | |
| 89 return base::android::ScopedJavaLocalRef<jobject>(); | |
| 90 | |
| 91 return content_view_core_impl->GetJavaObject(); | |
| 92 } | 71 } | 
| 93 | 72 | 
| 94 PowerSaveBlockerImpl::PowerSaveBlockerImpl( | 73 PowerSaveBlockerImpl::PowerSaveBlockerImpl( | 
| 95 PowerSaveBlockerType type, | 74 PowerSaveBlockerType type, | 
| 96 Reason reason, | 75 Reason reason, | 
| 97 const std::string& description, | 76 const std::string& description, | 
| 98 scoped_refptr<base::SequencedTaskRunner> ui_task_runner, | 77 scoped_refptr<base::SequencedTaskRunner> ui_task_runner, | 
| 99 scoped_refptr<base::SingleThreadTaskRunner> blocking_task_runner) | 78 scoped_refptr<base::SingleThreadTaskRunner> blocking_task_runner) | 
| 100 : ui_task_runner_(ui_task_runner), | 79 : ui_task_runner_(ui_task_runner), | 
| 101 blocking_task_runner_(blocking_task_runner) { | 80 blocking_task_runner_(blocking_task_runner) { | 
| 102 // Don't support kPowerSaveBlockPreventAppSuspension | 81 // Don't support kPowerSaveBlockPreventAppSuspension | 
| 103 } | 82 } | 
| 104 | 83 | 
| 105 PowerSaveBlockerImpl::~PowerSaveBlockerImpl() { | 84 PowerSaveBlockerImpl::~PowerSaveBlockerImpl() { | 
| 106 if (delegate_.get()) { | 85 if (delegate_.get()) { | 
| 107 ui_task_runner_->PostTask(FROM_HERE, | 86 ui_task_runner_->PostTask(FROM_HERE, | 
| 108 base::Bind(&Delegate::RemoveBlock, delegate_)); | 87 base::Bind(&Delegate::RemoveBlock, delegate_)); | 
| 109 } | 88 } | 
| 110 } | 89 } | 
| 111 | 90 | 
| 112 void PowerSaveBlockerImpl::InitDisplaySleepBlocker(WebContents* web_contents) { | 91 void PowerSaveBlockerImpl::InitDisplaySleepBlocker( | 
| 92 base::WeakPtr<ui::ViewAndroid> view_android) { | |
| 
boliu
2016/06/13 14:56:43
should parameter be const&?
 
ncarter (slow)
2016/06/13 16:56:20
I imagine const& is better, since copying a WeakPt
 
scottmg
2016/06/13 18:52:56
Done.
 | |
| 113 DCHECK(ui_task_runner_->RunsTasksOnCurrentThread()); | 93 DCHECK(ui_task_runner_->RunsTasksOnCurrentThread()); | 
| 114 if (!web_contents) | 94 if (!view_android) | 
| 115 return; | 95 return; | 
| 116 | 96 | 
| 117 delegate_ = new Delegate(web_contents, ui_task_runner_); | 97 delegate_ = new Delegate(view_android, ui_task_runner_); | 
| 118 delegate_->ApplyBlock(); | 98 delegate_->ApplyBlock(); | 
| 119 } | 99 } | 
| 120 | 100 | 
| 121 bool RegisterPowerSaveBlocker(JNIEnv* env) { | 101 bool RegisterPowerSaveBlocker(JNIEnv* env) { | 
| 122 return RegisterNativesImpl(env); | 102 return RegisterNativesImpl(env); | 
| 123 } | 103 } | 
| 124 | 104 | 
| 125 } // namespace content | 105 } // namespace content | 
| OLD | NEW |