mirror of
https://github.com/servo/servo.git
synced 2025-08-04 05:00:08 +01:00
Fix unsafe Heap constructor usage in DOM objects
This commit is contained in:
parent
ed7686b42c
commit
efb59b7ecd
7 changed files with 82 additions and 84 deletions
|
@ -35,7 +35,7 @@ impl ExtendableMessageEvent {
|
||||||
-> Root<ExtendableMessageEvent> {
|
-> Root<ExtendableMessageEvent> {
|
||||||
let ev = box ExtendableMessageEvent {
|
let ev = box ExtendableMessageEvent {
|
||||||
event: ExtendableEvent::new_inherited(),
|
event: ExtendableEvent::new_inherited(),
|
||||||
data: Heap::new(data.get()),
|
data: Heap::default(),
|
||||||
origin: origin,
|
origin: origin,
|
||||||
lastEventId: lastEventId,
|
lastEventId: lastEventId,
|
||||||
};
|
};
|
||||||
|
@ -44,6 +44,8 @@ impl ExtendableMessageEvent {
|
||||||
let event = ev.upcast::<Event>();
|
let event = ev.upcast::<Event>();
|
||||||
event.init_event(type_, bubbles, cancelable);
|
event.init_event(type_, bubbles, cancelable);
|
||||||
}
|
}
|
||||||
|
ev.data.set(data.get());
|
||||||
|
|
||||||
ev
|
ev
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -20,7 +20,6 @@ use dom_struct::dom_struct;
|
||||||
use js::jsapi::{Heap, JSContext, JSObject};
|
use js::jsapi::{Heap, JSContext, JSObject};
|
||||||
use js::typedarray::{Float64Array, CreateWith};
|
use js::typedarray::{Float64Array, CreateWith};
|
||||||
use std::cell::Cell;
|
use std::cell::Cell;
|
||||||
use std::ptr;
|
|
||||||
use webvr_traits::{WebVRGamepadData, WebVRGamepadHand, WebVRGamepadState};
|
use webvr_traits::{WebVRGamepadData, WebVRGamepadHand, WebVRGamepadState};
|
||||||
|
|
||||||
#[dom_struct]
|
#[dom_struct]
|
||||||
|
@ -47,7 +46,6 @@ impl Gamepad {
|
||||||
connected: bool,
|
connected: bool,
|
||||||
timestamp: f64,
|
timestamp: f64,
|
||||||
mapping_type: String,
|
mapping_type: String,
|
||||||
axes: *mut JSObject,
|
|
||||||
buttons: &GamepadButtonList,
|
buttons: &GamepadButtonList,
|
||||||
pose: Option<&VRPose>,
|
pose: Option<&VRPose>,
|
||||||
hand: WebVRGamepadHand,
|
hand: WebVRGamepadHand,
|
||||||
|
@ -60,7 +58,7 @@ impl Gamepad {
|
||||||
connected: Cell::new(connected),
|
connected: Cell::new(connected),
|
||||||
timestamp: Cell::new(timestamp),
|
timestamp: Cell::new(timestamp),
|
||||||
mapping_type: mapping_type,
|
mapping_type: mapping_type,
|
||||||
axes: Heap::new(axes),
|
axes: Heap::default(),
|
||||||
buttons: JS::from_ref(buttons),
|
buttons: JS::from_ref(buttons),
|
||||||
pose: pose.map(JS::from_ref),
|
pose: pose.map(JS::from_ref),
|
||||||
hand: hand,
|
hand: hand,
|
||||||
|
@ -75,28 +73,24 @@ impl Gamepad {
|
||||||
state: &WebVRGamepadState) -> Root<Gamepad> {
|
state: &WebVRGamepadState) -> Root<Gamepad> {
|
||||||
let buttons = GamepadButtonList::new_from_vr(&global, &state.buttons);
|
let buttons = GamepadButtonList::new_from_vr(&global, &state.buttons);
|
||||||
let pose = VRPose::new(&global, &state.pose);
|
let pose = VRPose::new(&global, &state.pose);
|
||||||
let cx = global.get_cx();
|
|
||||||
rooted!(in (cx) let mut axes = ptr::null_mut());
|
|
||||||
unsafe {
|
|
||||||
let _ = Float64Array::create(cx,
|
|
||||||
CreateWith::Slice(&state.axes),
|
|
||||||
axes.handle_mut());
|
|
||||||
}
|
|
||||||
|
|
||||||
reflect_dom_object(box Gamepad::new_inherited(state.gamepad_id,
|
let gamepad = reflect_dom_object(box Gamepad::new_inherited(state.gamepad_id,
|
||||||
data.name.clone(),
|
data.name.clone(),
|
||||||
index,
|
index,
|
||||||
state.connected,
|
state.connected,
|
||||||
state.timestamp,
|
state.timestamp,
|
||||||
"".into(),
|
"".into(),
|
||||||
axes.get(),
|
|
||||||
&buttons,
|
&buttons,
|
||||||
Some(&pose),
|
Some(&pose),
|
||||||
data.hand.clone(),
|
data.hand.clone(),
|
||||||
data.display_id),
|
data.display_id),
|
||||||
global,
|
global,
|
||||||
GamepadBinding::Wrap)
|
GamepadBinding::Wrap);
|
||||||
|
unsafe {
|
||||||
|
let _ = Float64Array::create(global.get_cx(), CreateWith::Slice(&state.axes), gamepad.axes.handle_mut());
|
||||||
|
}
|
||||||
|
|
||||||
|
gamepad
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -41,11 +41,14 @@ impl MessageEvent {
|
||||||
lastEventId: DOMString) -> Root<MessageEvent> {
|
lastEventId: DOMString) -> Root<MessageEvent> {
|
||||||
let ev = box MessageEvent {
|
let ev = box MessageEvent {
|
||||||
event: Event::new_inherited(),
|
event: Event::new_inherited(),
|
||||||
data: Heap::new(data.get()),
|
data: Heap::default(),
|
||||||
origin: origin,
|
origin: origin,
|
||||||
lastEventId: lastEventId,
|
lastEventId: lastEventId,
|
||||||
};
|
};
|
||||||
reflect_dom_object(ev, global, MessageEventBinding::Wrap)
|
let ev = reflect_dom_object(ev, global, MessageEventBinding::Wrap);
|
||||||
|
ev.data.set(data.get());
|
||||||
|
|
||||||
|
ev
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn new(global: &GlobalScope, type_: Atom,
|
pub fn new(global: &GlobalScope, type_: Atom,
|
||||||
|
|
|
@ -28,29 +28,29 @@ pub struct VREyeParameters {
|
||||||
unsafe_no_jsmanaged_fields!(WebVREyeParameters);
|
unsafe_no_jsmanaged_fields!(WebVREyeParameters);
|
||||||
|
|
||||||
impl VREyeParameters {
|
impl VREyeParameters {
|
||||||
#[allow(unsafe_code)]
|
fn new_inherited(parameters: WebVREyeParameters, fov: &VRFieldOfView) -> VREyeParameters {
|
||||||
#[allow(unrooted_must_root)]
|
VREyeParameters {
|
||||||
fn new_inherited(parameters: WebVREyeParameters, global: &GlobalScope) -> VREyeParameters {
|
|
||||||
let fov = VRFieldOfView::new(&global, parameters.field_of_view.clone());
|
|
||||||
let result = VREyeParameters {
|
|
||||||
reflector_: Reflector::new(),
|
reflector_: Reflector::new(),
|
||||||
parameters: DOMRefCell::new(parameters),
|
parameters: DOMRefCell::new(parameters),
|
||||||
offset: Heap::default(),
|
offset: Heap::default(),
|
||||||
fov: JS::from_ref(&*fov)
|
fov: JS::from_ref(&*fov)
|
||||||
};
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[allow(unsafe_code)]
|
||||||
|
pub fn new(parameters: WebVREyeParameters, global: &GlobalScope) -> Root<VREyeParameters> {
|
||||||
|
let fov = VRFieldOfView::new(&global, parameters.field_of_view.clone());
|
||||||
|
|
||||||
|
let eye_parameters = reflect_dom_object(box VREyeParameters::new_inherited(parameters, &fov),
|
||||||
|
global,
|
||||||
|
VREyeParametersBinding::Wrap);
|
||||||
unsafe {
|
unsafe {
|
||||||
let _ = Float32Array::create(global.get_cx(),
|
let _ = Float32Array::create(global.get_cx(),
|
||||||
CreateWith::Slice(&result.parameters.borrow().offset),
|
CreateWith::Slice(&eye_parameters.parameters.borrow().offset),
|
||||||
result.offset.handle_mut());
|
eye_parameters.offset.handle_mut());
|
||||||
}
|
|
||||||
result
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn new(parameters: WebVREyeParameters, global: &GlobalScope) -> Root<VREyeParameters> {
|
eye_parameters
|
||||||
reflect_dom_object(box VREyeParameters::new_inherited(parameters, global),
|
|
||||||
global,
|
|
||||||
VREyeParametersBinding::Wrap)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -31,16 +31,8 @@ pub struct VRFrameData {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl VRFrameData {
|
impl VRFrameData {
|
||||||
#[allow(unsafe_code)]
|
fn new_inherited(pose: &VRPose) -> VRFrameData {
|
||||||
#[allow(unrooted_must_root)]
|
VRFrameData {
|
||||||
fn new(global: &GlobalScope) -> Root<VRFrameData> {
|
|
||||||
let matrix = [1.0, 0.0, 0.0, 0.0,
|
|
||||||
0.0, 1.0, 0.0, 0.0,
|
|
||||||
0.0, 0.0, 1.0, 0.0,
|
|
||||||
0.0, 0.0, 0.0, 1.0f32];
|
|
||||||
let pose = VRPose::new(&global, &Default::default());
|
|
||||||
|
|
||||||
let framedata = VRFrameData {
|
|
||||||
reflector_: Reflector::new(),
|
reflector_: Reflector::new(),
|
||||||
left_proj: Heap::default(),
|
left_proj: Heap::default(),
|
||||||
left_view: Heap::default(),
|
left_view: Heap::default(),
|
||||||
|
@ -49,23 +41,25 @@ impl VRFrameData {
|
||||||
pose: JS::from_ref(&*pose),
|
pose: JS::from_ref(&*pose),
|
||||||
timestamp: Cell::new(0.0),
|
timestamp: Cell::new(0.0),
|
||||||
first_timestamp: Cell::new(0.0)
|
first_timestamp: Cell::new(0.0)
|
||||||
};
|
}
|
||||||
|
}
|
||||||
|
|
||||||
let root = reflect_dom_object(box framedata,
|
#[allow(unsafe_code)]
|
||||||
|
fn new(global: &GlobalScope) -> Root<VRFrameData> {
|
||||||
|
let matrix = [1.0, 0.0, 0.0, 0.0,
|
||||||
|
0.0, 1.0, 0.0, 0.0,
|
||||||
|
0.0, 0.0, 1.0, 0.0,
|
||||||
|
0.0, 0.0, 0.0, 1.0f32];
|
||||||
|
let pose = VRPose::new(&global, &Default::default());
|
||||||
|
|
||||||
|
let root = reflect_dom_object(box VRFrameData::new_inherited(&pose),
|
||||||
global,
|
global,
|
||||||
VRFrameDataBinding::Wrap);
|
VRFrameDataBinding::Wrap);
|
||||||
|
let cx = global.get_cx();
|
||||||
unsafe {
|
create_typed_array(cx, &matrix, &root.left_proj);
|
||||||
let ref framedata = *root;
|
create_typed_array(cx, &matrix, &root.left_view);
|
||||||
let _ = Float32Array::create(global.get_cx(), CreateWith::Slice(&matrix),
|
create_typed_array(cx, &matrix, &root.right_proj);
|
||||||
framedata.left_proj.handle_mut());
|
create_typed_array(cx, &matrix, &root.right_view);
|
||||||
let _ = Float32Array::create(global.get_cx(), CreateWith::Slice(&matrix),
|
|
||||||
framedata.left_view.handle_mut());
|
|
||||||
let _ = Float32Array::create(global.get_cx(), CreateWith::Slice(&matrix),
|
|
||||||
framedata.right_proj.handle_mut());
|
|
||||||
let _ = Float32Array::create(global.get_cx(), CreateWith::Slice(&matrix),
|
|
||||||
framedata.right_view.handle_mut());
|
|
||||||
}
|
|
||||||
|
|
||||||
root
|
root
|
||||||
}
|
}
|
||||||
|
@ -76,6 +70,13 @@ impl VRFrameData {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#[allow(unsafe_code)]
|
||||||
|
fn create_typed_array(cx: *mut JSContext, src: &[f32], dst: &Heap<*mut JSObject>) {
|
||||||
|
unsafe {
|
||||||
|
let _ = Float32Array::create(cx, CreateWith::Slice(src), dst.handle_mut());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl VRFrameData {
|
impl VRFrameData {
|
||||||
#[allow(unsafe_code)]
|
#[allow(unsafe_code)]
|
||||||
pub fn update(&self, data: &WebVRFrameData) {
|
pub fn update(&self, data: &WebVRFrameData) {
|
||||||
|
|
|
@ -32,9 +32,7 @@ unsafe fn update_or_create_typed_array(cx: *mut JSContext,
|
||||||
match src {
|
match src {
|
||||||
Some(data) => {
|
Some(data) => {
|
||||||
if dst.get().is_null() {
|
if dst.get().is_null() {
|
||||||
rooted!(in (cx) let mut array = ptr::null_mut());
|
let _ = Float32Array::create(cx, CreateWith::Slice(data), dst.handle_mut());
|
||||||
let _ = Float32Array::create(cx, CreateWith::Slice(data), array.handle_mut());
|
|
||||||
(*dst).set(array.get());
|
|
||||||
} else {
|
} else {
|
||||||
typedarray!(in(cx) let array: Float32Array = dst.get());
|
typedarray!(in(cx) let array: Float32Array = dst.get());
|
||||||
if let Ok(mut array) = array {
|
if let Ok(mut array) = array {
|
||||||
|
|
|
@ -26,28 +26,28 @@ pub struct VRStageParameters {
|
||||||
unsafe_no_jsmanaged_fields!(WebVRStageParameters);
|
unsafe_no_jsmanaged_fields!(WebVRStageParameters);
|
||||||
|
|
||||||
impl VRStageParameters {
|
impl VRStageParameters {
|
||||||
#[allow(unsafe_code)]
|
fn new_inherited(parameters: WebVRStageParameters) -> VRStageParameters {
|
||||||
#[allow(unrooted_must_root)]
|
VRStageParameters {
|
||||||
fn new_inherited(parameters: WebVRStageParameters, global: &GlobalScope) -> VRStageParameters {
|
|
||||||
let stage = VRStageParameters {
|
|
||||||
reflector_: Reflector::new(),
|
reflector_: Reflector::new(),
|
||||||
parameters: DOMRefCell::new(parameters),
|
parameters: DOMRefCell::new(parameters),
|
||||||
transform: Heap::default()
|
transform: Heap::default()
|
||||||
};
|
}
|
||||||
// XXX unsound!
|
|
||||||
unsafe {
|
|
||||||
let _ = Float32Array::create(global.get_cx(),
|
|
||||||
CreateWith::Slice(&stage.parameters.borrow().sitting_to_standing_transform),
|
|
||||||
stage.transform.handle_mut());
|
|
||||||
}
|
|
||||||
|
|
||||||
stage
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[allow(unsafe_code)]
|
||||||
pub fn new(parameters: WebVRStageParameters, global: &GlobalScope) -> Root<VRStageParameters> {
|
pub fn new(parameters: WebVRStageParameters, global: &GlobalScope) -> Root<VRStageParameters> {
|
||||||
reflect_dom_object(box VRStageParameters::new_inherited(parameters, global),
|
let cx = global.get_cx();
|
||||||
|
let stage_parameters = reflect_dom_object(box VRStageParameters::new_inherited(parameters),
|
||||||
global,
|
global,
|
||||||
VRStageParametersBinding::Wrap)
|
VRStageParametersBinding::Wrap);
|
||||||
|
unsafe {
|
||||||
|
let source = &stage_parameters.parameters.borrow().sitting_to_standing_transform;
|
||||||
|
let _ = Float32Array::create(cx,
|
||||||
|
CreateWith::Slice(source),
|
||||||
|
stage_parameters.transform.handle_mut());
|
||||||
|
}
|
||||||
|
|
||||||
|
stage_parameters
|
||||||
}
|
}
|
||||||
|
|
||||||
#[allow(unsafe_code)]
|
#[allow(unsafe_code)]
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue