From dc2cfadf82c15592375b7a6a386d4fb9750321f4 Mon Sep 17 00:00:00 2001 From: Samson <16504129+sagudev@users.noreply.github.com> Date: Wed, 30 Oct 2024 17:17:18 +0100 Subject: [PATCH] Fix some rust FFI (#319) * Fix bind_frag_data_location rust str is not null terminated Signed-off-by: sagudev <16504129+sagudev@users.noreply.github.com> * Fix get_transform_feedback_varying size and tftype must be mutable CString does not allow multiple nul bytes inside (this causes panic). Signed-off-by: sagudev <16504129+sagudev@users.noreply.github.com> --------- Signed-off-by: sagudev <16504129+sagudev@users.noreply.github.com> --- src/native.rs | 23 ++++++++++++----------- 1 file changed, 12 insertions(+), 11 deletions(-) diff --git a/src/native.rs b/src/native.rs index ca43b31..2505d5b 100644 --- a/src/native.rs +++ b/src/native.rs @@ -1314,6 +1314,7 @@ impl HasContext for Context { name: &str, ) { let gl = &self.raw; + let name = CString::new(name).unwrap(); gl.BindFragDataLocation( program.0.get(), color_number, @@ -4080,25 +4081,25 @@ impl HasContext for Context { ) -> Option { let gl = &self.raw; - const buf_size: usize = 256; - const bytes: [u8; buf_size] = [0; buf_size]; + const max_name_size: usize = 256; + let mut name_bytes = [0; max_name_size]; - let size: i32 = 0; - let tftype: u32 = 0; - let c_name = CString::new(bytes.to_vec()).unwrap(); - let c_name_buf = c_name.into_raw(); + let mut size = 0; + let mut tftype = 0; gl.GetTransformFeedbackVarying( program.0.get(), index, - buf_size as i32, + name_bytes.len() as i32, std::ptr::null_mut(), - size as *mut i32, - tftype as *mut u32, - c_name_buf, + &mut size, + &mut tftype, + name_bytes.as_mut_ptr(), ); - let name = CString::from_raw(c_name_buf).into_string().unwrap(); + let name = CStr::from_ptr(name_bytes.as_mut_ptr()) + .to_string_lossy() + .into_owned(); Some(ActiveTransformFeedback { size, tftype, name }) }