1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
|
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this file,
* You can obtain one at http://mozilla.org/MPL/2.0/. */
#include "nsWrapperCache.h"
#include "mozilla/HoldDropJSObjects.h"
#include "mozilla/dom/GamepadPoseBinding.h"
#include "mozilla/dom/GamepadPose.h"
namespace mozilla::dom {
GamepadPose::GamepadPose(nsISupports* aParent, const GamepadPoseState& aState)
: Pose(aParent), mPoseState(aState) {
mozilla::HoldJSObjects(this);
}
GamepadPose::GamepadPose(nsISupports* aParent) : Pose(aParent) {
mozilla::HoldJSObjects(this);
mPoseState.Clear();
}
GamepadPose::~GamepadPose() { mozilla::DropJSObjects(this); }
/* virtual */
JSObject* GamepadPose::WrapObject(JSContext* aJSContext,
JS::Handle<JSObject*> aGivenProto) {
return GamepadPose_Binding::Wrap(aJSContext, this, aGivenProto);
}
bool GamepadPose::HasOrientation() const {
return bool(mPoseState.flags & GamepadCapabilityFlags::Cap_Orientation);
}
bool GamepadPose::HasPosition() const {
return bool(mPoseState.flags & GamepadCapabilityFlags::Cap_Position) ||
bool(mPoseState.flags & GamepadCapabilityFlags::Cap_PositionEmulated);
}
void GamepadPose::GetPosition(JSContext* aJSContext,
JS::MutableHandle<JSObject*> aRetval,
ErrorResult& aRv) {
const bool valid =
mPoseState.isPositionValid &&
(bool(mPoseState.flags & GamepadCapabilityFlags::Cap_Position) ||
bool(mPoseState.flags & GamepadCapabilityFlags::Cap_PositionEmulated));
SetFloat32Array(aJSContext, this, aRetval, mPosition,
valid ? mPoseState.position : nullptr, 3, aRv);
}
void GamepadPose::GetLinearVelocity(JSContext* aJSContext,
JS::MutableHandle<JSObject*> aRetval,
ErrorResult& aRv) {
const bool valid =
mPoseState.isPositionValid &&
(bool(mPoseState.flags & GamepadCapabilityFlags::Cap_Position) ||
bool(mPoseState.flags & GamepadCapabilityFlags::Cap_PositionEmulated));
SetFloat32Array(aJSContext, this, aRetval, mLinearVelocity,
valid ? mPoseState.linearVelocity : nullptr, 3, aRv);
}
void GamepadPose::GetLinearAcceleration(JSContext* aJSContext,
JS::MutableHandle<JSObject*> aRetval,
ErrorResult& aRv) {
const bool valid =
mPoseState.isPositionValid &&
bool(mPoseState.flags & GamepadCapabilityFlags::Cap_LinearAcceleration);
SetFloat32Array(aJSContext, this, aRetval, mLinearAcceleration,
valid ? mPoseState.linearAcceleration : nullptr, 3, aRv);
}
void GamepadPose::GetOrientation(JSContext* aJSContext,
JS::MutableHandle<JSObject*> aRetval,
ErrorResult& aRv) {
const bool valid =
mPoseState.isOrientationValid &&
bool(mPoseState.flags & GamepadCapabilityFlags::Cap_Orientation);
SetFloat32Array(aJSContext, this, aRetval, mOrientation,
valid ? mPoseState.orientation : nullptr, 4, aRv);
}
void GamepadPose::GetAngularVelocity(JSContext* aJSContext,
JS::MutableHandle<JSObject*> aRetval,
ErrorResult& aRv) {
const bool valid =
mPoseState.isOrientationValid &&
bool(mPoseState.flags & GamepadCapabilityFlags::Cap_Orientation);
SetFloat32Array(aJSContext, this, aRetval, mAngularVelocity,
valid ? mPoseState.angularVelocity : nullptr, 3, aRv);
}
void GamepadPose::GetAngularAcceleration(JSContext* aJSContext,
JS::MutableHandle<JSObject*> aRetval,
ErrorResult& aRv) {
const bool valid =
mPoseState.isOrientationValid &&
bool(mPoseState.flags & GamepadCapabilityFlags::Cap_AngularAcceleration);
SetFloat32Array(aJSContext, this, aRetval, mAngularAcceleration,
valid ? mPoseState.angularAcceleration : nullptr, 3, aRv);
}
void GamepadPose::SetPoseState(const GamepadPoseState& aPose) {
mPoseState = aPose;
}
const GamepadPoseState& GamepadPose::GetPoseState() { return mPoseState; }
} // namespace mozilla::dom
|