forked from Pissandshittium/pissandshittium
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtask_pump.cc
49 lines (39 loc) · 1.28 KB
/
task_pump.cc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include <stdint.h>
#include "base/bind.h"
#include "base/threading/thread_task_runner_handle.h"
#include "jingle/glue/task_pump.h"
namespace jingle_glue {
TaskPump::TaskPump() : posted_wake_(false), stopped_(false) {}
TaskPump::~TaskPump() {
DCHECK_CALLED_ON_VALID_SEQUENCE(sequence_checker_);
}
void TaskPump::WakeTasks() {
DCHECK_CALLED_ON_VALID_SEQUENCE(sequence_checker_);
if (!stopped_ && !posted_wake_) {
// Do the requested wake up.
base::ThreadTaskRunnerHandle::Get()->PostTask(
FROM_HERE, base::BindOnce(&TaskPump::CheckAndRunTasks,
weak_factory_.GetWeakPtr()));
posted_wake_ = true;
}
}
void TaskPump::Stop() {
stopped_ = true;
}
void TaskPump::CheckAndRunTasks() {
DCHECK_CALLED_ON_VALID_SEQUENCE(sequence_checker_);
if (stopped_) {
return;
}
posted_wake_ = false;
// We shouldn't be using libjingle for timeout tasks, so we should
// have no timeout tasks at all.
// TODO(akalin): Add HasTimeoutTask() back in TaskRunner class and
// uncomment this check.
// DCHECK(!HasTimeoutTask())
RunTasks();
}
} // namespace jingle_glue