OLD | NEW |
---|---|
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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/task_scheduler/scheduler_worker_thread.h" | 5 #include "base/task_scheduler/scheduler_worker_thread.h" |
6 | 6 |
7 #include <stddef.h> | 7 #include <stddef.h> |
8 | 8 |
9 #include <utility> | 9 #include <utility> |
10 | 10 |
(...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
67 while (!task_tracker_->shutdown_completed() && !ShouldExitForTesting()) { | 67 while (!task_tracker_->shutdown_completed() && !ShouldExitForTesting()) { |
68 // Get the sequence containing the next task to execute. | 68 // Get the sequence containing the next task to execute. |
69 scoped_refptr<Sequence> sequence = delegate_->GetWork(this); | 69 scoped_refptr<Sequence> sequence = delegate_->GetWork(this); |
70 | 70 |
71 if (!sequence) { | 71 if (!sequence) { |
72 wake_up_event_.Wait(); | 72 wake_up_event_.Wait(); |
73 continue; | 73 continue; |
74 } | 74 } |
75 | 75 |
76 task_tracker_->RunTask(sequence->PeekTask()); | 76 task_tracker_->RunTask(sequence->PeekTask()); |
77 delegate_->RanTaskFromSequence(std::move(sequence)); | 77 |
78 const bool sequence_became_empty = sequence->PopTask(); | |
gab
2016/04/07 21:37:33
In other places you have comments explaining why t
fdoray
2016/04/08 15:59:12
Done.
| |
79 if (!sequence_became_empty) | |
80 delegate_->EnqueueSequence(std::move(sequence)); | |
78 | 81 |
79 // Calling WakeUp() guarantees that this SchedulerWorkerThread will run | 82 // Calling WakeUp() guarantees that this SchedulerWorkerThread will run |
80 // Tasks from Sequences returned by the GetWork() method of |delegate_| | 83 // Tasks from Sequences returned by the GetWork() method of |delegate_| |
81 // until it returns nullptr. Resetting |wake_up_event_| here doesn't break | 84 // until it returns nullptr. Resetting |wake_up_event_| here doesn't break |
82 // this invariant and avoids a useless loop iteration before going to sleep | 85 // this invariant and avoids a useless loop iteration before going to sleep |
83 // if WakeUp() is called while this SchedulerWorkerThread is awake. | 86 // if WakeUp() is called while this SchedulerWorkerThread is awake. |
84 wake_up_event_.Reset(); | 87 wake_up_event_.Reset(); |
85 } | 88 } |
86 | 89 |
87 delegate_->OnMainExit(); | 90 delegate_->OnMainExit(); |
88 } | 91 } |
89 | 92 |
90 bool SchedulerWorkerThread::ShouldExitForTesting() const { | 93 bool SchedulerWorkerThread::ShouldExitForTesting() const { |
91 AutoSchedulerLock auto_lock(should_exit_for_testing_lock_); | 94 AutoSchedulerLock auto_lock(should_exit_for_testing_lock_); |
92 return should_exit_for_testing_; | 95 return should_exit_for_testing_; |
93 } | 96 } |
94 | 97 |
95 } // namespace internal | 98 } // namespace internal |
96 } // namespace base | 99 } // namespace base |
OLD | NEW |