Chromium Code Reviews| 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 |