Skip to content

Commit

Permalink
Add user-defined errors for render functions (#196)
Browse files Browse the repository at this point in the history
- Fixes #189
  • Loading branch information
parasyte authored Sep 4, 2021
1 parent 0f8b1ab commit db00a67
Show file tree
Hide file tree
Showing 4 changed files with 29 additions and 10 deletions.
2 changes: 2 additions & 0 deletions examples/custom-shader/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -60,6 +60,8 @@ fn main() -> Result<(), Error> {
time += 0.01;

noise_renderer.render(encoder, render_target, context.scaling_renderer.clip_rect());

Ok(())
});

if render_result
Expand Down
5 changes: 3 additions & 2 deletions examples/egui-winit/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -67,8 +67,9 @@ fn main() -> Result<(), Error> {
context.scaling_renderer.render(encoder, render_target);

// Render egui
gui.render(encoder, render_target, context)
.expect("egui render error");
gui.render(encoder, render_target, context)?;

Ok(())
});

// Basic error handling
Expand Down
5 changes: 3 additions & 2 deletions examples/imgui-winit/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -70,8 +70,9 @@ fn main() -> Result<(), Error> {
context.scaling_renderer.render(encoder, render_target);

// Render Dear ImGui
gui.render(&window, encoder, render_target, context)
.expect("gui.render() failed");
gui.render(&window, encoder, render_target, context)?;

Ok(())
});

// Basic error handling
Expand Down
27 changes: 21 additions & 6 deletions src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -115,6 +115,9 @@ pub enum Error {
/// Equivalent to [`wgpu::SurfaceError`]
#[error("The GPU failed to acquire a surface frame.")]
Surface(wgpu::SurfaceError),
/// User-defined error from custom render function
#[error("User-defined error.")]
UserDefined(#[from] Box<dyn std::error::Error>),
}

impl<'win, W: HasRawWindowHandle> SurfaceTexture<'win, W> {
Expand Down Expand Up @@ -296,12 +299,14 @@ impl Pixels {
/// }
///
/// // Draw it to the `SurfaceTexture`
/// pixels.render();
/// pixels.render()?;
/// # Ok::<(), pixels::Error>(())
/// ```
pub fn render(&mut self) -> Result<(), Error> {
self.render_with(|encoder, render_target, context| {
context.scaling_renderer.render(encoder, render_target);

Ok(())
})
}

Expand All @@ -312,9 +317,14 @@ impl Pixels {
/// which you can use to render to the screen, and a [`PixelsContext`] with all of the internal
/// `wgpu` context.
///
/// The render function must return a `Result`. This allows fallible render functions to be
/// handled gracefully. The boxed `Error` will be made available in the [`Error::UserDefined`]
/// variant returned by `render_with()`.
///
/// # Errors
///
/// Returns an error when [`wgpu::Surface::get_current_frame`] fails.
/// Returns an error when either [`wgpu::Surface::get_current_frame`] or the provided render
/// function fails.
///
/// # Example
///
Expand All @@ -337,12 +347,17 @@ impl Pixels {
/// pixels.render_with(|encoder, render_target, context| {
/// context.scaling_renderer.render(encoder, render_target);
/// // etc...
/// });
/// Ok(())
/// })?;
/// # Ok::<(), pixels::Error>(())
/// ```
pub fn render_with<F>(&mut self, render_function: F) -> Result<(), Error>
where
F: FnOnce(&mut wgpu::CommandEncoder, &wgpu::TextureView, &PixelsContext),
F: FnOnce(
&mut wgpu::CommandEncoder,
&wgpu::TextureView,
&PixelsContext,
) -> Result<(), Box<dyn std::error::Error>>,
{
let frame = self
.context
Expand Down Expand Up @@ -389,8 +404,8 @@ impl Pixels {
.texture
.create_view(&wgpu::TextureViewDescriptor::default());

// Call the users render function.
(render_function)(&mut encoder, &view, &self.context);
// Call the user's render function.
(render_function)(&mut encoder, &view, &self.context)?;

self.context.queue.submit(Some(encoder.finish()));
Ok(())
Expand Down

0 comments on commit db00a67

Please sign in to comment.