diff options
author | Pierre Krieger <pierre.krieger1708@gmail.com> | 2015-07-22 08:39:31 +0200 |
---|---|---|
committer | Pierre Krieger <pierre.krieger1708@gmail.com> | 2015-07-22 08:39:31 +0200 |
commit | 65d56e55216beed99f4bb81eddaffa8bafbdb33e (patch) | |
tree | 09b1bcc8e87f25911034941229ca0a61d0ee5cae /src/api/glx | |
parent | 04a651320ba00571a0b2af9ae25c6d6c696c2803 (diff) | |
download | glutin-65d56e55216beed99f4bb81eddaffa8bafbdb33e.tar.gz glutin-65d56e55216beed99f4bb81eddaffa8bafbdb33e.zip |
Fix calling XFree before reading from memory
Diffstat (limited to 'src/api/glx')
-rw-r--r-- | src/api/glx/mod.rs | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/src/api/glx/mod.rs b/src/api/glx/mod.rs index 65819f8..f640bee 100644 --- a/src/api/glx/mod.rs +++ b/src/api/glx/mod.rs @@ -340,13 +340,14 @@ fn create_context(glx: &ffi::glx::Glx, extra_functions: &ffi::glx_extra::Glx, ex unsafe fn enumerate_configs(glx: &ffi::glx::Glx, xlib: &ffi::Xlib, display: *mut ffi::Display) -> Result<Vec<(ffi::glx::types::GLXFBConfig, PixelFormat)>, CreationError> { - let configs = { + let configs: Vec<ffi::glx::types::GLXFBConfig> = { let mut num_configs = 0; let vals = glx.GetFBConfigs(display as *mut _, 0, &mut num_configs); // TODO: screen number assert!(!vals.is_null()); let configs = slice::from_raw_parts(vals, num_configs as usize); + let ret = configs.to_vec(); (xlib.XFree)(vals as *mut _); - configs.to_vec() + ret }; let get_attrib = |attrib: libc::c_int, fb_config: ffi::glx::types::GLXFBConfig| -> i32 { |