Merge pull request #221 from tomaka/fix-rc

Fix race condition with XOpenIM
This commit is contained in:
tomaka 2015-01-25 12:55:58 +01:00
commit a2e03e7c15

View file

@ -8,6 +8,7 @@ use std::sync::atomic::AtomicBool;
use std::collections::RingBuf; use std::collections::RingBuf;
use super::ffi; use super::ffi;
use std::sync::{Arc, Once, ONCE_INIT}; use std::sync::{Arc, Once, ONCE_INIT};
use std::sync::{StaticMutex, MUTEX_INIT};
pub use self::monitor::{MonitorID, get_available_monitors, get_primary_monitor}; pub use self::monitor::{MonitorID, get_available_monitors, get_primary_monitor};
@ -262,6 +263,10 @@ impl Window {
// creating IM // creating IM
let im = unsafe { let im = unsafe {
// XOpenIM doesn't seem to be thread-safe
static GLOBAL_XOPENIM_LOCK: StaticMutex = MUTEX_INIT;
let _lock = GLOBAL_XOPENIM_LOCK.lock().unwrap();
let im = ffi::XOpenIM(display, ptr::null(), ptr::null_mut(), ptr::null_mut()); let im = ffi::XOpenIM(display, ptr::null(), ptr::null_mut(), ptr::null_mut());
if im.is_null() { if im.is_null() {
return Err(OsError(format!("XOpenIM failed"))); return Err(OsError(format!("XOpenIM failed")));