Skip to content

Commit

Permalink
[wgpu-hal] return None in Adapter.surface_capabilities() if the `…
Browse files Browse the repository at this point in the history
…Surface` and the `Adapter` don't share the same WebGL2 context
  • Loading branch information
teoxoy committed Jul 3, 2024
1 parent 479b497 commit ca8475a
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 4 deletions.
5 changes: 5 additions & 0 deletions wgpu-hal/src/gles/adapter.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1152,6 +1152,11 @@ impl crate::Adapter for super::Adapter {
&self,
surface: &super::Surface,
) -> Option<crate::SurfaceCapabilities> {
#[cfg(webgl)]
if self.shared.context.webgl2_context != surface.webgl2_context {
return None;
}

if surface.presentable {
let mut formats = vec![
wgt::TextureFormat::Rgba8Unorm,
Expand Down
14 changes: 10 additions & 4 deletions wgpu-hal/src/gles/web.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ use super::TextureFormatDesc;
/// with the `AdapterContext` API from the EGL implementation.
pub struct AdapterContext {
pub glow_context: glow::Context,
pub webgl2_context: web_sys::WebGl2RenderingContext,
}

impl AdapterContext {
Expand Down Expand Up @@ -124,9 +125,14 @@ impl crate::Instance for Instance {
if let Some(surface_hint) = surface_hint {
let gl = glow::Context::from_webgl2_context(surface_hint.webgl2_context.clone());

unsafe { super::Adapter::expose(AdapterContext { glow_context: gl }) }
.into_iter()
.collect()
unsafe {
super::Adapter::expose(AdapterContext {
glow_context: gl,
webgl2_context: surface_hint.webgl2_context.clone(),
})
}
.into_iter()
.collect()
} else {
Vec::new()
}
Expand Down Expand Up @@ -172,7 +178,7 @@ impl crate::Instance for Instance {
#[derive(Debug)]
pub struct Surface {
canvas: Canvas,
webgl2_context: web_sys::WebGl2RenderingContext,
pub(super) webgl2_context: web_sys::WebGl2RenderingContext,
pub(super) swapchain: RwLock<Option<Swapchain>>,
texture: Mutex<Option<glow::Texture>>,
pub(super) presentable: bool,
Expand Down

0 comments on commit ca8475a

Please sign in to comment.