From 13a0606449a42db9def1df6f3452e3b750add7ab Mon Sep 17 00:00:00 2001 From: Anand Thamban Date: Tue, 2 Aug 2022 00:28:02 -0500 Subject: [PATCH] Store and check adapter features before using them --- crates/fj-viewer/src/graphics/renderer.rs | 41 ++++++++++++++--------- 1 file changed, 25 insertions(+), 16 deletions(-) diff --git a/crates/fj-viewer/src/graphics/renderer.rs b/crates/fj-viewer/src/graphics/renderer.rs index 614b9ecf2..e33acd19e 100644 --- a/crates/fj-viewer/src/graphics/renderer.rs +++ b/crates/fj-viewer/src/graphics/renderer.rs @@ -44,6 +44,7 @@ impl std::fmt::Debug for EguiState { #[derive(Debug)] pub struct Renderer { surface: wgpu::Surface, + features: wgpu::Features, device: wgpu::Device, queue: wgpu::Queue, @@ -134,6 +135,8 @@ impl Renderer { .await .ok_or(InitError::RequestAdapter)?; + let features = adapter.features(); + let (device, queue) = adapter .request_device( &wgpu::DeviceDescriptor { @@ -144,7 +147,7 @@ impl Renderer { // // See this issue: // https://github.com/hannobraun/fornjot/issues/33 - features: wgpu::Features::POLYGON_MODE_LINE, + features, limits: wgpu::Limits::default(), }, None, @@ -239,6 +242,7 @@ impl Renderer { Ok(Self { surface, + features, device, queue, @@ -328,21 +332,26 @@ impl Renderer { &self.bind_group, ); } - if config.draw_mesh { - drawables.mesh.draw( - &mut encoder, - &color_view, - &self.depth_view, - &self.bind_group, - ); - } - if config.draw_debug { - drawables.lines.draw( - &mut encoder, - &color_view, - &self.depth_view, - &self.bind_group, - ); + + // NOTE: This does not inform the user if the renderer cannot + // use the POLYGON_MODE_LINE feature. + if self.features.contains(wgpu::Features::POLYGON_MODE_LINE) { + if config.draw_mesh { + drawables.mesh.draw( + &mut encoder, + &color_view, + &self.depth_view, + &self.bind_group, + ); + } + if config.draw_debug { + drawables.lines.draw( + &mut encoder, + &color_view, + &self.depth_view, + &self.bind_group, + ); + } } if self.egui.options.show_original_ui {