OLD | NEW |
1 | 1 |
2 /* | 2 /* |
3 * Copyright 2006 The Android Open Source Project | 3 * Copyright 2006 The Android Open Source Project |
4 * | 4 * |
5 * Use of this source code is governed by a BSD-style license that can be | 5 * Use of this source code is governed by a BSD-style license that can be |
6 * found in the LICENSE file. | 6 * found in the LICENSE file. |
7 */ | 7 */ |
8 | 8 |
9 | 9 |
10 #ifndef SkTime_DEFINED | 10 #ifndef SkTime_DEFINED |
(...skipping 16 matching lines...) Expand all Loading... |
27 uint8_t fDayOfWeek; //!< 0..6, 0==Sunday | 27 uint8_t fDayOfWeek; //!< 0..6, 0==Sunday |
28 uint8_t fDay; //!< 1..31 | 28 uint8_t fDay; //!< 1..31 |
29 uint8_t fHour; //!< 0..23 | 29 uint8_t fHour; //!< 0..23 |
30 uint8_t fMinute; //!< 0..59 | 30 uint8_t fMinute; //!< 0..59 |
31 uint8_t fSecond; //!< 0..59 | 31 uint8_t fSecond; //!< 0..59 |
32 | 32 |
33 void toISO8601(SkString* dst) const; | 33 void toISO8601(SkString* dst) const; |
34 }; | 34 }; |
35 static void GetDateTime(DateTime*); | 35 static void GetDateTime(DateTime*); |
36 | 36 |
37 static SkMSec GetMSecs() { return (SkMSec)(GetNSecs() * 1e-6); } | 37 static double GetSecs() { return GetNSecs() * 1e-9; } |
| 38 static double GetMSecs() { return GetNSecs() * 1e-6; } |
38 static double GetNSecs(); | 39 static double GetNSecs(); |
39 }; | 40 }; |
40 | 41 |
41 #define SK_TIME_FACTOR 1 | |
42 | |
43 /////////////////////////////////////////////////////////////////////////////// | 42 /////////////////////////////////////////////////////////////////////////////// |
44 | 43 |
45 class SkAutoTime { | 44 class SkAutoTime { |
46 public: | 45 public: |
47 // The label is not deep-copied, so its address must remain valid for the | 46 // The label is not deep-copied, so its address must remain valid for the |
48 // lifetime of this object | 47 // lifetime of this object |
49 SkAutoTime(const char* label = NULL, SkMSec minToDump = 0) : fLabel(label) | 48 SkAutoTime(const char* label = nullptr) |
50 { | 49 : fLabel(label) |
51 fNow = SkTime::GetMSecs(); | 50 , fNow(SkTime::GetMSecs()) {} |
52 fMinToDump = minToDump; | 51 ~SkAutoTime() { |
53 } | 52 uint64_t dur = static_cast<uint64_t>(SkTime::GetMSecs() - fNow); |
54 ~SkAutoTime() | 53 SkDebugf("%s %ld\n", fLabel ? fLabel : "", dur); |
55 { | |
56 SkMSec dur = SkTime::GetMSecs() - fNow; | |
57 if (dur >= fMinToDump) { | |
58 SkDebugf("%s %d\n", fLabel ? fLabel : "", dur); | |
59 } | |
60 } | 54 } |
61 private: | 55 private: |
62 const char* fLabel; | 56 const char* fLabel; |
63 SkMSec fNow; | 57 double fNow; |
64 SkMSec fMinToDump; | |
65 }; | 58 }; |
66 #define SkAutoTime(...) SK_REQUIRE_LOCAL_VAR(SkAutoTime) | 59 #define SkAutoTime(...) SK_REQUIRE_LOCAL_VAR(SkAutoTime) |
67 | 60 |
68 #endif | 61 #endif |
OLD | NEW |