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 stopwatch_.Start(ThreadData::NowForStartOfRun(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(ThreadData::NowForEndOfRun()); | |
jar (doing other things)
2014/08/27 15:25:18
Why do you need to stop the stopwatch if it is nev
vadimt
2014/08/27 19:14:20
Because Start and Stop should be strictly paired.
| |
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 |