Index: services/device/device_service.h |
diff --git a/services/device/device_service.h b/services/device/device_service.h |
index 7e9e44a1532c6c70d503b326f598e8a8b84c4f42..a51a397ac25ed7f4743cd26d8dd786daad769a63 100644 |
--- a/services/device/device_service.h |
+++ b/services/device/device_service.h |
@@ -6,14 +6,17 @@ |
#define SERVICES_DEVICE_DEVICE_SERVICE_H_ |
#include "base/memory/ref_counted.h" |
+#include "device/battery/battery_monitor.mojom.h" |
#include "device/screen_orientation/public/interfaces/screen_orientation.mojom.h" |
#include "device/sensors/public/interfaces/light.mojom.h" |
#include "device/sensors/public/interfaces/motion.mojom.h" |
#include "device/sensors/public/interfaces/orientation.mojom.h" |
+#include "mojo/public/cpp/bindings/binding_set.h" |
#include "services/device/public/interfaces/fingerprint.mojom.h" |
#include "services/device/public/interfaces/power_monitor.mojom.h" |
#include "services/device/public/interfaces/time_zone_monitor.mojom.h" |
#include "services/service_manager/public/cpp/interface_factory.h" |
+#include "services/service_manager/public/cpp/interface_provider.h" |
#include "services/service_manager/public/cpp/service.h" |
namespace base { |
@@ -37,6 +40,10 @@ class DeviceService |
public service_manager::InterfaceFactory<mojom::OrientationSensor>, |
public service_manager::InterfaceFactory< |
mojom::OrientationAbsoluteSensor>, |
+#if !defined(OS_ANDROID) |
+ // On Android the Device Service provides BatteryMonitor via Java. |
+ public service_manager::InterfaceFactory<BatteryMonitor>, |
+#endif |
public service_manager::InterfaceFactory<mojom::PowerMonitor>, |
public service_manager::InterfaceFactory< |
mojom::ScreenOrientationListener>, |
@@ -72,6 +79,12 @@ class DeviceService |
void Create(const service_manager::Identity& remote_identity, |
mojom::OrientationAbsoluteSensorRequest request) override; |
+#if !defined(OS_ANDROID) |
+ // InterfaceFactory<BatteryMonitor>: |
+ void Create(const service_manager::Identity& remote_identity, |
+ BatteryMonitorRequest request) override; |
+#endif |
+ |
// InterfaceFactory<mojom::PowerMonitor>: |
void Create(const service_manager::Identity& remote_identity, |
mojom::PowerMonitorRequest request) override; |
@@ -87,6 +100,16 @@ class DeviceService |
std::unique_ptr<PowerMonitorMessageBroadcaster> |
power_monitor_message_broadcaster_; |
std::unique_ptr<TimeZoneMonitor> time_zone_monitor_; |
+#if defined(OS_ANDROID) |
+ // Binds |java_interface_provider_| to an interface registry that exposes |
+ // factories for the interfaces that are provided via Java on Android. |
+ service_manager::InterfaceProvider* GetJavaInterfaceProvider(); |
+ |
+ // InterfaceProvider that is bound to the Java-side interface registry. |
+ service_manager::InterfaceProvider java_interface_provider_; |
+ |
+ bool java_interface_provider_initialized_; |
+#endif |
scoped_refptr<base::SingleThreadTaskRunner> file_task_runner_; |
scoped_refptr<base::SingleThreadTaskRunner> io_task_runner_; |