mirror of
https://github.com/servo/servo.git
synced 2025-06-06 16:45:39 +00:00
This fixes many rustdoc errors that occur due to raw URLs in rustdoc comments as well as unescaped Rust code that should be in backticks.
298 lines
10 KiB
Rust
298 lines
10 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 https://mozilla.org/MPL/2.0/. */
|
|
|
|
use dom_struct::dom_struct;
|
|
use webgpu::wgpu::command::{render_ffi as wgpu_render, RenderPass};
|
|
use webgpu::{wgt, WebGPU, WebGPURequest};
|
|
|
|
use super::bindings::codegen::Bindings::WebGPUBinding::GPUIndexFormat;
|
|
use super::bindings::error::Fallible;
|
|
use crate::dom::bindings::cell::DomRefCell;
|
|
use crate::dom::bindings::codegen::Bindings::WebGPUBinding::{
|
|
GPUColor, GPURenderPassEncoderMethods,
|
|
};
|
|
use crate::dom::bindings::num::Finite;
|
|
use crate::dom::bindings::reflector::{reflect_dom_object, Reflector};
|
|
use crate::dom::bindings::root::{Dom, DomRoot};
|
|
use crate::dom::bindings::str::USVString;
|
|
use crate::dom::globalscope::GlobalScope;
|
|
use crate::dom::gpubindgroup::GPUBindGroup;
|
|
use crate::dom::gpubuffer::GPUBuffer;
|
|
use crate::dom::gpucommandencoder::{GPUCommandEncoder, GPUCommandEncoderState};
|
|
use crate::dom::gpurenderbundle::GPURenderBundle;
|
|
use crate::dom::gpurenderpipeline::GPURenderPipeline;
|
|
|
|
#[dom_struct]
|
|
pub struct GPURenderPassEncoder {
|
|
reflector_: Reflector,
|
|
#[ignore_malloc_size_of = "defined in webgpu"]
|
|
#[no_trace]
|
|
channel: WebGPU,
|
|
label: DomRefCell<USVString>,
|
|
#[ignore_malloc_size_of = "defined in wgpu-core"]
|
|
#[no_trace]
|
|
render_pass: DomRefCell<Option<RenderPass>>,
|
|
command_encoder: Dom<GPUCommandEncoder>,
|
|
}
|
|
|
|
impl GPURenderPassEncoder {
|
|
fn new_inherited(
|
|
channel: WebGPU,
|
|
render_pass: Option<RenderPass>,
|
|
parent: &GPUCommandEncoder,
|
|
label: USVString,
|
|
) -> Self {
|
|
Self {
|
|
channel,
|
|
reflector_: Reflector::new(),
|
|
label: DomRefCell::new(label),
|
|
render_pass: DomRefCell::new(render_pass),
|
|
command_encoder: Dom::from_ref(parent),
|
|
}
|
|
}
|
|
|
|
pub fn new(
|
|
global: &GlobalScope,
|
|
channel: WebGPU,
|
|
render_pass: Option<RenderPass>,
|
|
parent: &GPUCommandEncoder,
|
|
label: USVString,
|
|
) -> DomRoot<Self> {
|
|
reflect_dom_object(
|
|
Box::new(GPURenderPassEncoder::new_inherited(
|
|
channel,
|
|
render_pass,
|
|
parent,
|
|
label,
|
|
)),
|
|
global,
|
|
)
|
|
}
|
|
}
|
|
|
|
impl GPURenderPassEncoderMethods for GPURenderPassEncoder {
|
|
/// <https://gpuweb.github.io/gpuweb/#dom-gpuobjectbase-label>
|
|
fn Label(&self) -> USVString {
|
|
self.label.borrow().clone()
|
|
}
|
|
|
|
/// <https://gpuweb.github.io/gpuweb/#dom-gpuobjectbase-label>
|
|
fn SetLabel(&self, value: USVString) {
|
|
*self.label.borrow_mut() = value;
|
|
}
|
|
|
|
/// <https://gpuweb.github.io/gpuweb/#dom-gpuprogrammablepassencoder-setbindgroup>
|
|
#[allow(unsafe_code)]
|
|
fn SetBindGroup(&self, index: u32, bind_group: &GPUBindGroup, dynamic_offsets: Vec<u32>) {
|
|
if let Some(render_pass) = self.render_pass.borrow_mut().as_mut() {
|
|
unsafe {
|
|
wgpu_render::wgpu_render_pass_set_bind_group(
|
|
render_pass,
|
|
index,
|
|
bind_group.id().0,
|
|
dynamic_offsets.as_ptr(),
|
|
dynamic_offsets.len(),
|
|
)
|
|
};
|
|
}
|
|
}
|
|
|
|
/// <https://gpuweb.github.io/gpuweb/#dom-gpurenderpassencoder-setviewport>
|
|
fn SetViewport(
|
|
&self,
|
|
x: Finite<f32>,
|
|
y: Finite<f32>,
|
|
width: Finite<f32>,
|
|
height: Finite<f32>,
|
|
min_depth: Finite<f32>,
|
|
max_depth: Finite<f32>,
|
|
) {
|
|
if let Some(render_pass) = self.render_pass.borrow_mut().as_mut() {
|
|
wgpu_render::wgpu_render_pass_set_viewport(
|
|
render_pass,
|
|
*x,
|
|
*y,
|
|
*width,
|
|
*height,
|
|
*min_depth,
|
|
*max_depth,
|
|
);
|
|
}
|
|
}
|
|
|
|
/// <https://gpuweb.github.io/gpuweb/#dom-gpurenderpassencoder-setscissorrect>
|
|
fn SetScissorRect(&self, x: u32, y: u32, width: u32, height: u32) {
|
|
if let Some(render_pass) = self.render_pass.borrow_mut().as_mut() {
|
|
wgpu_render::wgpu_render_pass_set_scissor_rect(render_pass, x, y, width, height);
|
|
}
|
|
}
|
|
|
|
/// <https://gpuweb.github.io/gpuweb/#dom-gpurenderpassencoder-setblendcolor>
|
|
fn SetBlendConstant(&self, color: GPUColor) {
|
|
if let Some(render_pass) = self.render_pass.borrow_mut().as_mut() {
|
|
let colors = match color {
|
|
GPUColor::GPUColorDict(d) => wgt::Color {
|
|
r: *d.r,
|
|
g: *d.g,
|
|
b: *d.b,
|
|
a: *d.a,
|
|
},
|
|
GPUColor::DoubleSequence(mut s) => {
|
|
if s.len() < 3 {
|
|
s.resize(3, Finite::wrap(0.0f64));
|
|
}
|
|
s.resize(4, Finite::wrap(1.0f64));
|
|
wgt::Color {
|
|
r: *s[0],
|
|
g: *s[1],
|
|
b: *s[2],
|
|
a: *s[3],
|
|
}
|
|
},
|
|
};
|
|
wgpu_render::wgpu_render_pass_set_blend_constant(render_pass, &colors);
|
|
}
|
|
}
|
|
|
|
/// <https://gpuweb.github.io/gpuweb/#dom-gpurenderpassencoder-setstencilreference>
|
|
fn SetStencilReference(&self, reference: u32) {
|
|
if let Some(render_pass) = self.render_pass.borrow_mut().as_mut() {
|
|
wgpu_render::wgpu_render_pass_set_stencil_reference(render_pass, reference);
|
|
}
|
|
}
|
|
|
|
/// <https://gpuweb.github.io/gpuweb/#dom-gpurenderpassencoder-end>
|
|
fn End(&self) -> Fallible<()> {
|
|
let render_pass = self.render_pass.borrow_mut().take();
|
|
self.channel
|
|
.0
|
|
.send((
|
|
None,
|
|
WebGPURequest::RunRenderPass {
|
|
command_encoder_id: self.command_encoder.id().0,
|
|
render_pass,
|
|
},
|
|
))
|
|
.expect("Failed to send RunRenderPass");
|
|
|
|
self.command_encoder.set_state(
|
|
GPUCommandEncoderState::Open,
|
|
GPUCommandEncoderState::EncodingRenderPass,
|
|
);
|
|
Ok(())
|
|
}
|
|
|
|
/// <https://gpuweb.github.io/gpuweb/#dom-gpurenderencoderbase-setpipeline>
|
|
fn SetPipeline(&self, pipeline: &GPURenderPipeline) {
|
|
if let Some(render_pass) = self.render_pass.borrow_mut().as_mut() {
|
|
wgpu_render::wgpu_render_pass_set_pipeline(render_pass, pipeline.id().0);
|
|
}
|
|
}
|
|
|
|
/// <https://gpuweb.github.io/gpuweb/#dom-gpurendercommandsmixin-setindexbuffer>
|
|
fn SetIndexBuffer(
|
|
&self,
|
|
buffer: &GPUBuffer,
|
|
index_format: GPUIndexFormat,
|
|
offset: u64,
|
|
size: u64,
|
|
) {
|
|
if let Some(render_pass) = self.render_pass.borrow_mut().as_mut() {
|
|
wgpu_render::wgpu_render_pass_set_index_buffer(
|
|
render_pass,
|
|
buffer.id().0,
|
|
match index_format {
|
|
GPUIndexFormat::Uint16 => wgt::IndexFormat::Uint16,
|
|
GPUIndexFormat::Uint32 => wgt::IndexFormat::Uint32,
|
|
},
|
|
offset,
|
|
wgt::BufferSize::new(size),
|
|
);
|
|
}
|
|
}
|
|
|
|
/// <https://gpuweb.github.io/gpuweb/#dom-gpurenderencoderbase-setvertexbuffer>
|
|
fn SetVertexBuffer(&self, slot: u32, buffer: &GPUBuffer, offset: u64, size: u64) {
|
|
if let Some(render_pass) = self.render_pass.borrow_mut().as_mut() {
|
|
wgpu_render::wgpu_render_pass_set_vertex_buffer(
|
|
render_pass,
|
|
slot,
|
|
buffer.id().0,
|
|
offset,
|
|
wgt::BufferSize::new(size),
|
|
);
|
|
}
|
|
}
|
|
|
|
/// <https://gpuweb.github.io/gpuweb/#dom-gpurenderencoderbase-draw>
|
|
fn Draw(&self, vertex_count: u32, instance_count: u32, first_vertex: u32, first_instance: u32) {
|
|
if let Some(render_pass) = self.render_pass.borrow_mut().as_mut() {
|
|
wgpu_render::wgpu_render_pass_draw(
|
|
render_pass,
|
|
vertex_count,
|
|
instance_count,
|
|
first_vertex,
|
|
first_instance,
|
|
);
|
|
}
|
|
}
|
|
|
|
/// <https://gpuweb.github.io/gpuweb/#dom-gpurenderencoderbase-drawindexed>
|
|
fn DrawIndexed(
|
|
&self,
|
|
index_count: u32,
|
|
instance_count: u32,
|
|
first_index: u32,
|
|
base_vertex: i32,
|
|
first_instance: u32,
|
|
) {
|
|
if let Some(render_pass) = self.render_pass.borrow_mut().as_mut() {
|
|
wgpu_render::wgpu_render_pass_draw_indexed(
|
|
render_pass,
|
|
index_count,
|
|
instance_count,
|
|
first_index,
|
|
base_vertex,
|
|
first_instance,
|
|
);
|
|
}
|
|
}
|
|
|
|
/// <https://gpuweb.github.io/gpuweb/#dom-gpurenderencoderbase-drawindirect>
|
|
fn DrawIndirect(&self, indirect_buffer: &GPUBuffer, indirect_offset: u64) {
|
|
if let Some(render_pass) = self.render_pass.borrow_mut().as_mut() {
|
|
wgpu_render::wgpu_render_pass_draw_indirect(
|
|
render_pass,
|
|
indirect_buffer.id().0,
|
|
indirect_offset,
|
|
);
|
|
}
|
|
}
|
|
|
|
/// <https://gpuweb.github.io/gpuweb/#dom-gpurenderencoderbase-drawindexedindirect>
|
|
fn DrawIndexedIndirect(&self, indirect_buffer: &GPUBuffer, indirect_offset: u64) {
|
|
if let Some(render_pass) = self.render_pass.borrow_mut().as_mut() {
|
|
wgpu_render::wgpu_render_pass_draw_indexed_indirect(
|
|
render_pass,
|
|
indirect_buffer.id().0,
|
|
indirect_offset,
|
|
);
|
|
}
|
|
}
|
|
|
|
/// <https://gpuweb.github.io/gpuweb/#dom-gpurenderpassencoder-executebundles>
|
|
#[allow(unsafe_code)]
|
|
fn ExecuteBundles(&self, bundles: Vec<DomRoot<GPURenderBundle>>) {
|
|
let bundle_ids = bundles.iter().map(|b| b.id().0).collect::<Vec<_>>();
|
|
if let Some(render_pass) = self.render_pass.borrow_mut().as_mut() {
|
|
unsafe {
|
|
wgpu_render::wgpu_render_pass_execute_bundles(
|
|
render_pass,
|
|
bundle_ids.as_ptr(),
|
|
bundle_ids.len(),
|
|
)
|
|
};
|
|
}
|
|
}
|
|
}
|