Implement ImageBitmap.close (#34124)

* Implement ImageBitmap.close

Signed-off-by: Simon Wülker <simon.wuelker@arcor.de>

* Update WPT expectations

Signed-off-by: Simon Wülker <simon.wuelker@arcor.de>

---------

Signed-off-by: Simon Wülker <simon.wuelker@arcor.de>
This commit is contained in:
Simon Wülker 2024-11-04 02:09:43 +01:00 committed by GitHub
parent e93544c003
commit e5cc7ad235
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
4 changed files with 36 additions and 16 deletions

View file

@ -19,7 +19,11 @@ pub struct ImageBitmap {
reflector_: Reflector, reflector_: Reflector,
width: u32, width: u32,
height: u32, height: u32,
bitmap_data: DomRefCell<Vec<u8>>, /// The actual pixel data of the bitmap
///
/// If this is `None`, then the bitmap data has been released by calling
/// [`close`](https://html.spec.whatwg.org/multipage/#dom-imagebitmap-close)
bitmap_data: DomRefCell<Option<Vec<u8>>>,
origin_clean: Cell<bool>, origin_clean: Cell<bool>,
} }
@ -29,7 +33,7 @@ impl ImageBitmap {
reflector_: Reflector::new(), reflector_: Reflector::new(),
width: width_arg, width: width_arg,
height: height_arg, height: height_arg,
bitmap_data: DomRefCell::new(vec![]), bitmap_data: DomRefCell::new(Some(vec![])),
origin_clean: Cell::new(true), origin_clean: Cell::new(true),
} }
} }
@ -43,26 +47,48 @@ impl ImageBitmap {
} }
pub fn set_bitmap_data(&self, data: Vec<u8>) { pub fn set_bitmap_data(&self, data: Vec<u8>) {
*self.bitmap_data.borrow_mut() = data; *self.bitmap_data.borrow_mut() = Some(data);
} }
pub fn set_origin_clean(&self, origin_is_clean: bool) { pub fn set_origin_clean(&self, origin_is_clean: bool) {
self.origin_clean.set(origin_is_clean); self.origin_clean.set(origin_is_clean);
} }
/// Return the value of the [`[[Detached]]`](https://html.spec.whatwg.org/multipage/#detached)
/// internal slot
fn is_detached(&self) -> bool {
self.bitmap_data.borrow().is_none()
}
} }
impl ImageBitmapMethods for ImageBitmap { impl ImageBitmapMethods for ImageBitmap {
// https://html.spec.whatwg.org/multipage/#dom-imagebitmap-height /// <https://html.spec.whatwg.org/multipage/#dom-imagebitmap-height>
fn Height(&self) -> u32 { fn Height(&self) -> u32 {
//to do: add a condition for checking detached internal slot // Step 1. If this's [[Detached]] internal slot's value is true, then return 0.
//and return 0 if set to true if self.is_detached() {
return 0;
}
// Step 2. Return this's height, in CSS pixels.
self.height self.height
} }
// https://html.spec.whatwg.org/multipage/#dom-imagebitmap-width /// <https://html.spec.whatwg.org/multipage/#dom-imagebitmap-width>
fn Width(&self) -> u32 { fn Width(&self) -> u32 {
//to do: add a condition to check detached internal slot // Step 1. If this's [[Detached]] internal slot's value is true, then return 0.
////and return 0 if set to true if self.is_detached() {
return 0;
}
// Step 2. Return this's width, in CSS pixels.
self.width self.width
} }
/// <https://html.spec.whatwg.org/multipage/#dom-imagebitmap-close>
fn Close(&self) {
// Step 1. Set this's [[Detached]] internal slot value to true.
// Step 2. Unset this's bitmap data.
// NOTE: The existence of the bitmap data is the internal slot in our implementation
self.bitmap_data.borrow_mut().take();
}
} }

View file

@ -14,7 +14,7 @@
interface ImageBitmap { interface ImageBitmap {
readonly attribute unsigned long width; readonly attribute unsigned long width;
readonly attribute unsigned long height; readonly attribute unsigned long height;
//void close(); undefined close();
}; };
typedef (CanvasImageSource or typedef (CanvasImageSource or

View file

@ -662,9 +662,6 @@
[CanvasRenderingContext2D interface: document.createElement("canvas").getContext("2d") must inherit property "filter" with the proper type] [CanvasRenderingContext2D interface: document.createElement("canvas").getContext("2d") must inherit property "filter" with the proper type]
expected: FAIL expected: FAIL
[ImageBitmap interface: operation close()]
expected: FAIL
[DataTransfer interface: attribute files] [DataTransfer interface: attribute files]
expected: FAIL expected: FAIL

View file

@ -170,9 +170,6 @@
[WorkerGlobalScope interface: attribute ononline] [WorkerGlobalScope interface: attribute ononline]
expected: FAIL expected: FAIL
[ImageBitmap interface: operation close()]
expected: FAIL
[OffscreenCanvasRenderingContext2D interface: operation setLineDash(sequence<unrestricted double>)] [OffscreenCanvasRenderingContext2D interface: operation setLineDash(sequence<unrestricted double>)]
expected: FAIL expected: FAIL