Merge pull request #85 from glennw/c-str-issues

Fix a few more string memory issues.
This commit is contained in:
tomaka 2014-10-28 07:56:17 +01:00
commit e5bde5e383

View file

@ -166,9 +166,9 @@ impl Window {
let wm_delete_window = unsafe { let wm_delete_window = unsafe {
use std::c_str::ToCStr; use std::c_str::ToCStr;
let delete_window = "WM_DELETE_WINDOW".to_c_str();
ffi::XMapWindow(display, window); ffi::XMapWindow(display, window);
let mut wm_delete_window = ffi::XInternAtom(display, let mut wm_delete_window = ffi::XInternAtom(display, delete_window.as_ptr(), 0);
"WM_DELETE_WINDOW".to_c_str().as_ptr() as *const libc::c_char, 0);
ffi::XSetWMProtocols(display, window, &mut wm_delete_window, 1); ffi::XSetWMProtocols(display, window, &mut wm_delete_window, 1);
let c_title = builder.title.to_c_str(); let c_title = builder.title.to_c_str();
ffi::XStoreName(display, window, c_title.as_ptr()); ffi::XStoreName(display, window, c_title.as_ptr());
@ -190,8 +190,10 @@ impl Window {
let ic = unsafe { let ic = unsafe {
use std::c_str::ToCStr; use std::c_str::ToCStr;
let ic = ffi::XCreateIC(im, "inputStyle".to_c_str().as_ptr(), let input_style = "inputStyle".to_c_str();
ffi::XIMPreeditNothing | ffi::XIMStatusNothing, "clientWindow".to_c_str().as_ptr(), let client_window = "clientWindow".to_c_str();
let ic = ffi::XCreateIC(im, input_style.as_ptr(),
ffi::XIMPreeditNothing | ffi::XIMStatusNothing, client_window.as_ptr(),
window, ptr::null()); window, ptr::null());
if ic.is_null() { if ic.is_null() {
return Err(format!("XCreateIC failed")); return Err(format!("XCreateIC failed"));