OLD | NEW |
---|---|
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 "chrome/installer/setup/installer_metrics.h" | 5 #include "chrome/installer/setup/installer_metrics.h" |
6 | 6 |
7 #include "base/files/file.h" | 7 #include "base/files/file.h" |
8 #include "base/files/file_path.h" | 8 #include "base/files/file_path.h" |
9 #include "base/files/file_util.h" | 9 #include "base/files/file_util.h" |
10 #include "base/metrics/histogram_base.h" | 10 #include "base/metrics/histogram_base.h" |
11 #include "base/metrics/histogram_persistence.h" | 11 #include "base/metrics/histogram_persistence.h" |
12 #include "base/metrics/persistent_memory_allocator.h" | 12 #include "base/metrics/persistent_memory_allocator.h" |
13 #include "chrome/installer/util/util_constants.h" | 13 #include "chrome/installer/util/util_constants.h" |
14 | 14 |
15 namespace installer { | 15 namespace installer { |
16 | 16 |
17 void BeginPersistentHistogramStorage() { | 17 void BeginPersistentHistogramStorage() { |
18 base::SetPersistentHistogramMemoryAllocator( | 18 base::SetPersistentHistogramMemoryAllocator( |
19 new base::LocalPersistentMemoryAllocator( | 19 new base::LocalPersistentMemoryAllocator( |
20 1 << 20, 0, // 1 MiB | 20 1 << 20, 0, // 1 MiB |
21 installer::kSetupHistogramAllocatorName)); | 21 installer::kSetupHistogramAllocatorName)); |
22 base::GetPersistentHistogramMemoryAllocator()->CreateTrackingHistograms( | 22 base::GetPersistentHistogramMemoryAllocator()->CreateTrackingHistograms( |
23 installer::kSetupHistogramAllocatorName); | 23 installer::kSetupHistogramAllocatorName); |
24 | |
25 // This can't be enabled until after the allocator is configured because | |
26 // there is no other reporting out of setup other than persistent memory. | |
27 base::HistogramBase::EnableCreationReportHistogram("setup"); | |
Alexei Svitkine (slow)
2016/03/01 16:41:34
I find it unfortunate that we need an extra call (
bcwhite
2016/03/02 19:14:19
Most of the time, the Report histogram will be ena
Alexei Svitkine (slow)
2016/03/03 17:56:23
You can have a helper function that calls the macr
bcwhite
2016/03/07 13:39:25
I guess I've done so much work on histograms that
Alexei Svitkine (slow)
2016/03/07 16:16:46
Right - my preference is to use the macros because
bcwhite
2016/03/07 20:09:25
Well... We're just going to have to agree to disa
Alexei Svitkine (slow)
2016/03/07 20:26:22
Okay, that's fair. Can you add a comment about thi
bcwhite
2016/03/07 20:47:34
Done.
Alexei Svitkine (slow)
2016/03/07 21:14:50
Yep - I see it! (I was using --gunit_shuffle inste
bcwhite
2016/03/07 22:20:41
Done.
| |
24 } | 28 } |
25 | 29 |
26 void EndPersistentHistogramStorage(const base::FilePath& target_path) { | 30 void EndPersistentHistogramStorage(const base::FilePath& target_path) { |
27 // For atomicity, first write to a temporary file and then rename it. | 31 // For atomicity, first write to a temporary file and then rename it. |
28 // The ImportantFileWriter would be good for this except it supports only | 32 // The ImportantFileWriter would be good for this except it supports only |
29 // std::string for its data. | 33 // std::string for its data. |
30 base::PersistentMemoryAllocator* allocator = | 34 base::PersistentMemoryAllocator* allocator = |
31 base::GetPersistentHistogramMemoryAllocator(); | 35 base::GetPersistentHistogramMemoryAllocator(); |
32 allocator->UpdateTrackingHistograms(); | 36 allocator->UpdateTrackingHistograms(); |
33 | 37 |
(...skipping 12 matching lines...) Expand all Loading... | |
46 if (base::ReplaceFile(tmp_file_path, file_path, nullptr)) { | 50 if (base::ReplaceFile(tmp_file_path, file_path, nullptr)) { |
47 VLOG(1) << "Persistent histograms saved in file: " | 51 VLOG(1) << "Persistent histograms saved in file: " |
48 << file_path.value(); | 52 << file_path.value(); |
49 } | 53 } |
50 } | 54 } |
51 base::DeleteFile(tmp_file_path, false); | 55 base::DeleteFile(tmp_file_path, false); |
52 } | 56 } |
53 } | 57 } |
54 | 58 |
55 } // namespace installer | 59 } // namespace installer |
OLD | NEW |