diff options
Diffstat (limited to 'Source/WebCore/dom/DeviceMotionData.h')
-rw-r--r-- | Source/WebCore/dom/DeviceMotionData.h | 106 |
1 files changed, 55 insertions, 51 deletions
diff --git a/Source/WebCore/dom/DeviceMotionData.h b/Source/WebCore/dom/DeviceMotionData.h index 1d53b531f..ccdb87a08 100644 --- a/Source/WebCore/dom/DeviceMotionData.h +++ b/Source/WebCore/dom/DeviceMotionData.h @@ -23,10 +23,9 @@ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ -#ifndef DeviceMotionData_h -#define DeviceMotionData_h +#pragma once -#include <wtf/PassRefPtr.h> +#include <wtf/Optional.h> #include <wtf/RefCounted.h> #include <wtf/RefPtr.h> @@ -36,74 +35,79 @@ class DeviceMotionData : public RefCounted<DeviceMotionData> { public: class Acceleration : public RefCounted<DeviceMotionData::Acceleration> { public: - static PassRefPtr<Acceleration> create(bool canProvideX, double x, bool canProvideY, double y, bool canProvideZ, double z); - - bool canProvideX() const { return m_canProvideX; } - bool canProvideY() const { return m_canProvideY; } - bool canProvideZ() const { return m_canProvideZ; } - - double x() const { return m_x; } - double y() const { return m_y; } - double z() const { return m_z; } + static Ref<Acceleration> create() + { + return adoptRef(*new Acceleration); + } + static Ref<Acceleration> create(std::optional<double> x, std::optional<double> y, std::optional<double> z) + { + return adoptRef(*new Acceleration(x, y, z)); + } + + std::optional<double> x() const { return m_x; } + std::optional<double> y() const { return m_y; } + std::optional<double> z() const { return m_z; } private: - Acceleration(bool canProvideX, double x, bool canProvideY, double y, bool canProvideZ, double z); - - double m_x; - double m_y; - double m_z; - - bool m_canProvideX; - bool m_canProvideY; - bool m_canProvideZ; + Acceleration() = default; + Acceleration(std::optional<double> x, std::optional<double> y, std::optional<double> z) + : m_x(x) + , m_y(y) + , m_z(z) + { + } + + std::optional<double> m_x; + std::optional<double> m_y; + std::optional<double> m_z; }; class RotationRate : public RefCounted<DeviceMotionData::RotationRate> { public: - static PassRefPtr<RotationRate> create(bool canProvideAlpha, double alpha, bool canProvideBeta, double beta, bool canProvideGamma, double gamma); - - bool canProvideAlpha() const { return m_canProvideAlpha; } - bool canProvideBeta() const { return m_canProvideBeta; } - bool canProvideGamma() const { return m_canProvideGamma; } - - double alpha() const { return m_alpha; } - double beta() const { return m_beta; } - double gamma() const { return m_gamma; } + static Ref<RotationRate> create() + { + return adoptRef(*new RotationRate); + } + static Ref<RotationRate> create(std::optional<double> alpha, std::optional<double> beta, std::optional<double> gamma) + { + return adoptRef(*new RotationRate(alpha, beta, gamma)); + } + + std::optional<double> alpha() const { return m_alpha; } + std::optional<double> beta() const { return m_beta; } + std::optional<double> gamma() const { return m_gamma; } private: - RotationRate(bool canProvideAlpha, double alpha, bool canProvideBeta, double beta, bool canProvideGamma, double gamma); - - double m_alpha; - double m_beta; - double m_gamma; - - bool m_canProvideAlpha; - bool m_canProvideBeta; - bool m_canProvideGamma; + RotationRate() = default; + RotationRate(std::optional<double> alpha, std::optional<double> beta, std::optional<double> gamma) + : m_alpha(alpha) + , m_beta(beta) + , m_gamma(gamma) + { + } + + std::optional<double> m_alpha; + std::optional<double> m_beta; + std::optional<double> m_gamma; }; - static PassRefPtr<DeviceMotionData> create(); - static PassRefPtr<DeviceMotionData> create(PassRefPtr<Acceleration> acceleration, PassRefPtr<Acceleration> accelerationIncludingGravity, - PassRefPtr<RotationRate> rotationRate, bool canProvideInterval, double interval); + WEBCORE_EXPORT static Ref<DeviceMotionData> create(); + WEBCORE_EXPORT static Ref<DeviceMotionData> create(RefPtr<Acceleration>&&, RefPtr<Acceleration>&& accelerationIncludingGravity, RefPtr<RotationRate>&&, std::optional<double> interval); const Acceleration* acceleration() const { return m_acceleration.get(); } const Acceleration* accelerationIncludingGravity() const { return m_accelerationIncludingGravity.get(); } const RotationRate* rotationRate() const { return m_rotationRate.get(); } - double interval() const { return m_interval; } - bool canProvideInterval() const { return m_canProvideInterval; } + + std::optional<double> interval() const { return m_interval; } private: - DeviceMotionData(); - DeviceMotionData(PassRefPtr<Acceleration> acceleration, PassRefPtr<Acceleration> accelerationIncludingGravity, - PassRefPtr<RotationRate> rotationRate, bool canProvideInterval, double interval); + DeviceMotionData() = default; + DeviceMotionData(RefPtr<Acceleration>&&, RefPtr<Acceleration>&& accelerationIncludingGravity, RefPtr<RotationRate>&&, std::optional<double> interval); RefPtr<Acceleration> m_acceleration; RefPtr<Acceleration> m_accelerationIncludingGravity; RefPtr<RotationRate> m_rotationRate; - bool m_canProvideInterval; - double m_interval; + std::optional<double> m_interval; }; } // namespace WebCore - -#endif // DeviceMotionData_h |