Chromium Code Reviews| Index: chrome/browser/metrics/leak_detector_remote_controller.h |
| diff --git a/chrome/browser/metrics/leak_detector_remote_controller.h b/chrome/browser/metrics/leak_detector_remote_controller.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..b9c0bd7f83901dca14d17d423be54e8cd016ba71 |
| --- /dev/null |
| +++ b/chrome/browser/metrics/leak_detector_remote_controller.h |
| @@ -0,0 +1,63 @@ |
| +// Copyright 2016 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#ifndef CHROME_BROWSER_METRICS_LEAK_DETECTOR_REMOTE_CONTROLLER_H_ |
| +#define CHROME_BROWSER_METRICS_LEAK_DETECTOR_REMOTE_CONTROLLER_H_ |
| + |
| +#include <string> |
| +#include <vector> |
| + |
| +#include "base/macros.h" |
| +#include "components/metrics/leak_detector/leak_detector_remote.mojom.h" |
| +#include "components/metrics/proto/memory_leak_report.pb.h" |
| +#include "mojo/public/cpp/bindings/interface_request.h" |
| +#include "mojo/public/cpp/bindings/strong_binding.h" |
| + |
| +namespace metrics { |
| + |
| +// This class acts as an interface to LeakDetector clients running on processes |
| +// other than its own (the browser process). |
| +class LeakDetectorRemoteController : public LeakDetectorRemote { |
| + public: |
| + // Interface class to be implemented by a local controller class that provides |
| + // leak detector parameters and can pass leak reports to UMA. |
| + class LocalController { |
| + public: |
| + // Returns a set of leak detection params to be used when initializing the |
| + // leak detector on a remote process. |
| + virtual MemoryLeakReportProto_Params GetParams() const = 0; |
| + |
| + // Pass a vector of memory leak reports provided by a remote process to the |
| + // local controller class. |
| + virtual void SendLeakReports( |
| + const std::vector<MemoryLeakReportProto>& reports) = 0; |
| + }; |
| + |
| + ~LeakDetectorRemoteController() override; |
| + |
| + static void Create(LeakDetectorRemoteRequest request); |
| + |
| + // LeakDetectorRemote: |
| + void GetParams(const LeakDetectorRemote::GetParamsCallback& callback) override; |
| + void SendLeakReports(mojo::Array<mojo::String>) override; |
| + |
| + // Sets a global pointer to a LocalController implementation. The global |
| + // pointer is defined in the .cc file. |
| + static void set_local_controller_instance(LocalController* controller); |
|
Ilya Sherman
2016/06/08 02:49:21
Now that this is moved to the .cc file, please res
Simon Que
2016/06/08 06:30:06
Done.
|
| + |
| + private: |
| + explicit LeakDetectorRemoteController(LeakDetectorRemoteRequest request); |
| + |
| + // Single instance of LocalController. All remote LeakDetector clients will |
| + // get their params from and send leak reports to this instance. |
| + static LocalController* controller_; |
|
Ilya Sherman
2016/06/08 02:49:21
nit: Please remove this.
Simon Que
2016/06/08 06:30:06
Done.
|
| + |
| + mojo::StrongBinding<metrics::LeakDetectorRemote> binding_; |
| + |
| + DISALLOW_COPY_AND_ASSIGN(LeakDetectorRemoteController); |
| +}; |
| + |
| +} // namespace metrics |
| + |
| +#endif // CHROME_BROWSER_METRICS_LEAK_DETECTOR_REMOTE_CONTROLLER_H_ |