From b7bc40d4b299ee00b03c96f55154fd1ec0d71135 Mon Sep 17 00:00:00 2001 From: sagudev <16504129+sagudev@users.noreply.github.com> Date: Tue, 22 Oct 2024 14:18:34 +0200 Subject: [PATCH 1/2] Error on creating native GL object instead of panic this matches webgl Signed-off-by: sagudev <16504129+sagudev@users.noreply.github.com> --- src/native.rs | 30 ++++++++++++++---------------- 1 file changed, 14 insertions(+), 16 deletions(-) diff --git a/src/native.rs b/src/native.rs index ab18b48..d215db3 100644 --- a/src/native.rs +++ b/src/native.rs @@ -226,14 +226,14 @@ impl HasContext for Context { let gl = &self.raw; let mut name = 0; gl.GenFramebuffers(1, &mut name); - Ok(NativeFramebuffer(non_zero_gl_name(name))) + NonZeroU32::new(name).map(NativeFramebuffer).ok_or_else(|| String::from("Unable to create Framebuffer object")) } unsafe fn create_named_framebuffer(&self) -> Result { let gl = &self.raw; let mut name = 0; gl.CreateFramebuffers(1, &mut name); - Ok(NativeFramebuffer(non_zero_gl_name(name))) + NonZeroU32::new(name).map(NativeFramebuffer).ok_or_else(|| String::from("Unable to create Framebuffer object")) } unsafe fn is_framebuffer(&self, framebuffer: Self::Framebuffer) -> bool { @@ -245,14 +245,14 @@ impl HasContext for Context { let gl = &self.raw; let mut name = 0; gl.GenQueries(1, &mut name); - Ok(NativeQuery(non_zero_gl_name(name))) + NonZeroU32::new(name).map(NativeQuery).ok_or_else(|| String::from("Unable to create Query object")) } unsafe fn create_renderbuffer(&self) -> Result { let gl = &self.raw; let mut name = 0; gl.GenRenderbuffers(1, &mut name); - Ok(NativeRenderbuffer(non_zero_gl_name(name))) + NonZeroU32::new(name).map(NativeRenderbuffer).ok_or_else(|| String::from("Unable to create Renderbuffer object")) } unsafe fn is_renderbuffer(&self, renderbuffer: Self::Renderbuffer) -> bool { @@ -264,14 +264,12 @@ impl HasContext for Context { let gl = &self.raw; let mut name = 0; gl.GenSamplers(1, &mut name); - Ok(NativeSampler(non_zero_gl_name(name))) + NonZeroU32::new(name).map(NativeSampler).ok_or_else(|| String::from("Unable to create Sampler object")) } unsafe fn create_shader(&self, shader_type: u32) -> Result { let gl = &self.raw; - Ok(NativeShader(non_zero_gl_name( - gl.CreateShader(shader_type as u32), - ))) + NonZeroU32::new(gl.CreateShader(shader_type as u32)).map(NativeShader).ok_or_else(|| String::from("Unable to create Shader object")) } unsafe fn is_shader(&self, shader: Self::Shader) -> bool { @@ -283,14 +281,14 @@ impl HasContext for Context { let gl = &self.raw; let mut name = 0; gl.GenTextures(1, &mut name); - Ok(NativeTexture(non_zero_gl_name(name))) + NonZeroU32::new(name).map(NativeTexture).ok_or_else(|| String::from("Unable to create Texture object")) } unsafe fn create_named_texture(&self, target: u32) -> Result { let gl = &self.raw; let mut name = 0; gl.CreateTextures(target, 1, &mut name); - Ok(NativeTexture(non_zero_gl_name(name))) + NonZeroU32::new(name).map(NativeTexture).ok_or_else(|| String::from("Unable to create Texture object")) } unsafe fn is_texture(&self, texture: Self::Texture) -> bool { @@ -375,7 +373,7 @@ impl HasContext for Context { unsafe fn create_program(&self) -> Result { let gl = &self.raw; - Ok(NativeProgram(non_zero_gl_name(gl.CreateProgram()))) + NonZeroU32::new(gl.CreateProgram()).map(NativeProgram).ok_or_else(|| String::from("Unable to create Program object")) } unsafe fn is_program(&self, program: Self::Program) -> bool { @@ -1087,14 +1085,14 @@ impl HasContext for Context { let gl = &self.raw; let mut buffer = 0; gl.GenBuffers(1, &mut buffer); - Ok(NativeBuffer(non_zero_gl_name(buffer))) + NonZeroU32::new(buffer).map(NativeBuffer).ok_or_else(|| String::from("Unable to create Buffer object")) } unsafe fn create_named_buffer(&self) -> Result { let gl = &self.raw; let mut buffer = 0; gl.CreateBuffers(1, &mut buffer); - Ok(NativeBuffer(non_zero_gl_name(buffer))) + NonZeroU32::new(buffer).map(NativeBuffer).ok_or_else(|| String::from("Unable to create Buffer object")) } unsafe fn is_buffer(&self, buffer: Self::Buffer) -> bool { @@ -1211,14 +1209,14 @@ impl HasContext for Context { let gl = &self.raw; let mut vertex_array = 0; gl.GenVertexArrays(1, &mut vertex_array); - Ok(NativeVertexArray(non_zero_gl_name(vertex_array))) + NonZeroU32::new(vertex_array).map(NativeVertexArray).ok_or_else(|| String::from("Unable to create VertexArray object")) } unsafe fn create_named_vertex_array(&self) -> Result { let gl = &self.raw; let mut vertex_array = 0; gl.CreateVertexArrays(1, &mut vertex_array); - Ok(NativeVertexArray(non_zero_gl_name(vertex_array))) + NonZeroU32::new(vertex_array).map(NativeVertexArray).ok_or_else(|| String::from("Unable to create VertexArray object")) } unsafe fn delete_vertex_array(&self, vertex_array: Self::VertexArray) { @@ -3986,7 +3984,7 @@ impl HasContext for Context { let gl = &self.raw; let mut name = 0; gl.GenTransformFeedbacks(1, &mut name); - Ok(NativeTransformFeedback(non_zero_gl_name(name))) + NonZeroU32::new(name).map(NativeTransformFeedback).ok_or_else(|| String::from("Unable to create TransformFeedback object")) } unsafe fn delete_transform_feedback(&self, transform_feedback: Self::TransformFeedback) { From f8ad8b00432fe1270e4fb8dd559b241f8196e43d Mon Sep 17 00:00:00 2001 From: sagudev <16504129+sagudev@users.noreply.github.com> Date: Tue, 22 Oct 2024 14:20:29 +0200 Subject: [PATCH 2/2] fmt Signed-off-by: sagudev <16504129+sagudev@users.noreply.github.com> --- src/native.rs | 56 ++++++++++++++++++++++++++++++++++++++------------- 1 file changed, 42 insertions(+), 14 deletions(-) diff --git a/src/native.rs b/src/native.rs index d215db3..ca43b31 100644 --- a/src/native.rs +++ b/src/native.rs @@ -226,14 +226,18 @@ impl HasContext for Context { let gl = &self.raw; let mut name = 0; gl.GenFramebuffers(1, &mut name); - NonZeroU32::new(name).map(NativeFramebuffer).ok_or_else(|| String::from("Unable to create Framebuffer object")) + NonZeroU32::new(name) + .map(NativeFramebuffer) + .ok_or_else(|| String::from("Unable to create Framebuffer object")) } unsafe fn create_named_framebuffer(&self) -> Result { let gl = &self.raw; let mut name = 0; gl.CreateFramebuffers(1, &mut name); - NonZeroU32::new(name).map(NativeFramebuffer).ok_or_else(|| String::from("Unable to create Framebuffer object")) + NonZeroU32::new(name) + .map(NativeFramebuffer) + .ok_or_else(|| String::from("Unable to create Framebuffer object")) } unsafe fn is_framebuffer(&self, framebuffer: Self::Framebuffer) -> bool { @@ -245,14 +249,18 @@ impl HasContext for Context { let gl = &self.raw; let mut name = 0; gl.GenQueries(1, &mut name); - NonZeroU32::new(name).map(NativeQuery).ok_or_else(|| String::from("Unable to create Query object")) + NonZeroU32::new(name) + .map(NativeQuery) + .ok_or_else(|| String::from("Unable to create Query object")) } unsafe fn create_renderbuffer(&self) -> Result { let gl = &self.raw; let mut name = 0; gl.GenRenderbuffers(1, &mut name); - NonZeroU32::new(name).map(NativeRenderbuffer).ok_or_else(|| String::from("Unable to create Renderbuffer object")) + NonZeroU32::new(name) + .map(NativeRenderbuffer) + .ok_or_else(|| String::from("Unable to create Renderbuffer object")) } unsafe fn is_renderbuffer(&self, renderbuffer: Self::Renderbuffer) -> bool { @@ -264,12 +272,16 @@ impl HasContext for Context { let gl = &self.raw; let mut name = 0; gl.GenSamplers(1, &mut name); - NonZeroU32::new(name).map(NativeSampler).ok_or_else(|| String::from("Unable to create Sampler object")) + NonZeroU32::new(name) + .map(NativeSampler) + .ok_or_else(|| String::from("Unable to create Sampler object")) } unsafe fn create_shader(&self, shader_type: u32) -> Result { let gl = &self.raw; - NonZeroU32::new(gl.CreateShader(shader_type as u32)).map(NativeShader).ok_or_else(|| String::from("Unable to create Shader object")) + NonZeroU32::new(gl.CreateShader(shader_type as u32)) + .map(NativeShader) + .ok_or_else(|| String::from("Unable to create Shader object")) } unsafe fn is_shader(&self, shader: Self::Shader) -> bool { @@ -281,14 +293,18 @@ impl HasContext for Context { let gl = &self.raw; let mut name = 0; gl.GenTextures(1, &mut name); - NonZeroU32::new(name).map(NativeTexture).ok_or_else(|| String::from("Unable to create Texture object")) + NonZeroU32::new(name) + .map(NativeTexture) + .ok_or_else(|| String::from("Unable to create Texture object")) } unsafe fn create_named_texture(&self, target: u32) -> Result { let gl = &self.raw; let mut name = 0; gl.CreateTextures(target, 1, &mut name); - NonZeroU32::new(name).map(NativeTexture).ok_or_else(|| String::from("Unable to create Texture object")) + NonZeroU32::new(name) + .map(NativeTexture) + .ok_or_else(|| String::from("Unable to create Texture object")) } unsafe fn is_texture(&self, texture: Self::Texture) -> bool { @@ -373,7 +389,9 @@ impl HasContext for Context { unsafe fn create_program(&self) -> Result { let gl = &self.raw; - NonZeroU32::new(gl.CreateProgram()).map(NativeProgram).ok_or_else(|| String::from("Unable to create Program object")) + NonZeroU32::new(gl.CreateProgram()) + .map(NativeProgram) + .ok_or_else(|| String::from("Unable to create Program object")) } unsafe fn is_program(&self, program: Self::Program) -> bool { @@ -1085,14 +1103,18 @@ impl HasContext for Context { let gl = &self.raw; let mut buffer = 0; gl.GenBuffers(1, &mut buffer); - NonZeroU32::new(buffer).map(NativeBuffer).ok_or_else(|| String::from("Unable to create Buffer object")) + NonZeroU32::new(buffer) + .map(NativeBuffer) + .ok_or_else(|| String::from("Unable to create Buffer object")) } unsafe fn create_named_buffer(&self) -> Result { let gl = &self.raw; let mut buffer = 0; gl.CreateBuffers(1, &mut buffer); - NonZeroU32::new(buffer).map(NativeBuffer).ok_or_else(|| String::from("Unable to create Buffer object")) + NonZeroU32::new(buffer) + .map(NativeBuffer) + .ok_or_else(|| String::from("Unable to create Buffer object")) } unsafe fn is_buffer(&self, buffer: Self::Buffer) -> bool { @@ -1209,14 +1231,18 @@ impl HasContext for Context { let gl = &self.raw; let mut vertex_array = 0; gl.GenVertexArrays(1, &mut vertex_array); - NonZeroU32::new(vertex_array).map(NativeVertexArray).ok_or_else(|| String::from("Unable to create VertexArray object")) + NonZeroU32::new(vertex_array) + .map(NativeVertexArray) + .ok_or_else(|| String::from("Unable to create VertexArray object")) } unsafe fn create_named_vertex_array(&self) -> Result { let gl = &self.raw; let mut vertex_array = 0; gl.CreateVertexArrays(1, &mut vertex_array); - NonZeroU32::new(vertex_array).map(NativeVertexArray).ok_or_else(|| String::from("Unable to create VertexArray object")) + NonZeroU32::new(vertex_array) + .map(NativeVertexArray) + .ok_or_else(|| String::from("Unable to create VertexArray object")) } unsafe fn delete_vertex_array(&self, vertex_array: Self::VertexArray) { @@ -3984,7 +4010,9 @@ impl HasContext for Context { let gl = &self.raw; let mut name = 0; gl.GenTransformFeedbacks(1, &mut name); - NonZeroU32::new(name).map(NativeTransformFeedback).ok_or_else(|| String::from("Unable to create TransformFeedback object")) + NonZeroU32::new(name) + .map(NativeTransformFeedback) + .ok_or_else(|| String::from("Unable to create TransformFeedback object")) } unsafe fn delete_transform_feedback(&self, transform_feedback: Self::TransformFeedback) {