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

Unified Diff: device/generic_sensor/platform_sensor.h

Issue 2865263002: Move //device/generic_sensor to be part of the internal implementation of the Device Service. (Closed)
Patch Set: code rebase Created 3 years, 7 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « device/generic_sensor/linux/sensor_device_manager.cc ('k') | device/generic_sensor/platform_sensor.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: device/generic_sensor/platform_sensor.h
diff --git a/device/generic_sensor/platform_sensor.h b/device/generic_sensor/platform_sensor.h
deleted file mode 100644
index 94629a552b9d9abe55556bce46e78145afa448c5..0000000000000000000000000000000000000000
--- a/device/generic_sensor/platform_sensor.h
+++ /dev/null
@@ -1,111 +0,0 @@
-// 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 DEVICE_GENERIC_SENSOR_PLATFORM_SENSOR_H_
-#define DEVICE_GENERIC_SENSOR_PLATFORM_SENSOR_H_
-
-#include <list>
-#include <map>
-
-#include "base/macros.h"
-#include "base/memory/ref_counted.h"
-#include "base/memory/weak_ptr.h"
-#include "base/observer_list.h"
-#include "base/single_thread_task_runner.h"
-#include "device/generic_sensor/generic_sensor_export.h"
-#include "device/generic_sensor/public/cpp/sensor_reading.h"
-#include "device/generic_sensor/public/interfaces/sensor.mojom.h"
-#include "mojo/public/cpp/system/buffer.h"
-
-namespace device {
-
-class PlatformSensorProvider;
-class PlatformSensorConfiguration;
-
-// Base class for the sensors provided by the platform. Concrete instances of
-// this class are created by platform specific PlatformSensorProvider.
-class DEVICE_GENERIC_SENSOR_EXPORT PlatformSensor
- : public base::RefCountedThreadSafe<PlatformSensor> {
- public:
- // The interface that must be implemented by PlatformSensor clients.
- class Client {
- public:
- virtual void OnSensorReadingChanged() = 0;
- virtual void OnSensorError() = 0;
- virtual bool IsNotificationSuspended() = 0;
-
- protected:
- virtual ~Client() {}
- };
-
- virtual mojom::ReportingMode GetReportingMode() = 0;
- virtual PlatformSensorConfiguration GetDefaultConfiguration() = 0;
-
- // Can be overriden to return the sensor maximum sampling frequency
- // value obtained from the platform if it is available. If platfrom
- // does not provide maximum sampling frequency this method must
- // return default frequency.
- // The default implementation returns default frequency.
- virtual double GetMaximumSupportedFrequency();
-
- // Can be overriden to return the sensor minimum sampling frequency.
- // The default implementation returns '1.0 / (60 * 60)', i.e. once per hour.
- virtual double GetMinimumSupportedFrequency();
-
- mojom::SensorType GetType() const;
-
- bool StartListening(Client* client,
- const PlatformSensorConfiguration& config);
- bool StopListening(Client* client, const PlatformSensorConfiguration& config);
-
- void UpdateSensor();
-
- void AddClient(Client*);
- void RemoveClient(Client*);
-
- protected:
- virtual ~PlatformSensor();
- PlatformSensor(mojom::SensorType type,
- mojo::ScopedSharedBufferMapping mapping,
- PlatformSensorProvider* provider);
-
- using ConfigMap = std::map<Client*, std::list<PlatformSensorConfiguration>>;
- using ReadingBuffer = SensorReadingSharedBuffer;
-
- virtual bool UpdateSensorInternal(const ConfigMap& configurations);
- virtual bool StartSensor(
- const PlatformSensorConfiguration& configuration) = 0;
- virtual void StopSensor() = 0;
- virtual bool CheckSensorConfiguration(
- const PlatformSensorConfiguration& configuration) = 0;
-
- // Updates shared buffer with new sensor reading data.
- // Note: this method is thread-safe.
- void UpdateSensorReading(const SensorReading& reading, bool notify_clients);
-
- void NotifySensorReadingChanged();
- void NotifySensorError();
-
- // For testing purposes.
- const ConfigMap& config_map() const { return config_map_; }
-
- // Task runner that is used by mojo objects for the IPC.
- // If platfrom sensor events are processed on a different
- // thread, notifications are forwarded to |task_runner_|.
- scoped_refptr<base::SingleThreadTaskRunner> task_runner_;
-
- private:
- friend class base::RefCountedThreadSafe<PlatformSensor>;
- const mojo::ScopedSharedBufferMapping shared_buffer_mapping_;
- mojom::SensorType type_;
- base::ObserverList<Client, true> clients_;
- ConfigMap config_map_;
- PlatformSensorProvider* provider_;
- base::WeakPtrFactory<PlatformSensor> weak_factory_;
- DISALLOW_COPY_AND_ASSIGN(PlatformSensor);
-};
-
-} // namespace device
-
-#endif // DEVICE_GENERIC_SENSOR_PLATFORM_SENSOR_H_
« no previous file with comments | « device/generic_sensor/linux/sensor_device_manager.cc ('k') | device/generic_sensor/platform_sensor.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698