<!-- Please describe your changes on the following line: --> This PR allows different `Window` objects in the same browsing context to share a `BrowsingContext` object. SpiderMonkey requires a `WindowProxy` object to be in the same compartment as its `Window`, so when a `WindowProxy` changes `Window`, we have to brain-transplant it. In turn this requires the reflector of a `BrowsingContext` to be mutable. --- <!-- Thank you for contributing to Servo! Please replace each `[ ]` by `[X]` when the step is complete, and replace `__` with appropriate data: --> - [X] `./mach build -d` does not report any errors - [X] `./mach test-tidy` does not report any errors - [X] These changes fix #13608 and #14843 - [X] These changes do not require tests because an existing test catches this (`/html/browsers/the-window-object/Window-document.html` is now `PASS`) <!-- Pull requests that do not address these steps are welcome, but they will require additional verification as part of the review process. --> Source-Repo: https://github.com/servo/servo Source-Revision: 67c182638253211553161495cd2e4570002fd5bc
84 lines
2.6 KiB
Rust
84 lines
2.6 KiB
Rust
/* 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/. */
|
|
|
|
use core::nonzero::NonZero;
|
|
use dom::bindings::codegen::Bindings::ImageDataBinding;
|
|
use dom::bindings::codegen::Bindings::ImageDataBinding::ImageDataMethods;
|
|
use dom::bindings::js::Root;
|
|
use dom::bindings::reflector::{Reflector, reflect_dom_object};
|
|
use dom::globalscope::GlobalScope;
|
|
use euclid::size::Size2D;
|
|
use js::jsapi::{Heap, JSContext, JSObject};
|
|
use js::rust::Runtime;
|
|
use js::typedarray::Uint8ClampedArray;
|
|
use std::default::Default;
|
|
use std::ptr;
|
|
use std::vec::Vec;
|
|
|
|
#[dom_struct]
|
|
pub struct ImageData {
|
|
reflector_: Reflector,
|
|
width: u32,
|
|
height: u32,
|
|
data: Heap<*mut JSObject>,
|
|
}
|
|
|
|
impl ImageData {
|
|
#[allow(unsafe_code)]
|
|
pub fn new(global: &GlobalScope, width: u32, height: u32, data: Option<Vec<u8>>) -> Root<ImageData> {
|
|
let imagedata = box ImageData {
|
|
reflector_: Reflector::new(),
|
|
width: width,
|
|
height: height,
|
|
data: Heap::default(),
|
|
};
|
|
|
|
unsafe {
|
|
let cx = global.get_cx();
|
|
rooted!(in (cx) let mut js_object = ptr::null_mut());
|
|
let data = data.as_ref().map(|d| &d[..]);
|
|
Uint8ClampedArray::create(cx, width * height * 4, data, js_object.handle_mut()).unwrap();
|
|
(*imagedata).data.set(js_object.get());
|
|
}
|
|
|
|
reflect_dom_object(imagedata,
|
|
global, ImageDataBinding::Wrap)
|
|
}
|
|
|
|
#[allow(unsafe_code)]
|
|
pub fn get_data_array(&self) -> Vec<u8> {
|
|
unsafe {
|
|
assert!(!self.data.get().is_null());
|
|
let cx = Runtime::get();
|
|
assert!(!cx.is_null());
|
|
typedarray!(in(cx) let array: Uint8ClampedArray = self.data.get());
|
|
let vec = array.unwrap().as_slice().to_vec();
|
|
vec
|
|
}
|
|
}
|
|
|
|
pub fn get_size(&self) -> Size2D<i32> {
|
|
Size2D::new(self.Width() as i32, self.Height() as i32)
|
|
}
|
|
}
|
|
|
|
impl ImageDataMethods for ImageData {
|
|
// https://html.spec.whatwg.org/multipage/#dom-imagedata-width
|
|
fn Width(&self) -> u32 {
|
|
self.width
|
|
}
|
|
|
|
// https://html.spec.whatwg.org/multipage/#dom-imagedata-height
|
|
fn Height(&self) -> u32 {
|
|
self.height
|
|
}
|
|
|
|
#[allow(unsafe_code)]
|
|
// https://html.spec.whatwg.org/multipage/#dom-imagedata-data
|
|
unsafe fn Data(&self, _: *mut JSContext) -> NonZero<*mut JSObject> {
|
|
assert!(!self.data.get().is_null());
|
|
NonZero::new(self.data.get())
|
|
}
|
|
}
|