mirror of
https://github.com/servo/servo.git
synced 2025-08-04 21:20:23 +01:00
webgpu: Move errorscopes to WGPU thread (#32304)
* Prepare errorscopes logic in wgpu_thread * remove scope_id from ipc * new GPUErrors per spec * remove cotent timeline error_scope * fixup poperrorscope types * device_scope -> gpu_error and nice errors * Handle errors detection more elegantly * good expectations * new expectations * Make error_scope.errors Vec as per spec
This commit is contained in:
parent
9f32809671
commit
794110ebe5
37 changed files with 3401 additions and 725 deletions
|
@ -5,41 +5,30 @@
|
|||
use dom_struct::dom_struct;
|
||||
use js::rust::HandleObject;
|
||||
|
||||
use super::bindings::error::Fallible;
|
||||
use crate::dom::bindings::codegen::Bindings::WebGPUBinding::GPUValidationErrorMethods;
|
||||
use crate::dom::bindings::reflector::{reflect_dom_object_with_proto, Reflector};
|
||||
use super::types::GPUError;
|
||||
use crate::dom::bindings::reflector::reflect_dom_object_with_proto;
|
||||
use crate::dom::bindings::root::DomRoot;
|
||||
use crate::dom::bindings::str::DOMString;
|
||||
use crate::dom::globalscope::GlobalScope;
|
||||
|
||||
#[dom_struct]
|
||||
pub struct GPUValidationError {
|
||||
reflector_: Reflector,
|
||||
message: DOMString,
|
||||
gpu_error: GPUError,
|
||||
}
|
||||
|
||||
impl GPUValidationError {
|
||||
fn new_inherited(message: DOMString) -> Self {
|
||||
Self {
|
||||
reflector_: Reflector::new(),
|
||||
message,
|
||||
gpu_error: GPUError::new_inherited(message),
|
||||
}
|
||||
}
|
||||
|
||||
pub fn new(global: &GlobalScope, message: DOMString) -> DomRoot<Self> {
|
||||
Self::new_with_proto(global, None, message)
|
||||
}
|
||||
|
||||
fn new_with_proto(
|
||||
pub fn new_with_proto(
|
||||
global: &GlobalScope,
|
||||
proto: Option<HandleObject>,
|
||||
message: DOMString,
|
||||
) -> DomRoot<Self> {
|
||||
reflect_dom_object_with_proto(
|
||||
Box::new(GPUValidationError::new_inherited(message)),
|
||||
global,
|
||||
proto,
|
||||
)
|
||||
reflect_dom_object_with_proto(Box::new(Self::new_inherited(message)), global, proto)
|
||||
}
|
||||
|
||||
/// <https://gpuweb.github.io/gpuweb/#dom-gpuvalidationerror-gpuvalidationerror>
|
||||
|
@ -48,14 +37,7 @@ impl GPUValidationError {
|
|||
global: &GlobalScope,
|
||||
proto: Option<HandleObject>,
|
||||
message: DOMString,
|
||||
) -> Fallible<DomRoot<Self>> {
|
||||
Ok(GPUValidationError::new_with_proto(global, proto, message))
|
||||
}
|
||||
}
|
||||
|
||||
impl GPUValidationErrorMethods for GPUValidationError {
|
||||
/// <https://gpuweb.github.io/gpuweb/#dom-gpuvalidationerror-message>
|
||||
fn Message(&self) -> DOMString {
|
||||
self.message.clone()
|
||||
) -> DomRoot<Self> {
|
||||
Self::new_with_proto(global, proto, message)
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue