• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 
2 /*
3  * Copyright 2006 The Android Open Source Project
4  *
5  * Use of this source code is governed by a BSD-style license that can be
6  * found in the LICENSE file.
7  */
8 
9 
10 #ifndef SkTime_DEFINED
11 #define SkTime_DEFINED
12 
13 #include "SkTypes.h"
14 
15 class SkString;
16 
17 /** \class SkTime
18     Platform-implemented utilities to return time of day, and millisecond counter.
19 */
20 class SkTime {
21 public:
22     struct DateTime {
23         int16_t  fTimeZoneMinutes;  // The number of minutes that GetDateTime()
24                                     // is ahead of or behind UTC.
25         uint16_t fYear;          //!< e.g. 2005
26         uint8_t  fMonth;         //!< 1..12
27         uint8_t  fDayOfWeek;     //!< 0..6, 0==Sunday
28         uint8_t  fDay;           //!< 1..31
29         uint8_t  fHour;          //!< 0..23
30         uint8_t  fMinute;        //!< 0..59
31         uint8_t  fSecond;        //!< 0..59
32 
33         void toISO8601(SkString* dst) const;
34     };
35     static void GetDateTime(DateTime*);
36 
37     static SkMSec GetMSecs();
38 };
39 
40 #if defined(SK_DEBUG) && defined(SK_BUILD_FOR_WIN32)
41     extern SkMSec gForceTickCount;
42 #endif
43 
44 #define SK_TIME_FACTOR      1
45 
46 ///////////////////////////////////////////////////////////////////////////////
47 
48 class SkAutoTime {
49 public:
50     // The label is not deep-copied, so its address must remain valid for the
51     // lifetime of this object
fLabel(label)52     SkAutoTime(const char* label = NULL, SkMSec minToDump = 0) : fLabel(label)
53     {
54         fNow = SkTime::GetMSecs();
55         fMinToDump = minToDump;
56     }
~SkAutoTime()57     ~SkAutoTime()
58     {
59         SkMSec dur = SkTime::GetMSecs() - fNow;
60         if (dur >= fMinToDump) {
61             SkDebugf("%s %d\n", fLabel ? fLabel : "", dur);
62         }
63     }
64 private:
65     const char* fLabel;
66     SkMSec      fNow;
67     SkMSec      fMinToDump;
68 };
69 #define SkAutoTime(...) SK_REQUIRE_LOCAL_VAR(SkAutoTime)
70 
71 #endif
72