Chromium Code Reviews| 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 "device/power_save_blocker/power_save_blocker.h" | 5 #include "device/power_save_blocker/power_save_blocker.h" |
| 6 | 6 |
| 7 #include "base/android/jni_android.h" | 7 #include "base/android/jni_android.h" |
| 8 #include "base/bind.h" | 8 #include "base/bind.h" |
| 9 #include "base/location.h" | 9 #include "base/location.h" |
| 10 #include "base/logging.h" | 10 #include "base/logging.h" |
| (...skipping 16 matching lines...) Expand all Loading... | |
| 27 void RemoveBlock(); | 27 void RemoveBlock(); |
| 28 | 28 |
| 29 private: | 29 private: |
| 30 friend class base::RefCountedThreadSafe<Delegate>; | 30 friend class base::RefCountedThreadSafe<Delegate>; |
| 31 ~Delegate(); | 31 ~Delegate(); |
| 32 | 32 |
| 33 base::WeakPtr<ui::ViewAndroid> view_android_; | 33 base::WeakPtr<ui::ViewAndroid> view_android_; |
| 34 | 34 |
| 35 base::android::ScopedJavaGlobalRef<jobject> java_power_save_blocker_; | 35 base::android::ScopedJavaGlobalRef<jobject> java_power_save_blocker_; |
| 36 | 36 |
| 37 std::unique_ptr<ui::ViewAndroid::ScopedAnchorView> anchor_view_; | |
| 38 | |
| 37 scoped_refptr<base::SequencedTaskRunner> ui_task_runner_; | 39 scoped_refptr<base::SequencedTaskRunner> ui_task_runner_; |
| 38 | 40 |
| 39 DISALLOW_COPY_AND_ASSIGN(Delegate); | 41 DISALLOW_COPY_AND_ASSIGN(Delegate); |
| 40 }; | 42 }; |
| 41 | 43 |
| 42 PowerSaveBlocker::Delegate::Delegate( | 44 PowerSaveBlocker::Delegate::Delegate( |
| 43 base::WeakPtr<ui::ViewAndroid> view_android, | 45 base::WeakPtr<ui::ViewAndroid> view_android, |
| 44 scoped_refptr<base::SequencedTaskRunner> ui_task_runner) | 46 scoped_refptr<base::SequencedTaskRunner> ui_task_runner) |
| 45 : view_android_(view_android), ui_task_runner_(ui_task_runner) { | 47 : view_android_(view_android), ui_task_runner_(ui_task_runner) { |
| 46 JNIEnv* env = AttachCurrentThread(); | 48 JNIEnv* env = AttachCurrentThread(); |
| 47 java_power_save_blocker_.Reset(Java_PowerSaveBlocker_create(env)); | 49 java_power_save_blocker_.Reset(Java_PowerSaveBlocker_create(env)); |
| 48 } | 50 } |
| 49 | 51 |
| 50 PowerSaveBlocker::Delegate::~Delegate() {} | 52 PowerSaveBlocker::Delegate::~Delegate() {} |
| 51 | 53 |
| 52 void PowerSaveBlocker::Delegate::ApplyBlock() { | 54 void PowerSaveBlocker::Delegate::ApplyBlock() { |
| 53 DCHECK(ui_task_runner_->RunsTasksOnCurrentThread()); | 55 DCHECK(ui_task_runner_->RunsTasksOnCurrentThread()); |
| 54 | 56 |
| 55 ScopedJavaLocalRef<jobject> obj(java_power_save_blocker_); | 57 ScopedJavaLocalRef<jobject> obj(java_power_save_blocker_); |
| 56 JNIEnv* env = AttachCurrentThread(); | |
| 57 if (view_android_) { | 58 if (view_android_) { |
| 58 Java_PowerSaveBlocker_applyBlock( | 59 anchor_view_.reset(view_android_->AcquireAnchorView()); |
| 59 env, obj.obj(), view_android_->GetViewAndroidDelegate().obj()); | 60 JNIEnv* env = AttachCurrentThread(); |
|
no sievers
2016/07/18 22:14:16
I think you should handle |anchor_view_.view_.is_n
Jinsuk Kim
2016/07/19 07:08:39
Done.
| |
| 61 Java_PowerSaveBlocker_applyBlock(env, obj.obj(), anchor_view_->obj()); | |
| 60 } | 62 } |
| 61 } | 63 } |
| 62 | 64 |
| 63 void PowerSaveBlocker::Delegate::RemoveBlock() { | 65 void PowerSaveBlocker::Delegate::RemoveBlock() { |
| 64 DCHECK(ui_task_runner_->RunsTasksOnCurrentThread()); | 66 DCHECK(ui_task_runner_->RunsTasksOnCurrentThread()); |
| 65 ScopedJavaLocalRef<jobject> obj(java_power_save_blocker_); | 67 ScopedJavaLocalRef<jobject> obj(java_power_save_blocker_); |
| 66 JNIEnv* env = AttachCurrentThread(); | 68 Java_PowerSaveBlocker_removeBlock(AttachCurrentThread(), obj.obj()); |
|
no sievers
2016/07/18 22:14:16
It's possible that you fixed a corner case bug her
Jinsuk Kim
2016/07/19 07:08:39
:)
| |
| 67 if (view_android_) { | 69 anchor_view_.reset(); |
| 68 Java_PowerSaveBlocker_removeBlock( | |
| 69 env, obj.obj(), view_android_->GetViewAndroidDelegate().obj()); | |
| 70 } | |
| 71 } | 70 } |
| 72 | 71 |
| 73 PowerSaveBlocker::PowerSaveBlocker( | 72 PowerSaveBlocker::PowerSaveBlocker( |
| 74 PowerSaveBlockerType type, | 73 PowerSaveBlockerType type, |
| 75 Reason reason, | 74 Reason reason, |
| 76 const std::string& description, | 75 const std::string& description, |
| 77 scoped_refptr<base::SequencedTaskRunner> ui_task_runner, | 76 scoped_refptr<base::SequencedTaskRunner> ui_task_runner, |
| 78 scoped_refptr<base::SingleThreadTaskRunner> blocking_task_runner) | 77 scoped_refptr<base::SingleThreadTaskRunner> blocking_task_runner) |
| 79 : ui_task_runner_(ui_task_runner), | 78 : ui_task_runner_(ui_task_runner), |
| 80 blocking_task_runner_(blocking_task_runner) { | 79 blocking_task_runner_(blocking_task_runner) { |
| (...skipping 15 matching lines...) Expand all Loading... | |
| 96 | 95 |
| 97 delegate_ = new Delegate(view_android, ui_task_runner_); | 96 delegate_ = new Delegate(view_android, ui_task_runner_); |
| 98 delegate_->ApplyBlock(); | 97 delegate_->ApplyBlock(); |
| 99 } | 98 } |
| 100 | 99 |
| 101 bool RegisterPowerSaveBlocker(JNIEnv* env) { | 100 bool RegisterPowerSaveBlocker(JNIEnv* env) { |
| 102 return RegisterNativesImpl(env); | 101 return RegisterNativesImpl(env); |
| 103 } | 102 } |
| 104 | 103 |
| 105 } // namespace device | 104 } // namespace device |
| OLD | NEW |