blob: 507a850ff0a01c45990b4ed67ef84e0a697b5750 [file] [log] [blame]
[email protected]0cb3d72e2013-02-21 21:50:341// 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
3// found in the LICENSE file.
4
danakj0a448602015-03-10 00:31:165#ifndef BASE_TIME_CLOCK_H_
6#define BASE_TIME_CLOCK_H_
[email protected]0cb3d72e2013-02-21 21:50:347
8#include "base/base_export.h"
[email protected]89bf27e2013-06-27 18:04:569#include "base/time/time.h"
[email protected]0cb3d72e2013-02-21 21:50:3410
11namespace base {
12
13// A Clock is an interface for objects that vend Times. It is
14// intended to be able to test the behavior of classes with respect to
15// time.
16//
[email protected]89bf27e2013-06-27 18:04:5617// See DefaultClock (base/time/default_clock.h) for the default
[email protected]0cb3d72e2013-02-21 21:50:3418// implementation that simply uses Time::Now().
19//
20// (An implementation that uses Time::SystemTime() should be added as
21// needed.)
22//
23// See SimpleTestClock (base/test/simple_test_clock.h) for a simple
24// test implementation.
25//
[email protected]89bf27e2013-06-27 18:04:5626// See TickClock (base/time/tick_clock.h) for the equivalent interface for
[email protected]0cb3d72e2013-02-21 21:50:3427// TimeTicks.
28class BASE_EXPORT Clock {
29 public:
30 virtual ~Clock();
31
32 // Now() must be safe to call from any thread. The caller cannot
33 // make any ordering assumptions about the returned Time. For
34 // example, the system clock may change to an earlier time.
35 virtual Time Now() = 0;
36};
37
38} // namespace base
39
danakj0a448602015-03-10 00:31:1640#endif // BASE_TIME_CLOCK_H_