OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "base/profiler/scoped_profile.h" | 5 #include "base/profiler/scoped_profile.h" |
6 | 6 |
7 #include "base/location.h" | 7 #include "base/location.h" |
8 #include "base/tracked_objects.h" | 8 #include "base/tracked_objects.h" |
9 | 9 |
10 | 10 |
11 namespace tracked_objects { | 11 namespace tracked_objects { |
12 | 12 |
13 | 13 |
14 ScopedProfile::ScopedProfile(const Location& location) | 14 ScopedProfile::ScopedProfile(const Location& location) |
15 : birth_(ThreadData::TallyABirthIfActive(location)), | 15 : birth_(ThreadData::TallyABirthIfActive(location)) { |
16 start_of_run_(ThreadData::NowForStartOfRun(birth_)) { | 16 ThreadData::PrepareForStartOfRun(birth_); |
17 } | 17 } |
18 | 18 |
19 ScopedProfile::~ScopedProfile() { | 19 ScopedProfile::~ScopedProfile() { |
20 StopClockAndTally(); | 20 StopClockAndTally(); |
21 } | 21 } |
22 | 22 |
23 void ScopedProfile::StopClockAndTally() { | 23 void ScopedProfile::StopClockAndTally() { |
| 24 stopwatch_.Stop(); |
| 25 |
24 if (!birth_) | 26 if (!birth_) |
25 return; | 27 return; |
26 ThreadData::TallyRunInAScopedRegionIfTracking(birth_, start_of_run_, | 28 ThreadData::TallyRunInAScopedRegionIfTracking(birth_, stopwatch_); |
27 ThreadData::NowForEndOfRun()); | |
28 birth_ = NULL; | 29 birth_ = NULL; |
29 } | 30 } |
30 | 31 |
31 } // namespace tracked_objects | 32 } // namespace tracked_objects |
OLD | NEW |