Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/public/test/nested_message_pump_android.h" | 5 #include "content/public/test/nested_message_pump_android.h" |
| 6 | 6 |
| 7 #include "base/android/jni_android.h" | 7 #include "base/android/jni_android.h" |
| 8 #include "base/android/scoped_java_ref.h" | 8 #include "base/android/scoped_java_ref.h" |
| 9 #include "base/lazy_instance.h" | 9 #include "base/lazy_instance.h" |
| 10 #include "base/logging.h" | 10 #include "base/logging.h" |
| (...skipping 29 matching lines...) Expand all Loading... | |
| 40 bool should_quit; | 40 bool should_quit; |
| 41 | 41 |
| 42 // Used to sleep until there is more work to do. | 42 // Used to sleep until there is more work to do. |
| 43 base::WaitableEvent waitable_event; | 43 base::WaitableEvent waitable_event; |
| 44 | 44 |
| 45 // The time at which we should call DoDelayedWork. | 45 // The time at which we should call DoDelayedWork. |
| 46 base::TimeTicks delayed_work_time; | 46 base::TimeTicks delayed_work_time; |
| 47 }; | 47 }; |
| 48 | 48 |
| 49 NestedMessagePumpAndroid::NestedMessagePumpAndroid() | 49 NestedMessagePumpAndroid::NestedMessagePumpAndroid() |
| 50 : state_(NULL) { | 50 : state_(NULL), redundant_quit_executed_(false) { |
| 51 } | 51 } |
| 52 | 52 |
| 53 NestedMessagePumpAndroid::~NestedMessagePumpAndroid() { | 53 NestedMessagePumpAndroid::~NestedMessagePumpAndroid() { |
| 54 } | 54 } |
| 55 | 55 |
| 56 void NestedMessagePumpAndroid::Run(Delegate* delegate) { | 56 void NestedMessagePumpAndroid::Run(Delegate* delegate) { |
| 57 RunState state(delegate, state_ ? state_->run_depth + 1 : 1); | 57 RunState state(delegate, state_ ? state_->run_depth + 1 : 1); |
| 58 RunState* previous_state = state_; | 58 RunState* previous_state = state_; |
| 59 state_ = &state; | 59 state_ = &state; |
| 60 | 60 |
| (...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 116 | 116 |
| 117 state_ = previous_state; | 117 state_ = previous_state; |
| 118 } | 118 } |
| 119 | 119 |
| 120 void NestedMessagePumpAndroid::Start( | 120 void NestedMessagePumpAndroid::Start( |
| 121 base::MessagePump::Delegate* delegate) { | 121 base::MessagePump::Delegate* delegate) { |
| 122 JNIEnv* env = base::android::AttachCurrentThread(); | 122 JNIEnv* env = base::android::AttachCurrentThread(); |
| 123 DCHECK(env); | 123 DCHECK(env); |
| 124 g_message_handler_obj.Get().Reset( | 124 g_message_handler_obj.Get().Reset( |
| 125 Java_NestedSystemMessageHandler_create(env)); | 125 Java_NestedSystemMessageHandler_create(env)); |
| 126 | |
| 127 base::MessagePumpForUI::Start(delegate); | |
| 128 } | 126 } |
| 129 | 127 |
| 130 void NestedMessagePumpAndroid::Quit() { | 128 void NestedMessagePumpAndroid::Quit() { |
| 131 if (state_) { | 129 if (state_) { |
|
bulach
2014/11/17 22:08:42
it looks like redundant_quit_executed_ could be an
Jaekyun Seok (inactive)
2014/11/18 03:10:06
I will ignore the quit request in browser_main_run
| |
| 132 state_->should_quit = true; | 130 state_->should_quit = true; |
| 133 state_->waitable_event.Signal(); | 131 state_->waitable_event.Signal(); |
| 134 return; | 132 return; |
| 133 } else { | |
| 134 redundant_quit_executed_ = true; | |
| 135 } | 135 } |
| 136 base::MessagePumpForUI::Quit(); | 136 } |
| 137 | |
| 138 bool NestedMessagePumpAndroid::IsRedundantQuitExpected() { | |
| 139 // Redundant quit is allowed only once. | |
| 140 return !redundant_quit_executed_; | |
| 137 } | 141 } |
| 138 | 142 |
| 139 void NestedMessagePumpAndroid::ScheduleWork() { | 143 void NestedMessagePumpAndroid::ScheduleWork() { |
| 140 if (state_) { | 144 if (state_) { |
| 141 state_->waitable_event.Signal(); | 145 state_->waitable_event.Signal(); |
| 142 return; | 146 return; |
| 143 } | 147 } |
| 144 | |
| 145 base::MessagePumpForUI::ScheduleWork(); | |
| 146 } | 148 } |
| 147 | 149 |
| 148 void NestedMessagePumpAndroid::ScheduleDelayedWork( | 150 void NestedMessagePumpAndroid::ScheduleDelayedWork( |
| 149 const base::TimeTicks& delayed_work_time) { | 151 const base::TimeTicks& delayed_work_time) { |
| 150 if (state_) { | 152 if (state_) { |
| 151 // We know that we can't be blocked on Wait right now since this method can | 153 // We know that we can't be blocked on Wait right now since this method can |
| 152 // only be called on the same thread as Run, so we only need to update our | 154 // only be called on the same thread as Run, so we only need to update our |
| 153 // record of how long to sleep when we do sleep. | 155 // record of how long to sleep when we do sleep. |
| 154 state_->delayed_work_time = delayed_work_time; | 156 state_->delayed_work_time = delayed_work_time; |
| 155 return; | 157 return; |
| 156 } | 158 } |
| 157 | |
| 158 base::MessagePumpForUI::ScheduleDelayedWork(delayed_work_time); | |
| 159 } | 159 } |
| 160 | 160 |
| 161 // static | 161 // static |
| 162 bool NestedMessagePumpAndroid::RegisterJni(JNIEnv* env) { | 162 bool NestedMessagePumpAndroid::RegisterJni(JNIEnv* env) { |
| 163 return RegisterNativesImpl(env); | 163 return RegisterNativesImpl(env); |
| 164 } | 164 } |
| 165 | 165 |
| 166 } // namespace content | 166 } // namespace content |
| OLD | NEW |