Move convert_label to Into implementation (#33348)

Signed-off-by: Taym <haddadi.taym@gmail.com>
This commit is contained in:
Taym Haddadi 2024-09-06 23:58:13 +02:00 committed by GitHub
parent bc04f94a30
commit 152e62022a
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
11 changed files with 23 additions and 31 deletions

View file

@ -17,7 +17,6 @@ use crate::dom::bindings::root::{Dom, DomRoot};
use crate::dom::bindings::str::USVString; use crate::dom::bindings::str::USVString;
use crate::dom::globalscope::GlobalScope; use crate::dom::globalscope::GlobalScope;
use crate::dom::gpubindgrouplayout::GPUBindGroupLayout; use crate::dom::gpubindgrouplayout::GPUBindGroupLayout;
use crate::dom::gpuconvert::convert_label;
use crate::dom::gpudevice::GPUDevice; use crate::dom::gpudevice::GPUDevice;
#[dom_struct] #[dom_struct]
@ -86,7 +85,7 @@ impl GPUBindGroup {
.collect::<Vec<_>>(); .collect::<Vec<_>>();
let desc = BindGroupDescriptor { let desc = BindGroupDescriptor {
label: convert_label(&descriptor.parent), label: (&descriptor.parent).into(),
layout: descriptor.layout.id().0, layout: descriptor.layout.id().0,
entries: Cow::Owned(entries), entries: Cow::Owned(entries),
}; };

View file

@ -17,7 +17,7 @@ use crate::dom::bindings::reflector::{reflect_dom_object, DomObject, Reflector};
use crate::dom::bindings::root::DomRoot; use crate::dom::bindings::root::DomRoot;
use crate::dom::bindings::str::USVString; use crate::dom::bindings::str::USVString;
use crate::dom::globalscope::GlobalScope; use crate::dom::globalscope::GlobalScope;
use crate::dom::gpuconvert::{convert_bind_group_layout_entry, convert_label}; use crate::dom::gpuconvert::convert_bind_group_layout_entry;
use crate::dom::gpudevice::GPUDevice; use crate::dom::gpudevice::GPUDevice;
#[dom_struct] #[dom_struct]
@ -80,7 +80,7 @@ impl GPUBindGroupLayout {
let desc = match entries { let desc = match entries {
Ok(entries) => Some(BindGroupLayoutDescriptor { Ok(entries) => Some(BindGroupLayoutDescriptor {
label: convert_label(&descriptor.parent), label: (&descriptor.parent).into(),
entries: Cow::Owned(entries), entries: Cow::Owned(entries),
}), }),
Err(error) => { Err(error) => {

View file

@ -16,7 +16,6 @@ use super::bindings::buffer_source::DataBlock;
use super::bindings::codegen::Bindings::WebGPUBinding::{ use super::bindings::codegen::Bindings::WebGPUBinding::{
GPUBufferDescriptor, GPUBufferMapState, GPUFlagsConstant, GPUMapModeFlags, GPUBufferDescriptor, GPUBufferMapState, GPUFlagsConstant, GPUMapModeFlags,
}; };
use super::gpuconvert::convert_label;
use crate::dom::bindings::cell::DomRefCell; use crate::dom::bindings::cell::DomRefCell;
use crate::dom::bindings::codegen::Bindings::WebGPUBinding::{ use crate::dom::bindings::codegen::Bindings::WebGPUBinding::{
GPUBufferMethods, GPUMapModeConstants, GPUSize64, GPUBufferMethods, GPUMapModeConstants, GPUSize64,
@ -138,7 +137,7 @@ impl GPUBuffer {
descriptor: &GPUBufferDescriptor, descriptor: &GPUBufferDescriptor,
) -> Fallible<DomRoot<GPUBuffer>> { ) -> Fallible<DomRoot<GPUBuffer>> {
let desc = wgt::BufferDescriptor { let desc = wgt::BufferDescriptor {
label: convert_label(&descriptor.parent), label: (&descriptor.parent).into(),
size: descriptor.size as wgt::BufferAddress, size: descriptor.size as wgt::BufferAddress,
usage: wgt::BufferUsages::from_bits_retain(descriptor.usage), usage: wgt::BufferUsages::from_bits_retain(descriptor.usage),
mapped_at_creation: descriptor.mappedAtCreation, mapped_at_creation: descriptor.mappedAtCreation,

View file

@ -10,7 +10,6 @@ use webgpu::{
}; };
use super::bindings::error::Fallible; use super::bindings::error::Fallible;
use super::gpuconvert::convert_label;
use crate::dom::bindings::cell::DomRefCell; use crate::dom::bindings::cell::DomRefCell;
use crate::dom::bindings::codegen::Bindings::WebGPUBinding::{ use crate::dom::bindings::codegen::Bindings::WebGPUBinding::{
GPUCommandBufferDescriptor, GPUCommandEncoderDescriptor, GPUCommandEncoderMethods, GPUCommandBufferDescriptor, GPUCommandEncoderDescriptor, GPUCommandEncoderMethods,
@ -97,7 +96,7 @@ impl GPUCommandEncoder {
device_id: device.id().0, device_id: device.id().0,
command_encoder_id, command_encoder_id,
desc: wgt::CommandEncoderDescriptor { desc: wgt::CommandEncoderDescriptor {
label: convert_label(&descriptor.parent), label: (&descriptor.parent).into(),
}, },
}) })
.expect("Failed to create WebGPU command encoder"); .expect("Failed to create WebGPU command encoder");
@ -138,7 +137,7 @@ impl GPUCommandEncoderMethods for GPUCommandEncoder {
if let Err(e) = self.channel.0.send(WebGPURequest::BeginComputePass { if let Err(e) = self.channel.0.send(WebGPURequest::BeginComputePass {
command_encoder_id: self.id().0, command_encoder_id: self.id().0,
compute_pass_id, compute_pass_id,
label: convert_label(&descriptor.parent), label: (&descriptor.parent).into(),
device_id: self.device.id().0, device_id: self.device.id().0,
}) { }) {
warn!("Failed to send WebGPURequest::BeginComputePass {e:?}"); warn!("Failed to send WebGPURequest::BeginComputePass {e:?}");
@ -206,7 +205,7 @@ impl GPUCommandEncoderMethods for GPUCommandEncoder {
if let Err(e) = self.channel.0.send(WebGPURequest::BeginRenderPass { if let Err(e) = self.channel.0.send(WebGPURequest::BeginRenderPass {
command_encoder_id: self.id().0, command_encoder_id: self.id().0,
render_pass_id, render_pass_id,
label: convert_label(&descriptor.parent), label: (&descriptor.parent).into(),
depth_stencil_attachment, depth_stencil_attachment,
color_attachments, color_attachments,
device_id: self.device.id().0, device_id: self.device.id().0,
@ -313,7 +312,7 @@ impl GPUCommandEncoderMethods for GPUCommandEncoder {
command_encoder_id: self.encoder.0, command_encoder_id: self.encoder.0,
device_id: self.device.id().0, device_id: self.device.id().0,
desc: wgt::CommandBufferDescriptor { desc: wgt::CommandBufferDescriptor {
label: convert_label(&descriptor.parent), label: (&descriptor.parent).into(),
}, },
}) })
.expect("Failed to send Finish"); .expect("Failed to send Finish");

View file

@ -17,7 +17,6 @@ use crate::dom::bindings::root::{Dom, DomRoot};
use crate::dom::bindings::str::USVString; use crate::dom::bindings::str::USVString;
use crate::dom::globalscope::GlobalScope; use crate::dom::globalscope::GlobalScope;
use crate::dom::gpubindgrouplayout::GPUBindGroupLayout; use crate::dom::gpubindgrouplayout::GPUBindGroupLayout;
use crate::dom::gpuconvert::convert_label;
use crate::dom::gpudevice::GPUDevice; use crate::dom::gpudevice::GPUDevice;
#[dom_struct] #[dom_struct]
@ -83,7 +82,7 @@ impl GPUComputePipeline {
let (layout, implicit_ids, _) = device.get_pipeline_layout_data(&descriptor.parent.layout); let (layout, implicit_ids, _) = device.get_pipeline_layout_data(&descriptor.parent.layout);
let desc = ComputePipelineDescriptor { let desc = ComputePipelineDescriptor {
label: convert_label(&descriptor.parent.parent), label: (&descriptor.parent.parent).into(),
layout, layout,
stage: (&descriptor.compute).into(), stage: (&descriptor.compute).into(),
cache: None, cache: None,

View file

@ -497,14 +497,15 @@ impl TryFrom<&GPUImageCopyTexture> for wgpu_com::ImageCopyTexture {
} }
} }
pub fn convert_label<'a>(parent: &GPUObjectDescriptorBase) -> Option<Cow<'a, str>> { impl<'a> Into<Option<Cow<'a, str>>> for &GPUObjectDescriptorBase {
if parent.label.is_empty() { fn into(self) -> Option<Cow<'a, str>> {
None if self.label.is_empty() {
} else { None
Some(Cow::Owned(parent.label.to_string())) } else {
Some(Cow::Owned(self.label.to_string()))
}
} }
} }
pub fn convert_bind_group_layout_entry( pub fn convert_bind_group_layout_entry(
bgle: &GPUBindGroupLayoutEntry, bgle: &GPUBindGroupLayoutEntry,
device: &GPUDevice, device: &GPUDevice,

View file

@ -52,7 +52,6 @@ use crate::dom::gpubindgrouplayout::GPUBindGroupLayout;
use crate::dom::gpubuffer::GPUBuffer; use crate::dom::gpubuffer::GPUBuffer;
use crate::dom::gpucommandencoder::GPUCommandEncoder; use crate::dom::gpucommandencoder::GPUCommandEncoder;
use crate::dom::gpucomputepipeline::GPUComputePipeline; use crate::dom::gpucomputepipeline::GPUComputePipeline;
use crate::dom::gpuconvert::convert_label;
use crate::dom::gpupipelinelayout::GPUPipelineLayout; use crate::dom::gpupipelinelayout::GPUPipelineLayout;
use crate::dom::gpuqueue::GPUQueue; use crate::dom::gpuqueue::GPUQueue;
use crate::dom::gpurenderbundleencoder::GPURenderBundleEncoder; use crate::dom::gpurenderbundleencoder::GPURenderBundleEncoder;
@ -246,7 +245,7 @@ impl GPUDevice {
let (layout, implicit_ids, _) = self.get_pipeline_layout_data(&descriptor.parent.layout); let (layout, implicit_ids, _) = self.get_pipeline_layout_data(&descriptor.parent.layout);
let desc = wgpu_pipe::RenderPipelineDescriptor { let desc = wgpu_pipe::RenderPipelineDescriptor {
label: convert_label(&descriptor.parent.parent), label: (&descriptor.parent.parent).into(),
layout, layout,
cache: None, cache: None,
vertex: wgpu_pipe::VertexState { vertex: wgpu_pipe::VertexState {

View file

@ -16,7 +16,6 @@ use crate::dom::bindings::reflector::{reflect_dom_object, DomObject, Reflector};
use crate::dom::bindings::root::DomRoot; use crate::dom::bindings::root::DomRoot;
use crate::dom::bindings::str::USVString; use crate::dom::bindings::str::USVString;
use crate::dom::globalscope::GlobalScope; use crate::dom::globalscope::GlobalScope;
use crate::dom::gpuconvert::convert_label;
use crate::dom::gpudevice::GPUDevice; use crate::dom::gpudevice::GPUDevice;
#[dom_struct] #[dom_struct]
@ -88,7 +87,7 @@ impl GPUPipelineLayout {
.collect::<Vec<_>>(); .collect::<Vec<_>>();
let desc = PipelineLayoutDescriptor { let desc = PipelineLayoutDescriptor {
label: convert_label(&descriptor.parent), label: (&descriptor.parent).into(),
bind_group_layouts: Cow::Owned(bgls.iter().map(|l| l.0).collect::<Vec<_>>()), bind_group_layouts: Cow::Owned(bgls.iter().map(|l| l.0).collect::<Vec<_>>()),
push_constant_ranges: Cow::Owned(vec![]), push_constant_ranges: Cow::Owned(vec![]),
}; };

View file

@ -22,7 +22,6 @@ use crate::dom::bindings::str::USVString;
use crate::dom::globalscope::GlobalScope; use crate::dom::globalscope::GlobalScope;
use crate::dom::gpubindgroup::GPUBindGroup; use crate::dom::gpubindgroup::GPUBindGroup;
use crate::dom::gpubuffer::GPUBuffer; use crate::dom::gpubuffer::GPUBuffer;
use crate::dom::gpuconvert::convert_label;
use crate::dom::gpudevice::GPUDevice; use crate::dom::gpudevice::GPUDevice;
use crate::dom::gpurenderbundle::GPURenderBundle; use crate::dom::gpurenderbundle::GPURenderBundle;
use crate::dom::gpurenderpipeline::GPURenderPipeline; use crate::dom::gpurenderpipeline::GPURenderPipeline;
@ -82,7 +81,7 @@ impl GPURenderBundleEncoder {
descriptor: &GPURenderBundleEncoderDescriptor, descriptor: &GPURenderBundleEncoderDescriptor,
) -> Fallible<DomRoot<GPURenderBundleEncoder>> { ) -> Fallible<DomRoot<GPURenderBundleEncoder>> {
let desc = RenderBundleEncoderDescriptor { let desc = RenderBundleEncoderDescriptor {
label: convert_label(&descriptor.parent.parent), label: (&descriptor.parent.parent).into(),
color_formats: Cow::Owned( color_formats: Cow::Owned(
descriptor descriptor
.parent .parent
@ -253,7 +252,7 @@ impl GPURenderBundleEncoderMethods for GPURenderBundleEncoder {
/// <https://gpuweb.github.io/gpuweb/#dom-gpurenderbundleencoder-finish> /// <https://gpuweb.github.io/gpuweb/#dom-gpurenderbundleencoder-finish>
fn Finish(&self, descriptor: &GPURenderBundleDescriptor) -> DomRoot<GPURenderBundle> { fn Finish(&self, descriptor: &GPURenderBundleDescriptor) -> DomRoot<GPURenderBundle> {
let desc = wgt::RenderBundleDescriptor { let desc = wgt::RenderBundleDescriptor {
label: convert_label(&descriptor.parent), label: (&descriptor.parent).into(),
}; };
let encoder = self.render_bundle_encoder.borrow_mut().take().unwrap(); let encoder = self.render_bundle_encoder.borrow_mut().take().unwrap();
let render_bundle_id = self let render_bundle_id = self

View file

@ -14,7 +14,6 @@ use crate::dom::bindings::reflector::{reflect_dom_object, DomObject, Reflector};
use crate::dom::bindings::root::DomRoot; use crate::dom::bindings::root::DomRoot;
use crate::dom::bindings::str::USVString; use crate::dom::bindings::str::USVString;
use crate::dom::globalscope::GlobalScope; use crate::dom::globalscope::GlobalScope;
use crate::dom::gpuconvert::convert_label;
use crate::dom::gpudevice::GPUDevice; use crate::dom::gpudevice::GPUDevice;
#[dom_struct] #[dom_struct]
@ -83,7 +82,7 @@ impl GPUSampler {
.create_sampler_id(device.id().0.backend()); .create_sampler_id(device.id().0.backend());
let compare_enable = descriptor.compare.is_some(); let compare_enable = descriptor.compare.is_some();
let desc = SamplerDescriptor { let desc = SamplerDescriptor {
label: convert_label(&descriptor.parent), label: (&descriptor.parent).into(),
address_modes: [ address_modes: [
descriptor.addressModeU.into(), descriptor.addressModeU.into(),
descriptor.addressModeV.into(), descriptor.addressModeV.into(),

View file

@ -19,7 +19,6 @@ use crate::dom::bindings::reflector::{reflect_dom_object, DomObject, Reflector};
use crate::dom::bindings::root::{Dom, DomRoot}; use crate::dom::bindings::root::{Dom, DomRoot};
use crate::dom::bindings::str::USVString; use crate::dom::bindings::str::USVString;
use crate::dom::globalscope::GlobalScope; use crate::dom::globalscope::GlobalScope;
use crate::dom::gpuconvert::convert_label;
use crate::dom::gpudevice::GPUDevice; use crate::dom::gpudevice::GPUDevice;
use crate::dom::gputextureview::GPUTextureView; use crate::dom::gputextureview::GPUTextureView;
@ -136,7 +135,7 @@ impl GPUTexture {
) -> Fallible<DomRoot<GPUTexture>> { ) -> Fallible<DomRoot<GPUTexture>> {
let size = (&descriptor.size).try_into()?; let size = (&descriptor.size).try_into()?;
let desc = wgt::TextureDescriptor { let desc = wgt::TextureDescriptor {
label: convert_label(&descriptor.parent), label: (&descriptor.parent).into(),
size, size,
mip_level_count: descriptor.mipLevelCount, mip_level_count: descriptor.mipLevelCount,
sample_count: descriptor.sampleCount, sample_count: descriptor.sampleCount,
@ -203,7 +202,7 @@ impl GPUTextureMethods for GPUTexture {
!matches!(descriptor.arrayLayerCount, Some(0)) !matches!(descriptor.arrayLayerCount, Some(0))
{ {
Some(resource::TextureViewDescriptor { Some(resource::TextureViewDescriptor {
label: convert_label(&descriptor.parent), label: (&descriptor.parent).into(),
format: descriptor format: descriptor
.format .format
.map(|f| self.device.validate_texture_format_required_features(&f)) .map(|f| self.device.validate_texture_format_required_features(&f))