Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(256)

Side by Side Diff: device/battery/battery_monitor_impl.h

Issue 2326913003: Privatize StrongBinding lifetime management (Closed)
Patch Set: rebase Created 4 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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 #ifndef DEVICE_BATTERY_BATTERY_MONITOR_IMPL_H_ 5 #ifndef DEVICE_BATTERY_BATTERY_MONITOR_IMPL_H_
6 #define DEVICE_BATTERY_BATTERY_MONITOR_IMPL_H_ 6 #define DEVICE_BATTERY_BATTERY_MONITOR_IMPL_H_
7 7
8 #include <memory> 8 #include <memory>
9 9
10 #include "base/macros.h" 10 #include "base/macros.h"
11 #include "device/battery/battery_export.h" 11 #include "device/battery/battery_export.h"
12 #include "device/battery/battery_monitor.mojom.h" 12 #include "device/battery/battery_monitor.mojom.h"
13 #include "device/battery/battery_status_service.h" 13 #include "device/battery/battery_status_service.h"
14 #include "mojo/public/cpp/bindings/strong_binding.h"
15 14
16 namespace device { 15 namespace device {
17 16
18 class BatteryMonitorImpl : public BatteryMonitor { 17 class BatteryMonitorImpl : public BatteryMonitor {
19 public: 18 public:
20 DEVICE_BATTERY_EXPORT static void Create( 19 DEVICE_BATTERY_EXPORT static void Create(BatteryMonitorRequest request);
21 mojo::InterfaceRequest<BatteryMonitor> request); 20
21 BatteryMonitorImpl();
22 ~BatteryMonitorImpl() override;
22 23
23 private: 24 private:
24 explicit BatteryMonitorImpl(mojo::InterfaceRequest<BatteryMonitor> request);
25 ~BatteryMonitorImpl() override;
26
27 // BatteryMonitor methods: 25 // BatteryMonitor methods:
28 void QueryNextStatus(const QueryNextStatusCallback& callback) override; 26 void QueryNextStatus(const QueryNextStatusCallback& callback) override;
29 27
30 void RegisterSubscription(); 28 void RegisterSubscription();
31 void DidChange(const BatteryStatus& battery_status); 29 void DidChange(const BatteryStatus& battery_status);
32 void ReportStatus(); 30 void ReportStatus();
33 31
34 mojo::StrongBinding<BatteryMonitor> binding_;
35 std::unique_ptr<BatteryStatusService::BatteryUpdateSubscription> 32 std::unique_ptr<BatteryStatusService::BatteryUpdateSubscription>
36 subscription_; 33 subscription_;
37 QueryNextStatusCallback callback_; 34 QueryNextStatusCallback callback_;
38 BatteryStatus status_; 35 BatteryStatus status_;
39 bool status_to_report_; 36 bool status_to_report_;
40 37
41 DISALLOW_COPY_AND_ASSIGN(BatteryMonitorImpl); 38 DISALLOW_COPY_AND_ASSIGN(BatteryMonitorImpl);
42 }; 39 };
43 40
44 } // namespace device 41 } // namespace device
45 42
46 #endif // DEVICE_BATTERY_BATTERY_MONITOR_IMPL_H_ 43 #endif // DEVICE_BATTERY_BATTERY_MONITOR_IMPL_H_
OLDNEW
« no previous file with comments | « content/shell/utility/shell_content_utility_client.cc ('k') | device/battery/battery_monitor_impl.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698