OLD | NEW |
---|---|
(Empty) | |
1 /* | |
2 * Copyright 2016 The WebRTC project authors. All Rights Reserved. | |
3 * | |
4 * Use of this source code is governed by a BSD-style license | |
5 * that can be found in the LICENSE file in the root of the source | |
6 * tree. An additional intellectual property rights grant can be found | |
7 * in the file PATENTS. All contributing project authors may | |
8 * be found in the AUTHORS file in the root of the source tree. | |
9 */ | |
10 | |
11 #include "webrtc/base/fakeclock.h" | |
12 | |
13 #include "webrtc/base/checks.h" | |
14 #include "webrtc/base/messagequeue.h" | |
15 | |
16 namespace rtc { | |
17 | |
18 uint64_t FakeClock::TimeNanos() const { | |
19 CritScope cs(&lock_); | |
20 return time_; | |
21 } | |
22 | |
23 void FakeClock::SetTimeNanos(uint64_t nanos) { | |
24 { | |
25 CritScope cs(&lock_); | |
26 RTC_DCHECK(nanos >= time_); | |
27 time_ = nanos; | |
28 } | |
29 // If message queues are waiting in a socket select() with a timeout provided | |
30 // by the OS, they should wake up to check if there are any messages ready to | |
31 // be dispatched based on the fake time. | |
32 MessageQueueManager::WakeAllMessageQueues(); | |
33 } | |
34 | |
35 void FakeClock::AdvanceTimeNanos(uint64_t nanos) { | |
36 CritScope cs(&lock_); | |
37 SetTimeNanos(time_ + nanos); | |
38 } | |
39 | |
40 void FakeClock::AdvanceTimeMicros(uint64_t micros) { | |
41 AdvanceTimeNanos(micros * 1000); | |
pthatcher1
2016/05/24 18:05:46
You could use kNumNanosecsPerMicrosec.
Taylor Brandstetter
2016/05/24 21:47:59
Done.
| |
42 } | |
43 | |
44 void FakeClock::AdvanceTimeMillis(uint64_t millis) { | |
45 AdvanceTimeNanos(millis * 1000 * 1000); | |
pthatcher1
2016/05/24 18:05:46
And kNumNanosecsPerMillisec and kNumNanosecsPerSec
Taylor Brandstetter
2016/05/24 21:47:59
Done.
| |
46 } | |
47 | |
48 void FakeClock::AdvanceTimeSeconds(uint64_t seconds) { | |
49 AdvanceTimeNanos(seconds * 1000 * 1000 * 1000); | |
50 } | |
51 | |
52 } // namespace rtc | |
OLD | NEW |