Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 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 | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #ifndef CHROME_BROWSER_METRICS_LEAK_DETECTOR_CONTROLLER_H_ | |
| 6 #define CHROME_BROWSER_METRICS_LEAK_DETECTOR_CONTROLLER_H_ | |
| 7 | |
| 8 #include <vector> | |
| 9 | |
| 10 #include "base/macros.h" | |
| 11 #include "base/threading/thread_checker.h" | |
| 12 #include "components/metrics/leak_detector/leak_detector.h" | |
| 13 #include "components/metrics/proto/memory_leak_report.pb.h" | |
| 14 | |
| 15 namespace metrics { | |
| 16 | |
| 17 // This class initializes the LeakDetector on the browser process and registers | |
| 18 // itself to be notified of leak reports. | |
| 19 class LeakDetectorController : public LeakDetector::Observer { | |
| 20 public: | |
| 21 LeakDetectorController(); | |
| 22 ~LeakDetectorController() override; | |
| 23 | |
| 24 // Retrieves all reports in |stored_reports_|, moving them to |*reports|. | |
| 25 // |stored_reports_| is empty afterwards. | |
| 26 void GetLeakReports(std::vector<MemoryLeakReportProto>* reports); | |
| 27 | |
| 28 protected: | |
| 29 // LeakDetector::Observer: | |
| 30 void OnLeakFound(const LeakDetector::LeakReport& report) override; | |
|
Will Harris
2016/02/20 08:54:05
why is this protected and not public, normally int
Simon Que
2016/02/22 23:26:18
In an earlier comment, Alexei suggested it be made
| |
| 31 | |
| 32 private: | |
| 33 // Leak detector interface object. | |
| 34 LeakDetector detector_; | |
| 35 | |
| 36 // All leak reports received through OnLeakFound() are stored in protobuf | |
| 37 // format. | |
| 38 std::vector<MemoryLeakReportProto> stored_reports_; | |
| 39 | |
| 40 // For thread safety. | |
| 41 base::ThreadChecker thread_checker_; | |
| 42 | |
| 43 DISALLOW_COPY_AND_ASSIGN(LeakDetectorController); | |
| 44 }; | |
| 45 | |
| 46 } // namespace metrics | |
| 47 | |
| 48 #endif // CHROME_BROWSER_METRICS_LEAK_DETECTOR_CONTROLLER_H_ | |
| OLD | NEW |