Merge pull request #217 from glennw/context-fallback

Some GPU/driver combinations have glxCreateContextAttribsARB present, bu...
This commit is contained in:
tomaka 2015-01-22 21:37:07 +01:00
commit 1d6b863cd4
2 changed files with 26 additions and 2 deletions

View file

@ -1358,6 +1358,17 @@ pub struct XF86VidModeModeInfo {
private: libc::c_long, private: libc::c_long,
} }
#[repr(C)]
pub struct XErrorEvent {
pub type_: libc::c_int,
pub display: *mut Display,
pub serial: libc::c_ulong,
pub error_code: libc::c_char,
pub request_code: libc::c_char,
pub minor_code: libc::c_char,
pub resourceid: XID,
}
#[cfg(feature = "headless")] #[cfg(feature = "headless")]
#[link(name = "OSMesa")] #[link(name = "OSMesa")]
extern "C" { extern "C" {
@ -1430,6 +1441,7 @@ extern "C" {
pub fn XScreenOfDisplay(display: *mut Display, screen_number: libc::c_int) -> *const Screen; pub fn XScreenOfDisplay(display: *mut Display, screen_number: libc::c_int) -> *const Screen;
pub fn XWidthOfScreen(screen: *const Screen) -> libc::c_int; pub fn XWidthOfScreen(screen: *const Screen) -> libc::c_int;
pub fn XHeightOfScreen(screen: *const Screen) -> libc::c_int; pub fn XHeightOfScreen(screen: *const Screen) -> libc::c_int;
pub fn XSetErrorHandler(callback: fn(display: *mut Display, event: *mut XErrorEvent) -> libc::c_int) -> libc::c_int;
pub fn XCloseIM(im: XIM) -> Status; pub fn XCloseIM(im: XIM) -> Status;
pub fn XOpenIM(display: *mut Display, db: XrmDatabase, res_name: *mut libc::c_char, pub fn XOpenIM(display: *mut Display, db: XrmDatabase, res_name: *mut libc::c_char,

View file

@ -16,10 +16,18 @@ mod monitor;
static THREAD_INIT: Once = ONCE_INIT; static THREAD_INIT: Once = ONCE_INIT;
fn x_error_callback(_: *mut ffi::Display, event: *mut ffi::XErrorEvent) -> libc::c_int {
unsafe {
println!("[glutin] x error code={} major={} minor={}!", (*event).error_code, (*event).request_code, (*event).minor_code);
}
0
}
fn ensure_thread_init() { fn ensure_thread_init() {
THREAD_INIT.call_once(|| { THREAD_INIT.call_once(|| {
unsafe { unsafe {
ffi::XInitThreads(); ffi::XInitThreads();
ffi::XSetErrorHandler(x_error_callback);
} }
}); });
} }
@ -322,13 +330,17 @@ impl Window {
ptr::null() ptr::null()
}; };
let context = if extra_functions.CreateContextAttribsARB.is_loaded() { let mut context = if extra_functions.CreateContextAttribsARB.is_loaded() {
extra_functions.CreateContextAttribsARB(display as *mut ffi::glx_extra::types::Display, extra_functions.CreateContextAttribsARB(display as *mut ffi::glx_extra::types::Display,
fb_config, share, 1, attributes.as_ptr()) fb_config, share, 1, attributes.as_ptr())
} else { } else {
ffi::glx::CreateContext(display, &mut visual_infos, share, 1) ptr::null()
}; };
if context.is_null() {
context = ffi::glx::CreateContext(display, &mut visual_infos, share, 1)
}
if context.is_null() { if context.is_null() {
return Err(OsError(format!("GL context creation failed"))); return Err(OsError(format!("GL context creation failed")));
} }