aboutsummaryrefslogtreecommitdiffstats
path: root/src/x11/ffi.rs
diff options
context:
space:
mode:
authortomaka <pierre.krieger1708@gmail.com>2014-10-13 11:42:23 +0200
committertomaka <pierre.krieger1708@gmail.com>2014-10-13 11:42:23 +0200
commitc7f2dc67374edefd351a236eb49374602af0aabd (patch)
tree19ac46dddf3dcf2cccd18633cb5a7356a5e20d7d /src/x11/ffi.rs
parent4dcdf3ec50d24873895c279557a2aec7f05fd6e7 (diff)
parentbb22087d1ca2fdd4c52c980fb56f8bd425faa0d3 (diff)
downloadglutin-c7f2dc67374edefd351a236eb49374602af0aabd.tar.gz
glutin-c7f2dc67374edefd351a236eb49374602af0aabd.zip
Merge pull request #54 from tomaka/use-glx-glrs
Use gl-rs's GLX bindings for x11
Diffstat (limited to 'src/x11/ffi.rs')
-rw-r--r--src/x11/ffi.rs53
1 files changed, 11 insertions, 42 deletions
diff --git a/src/x11/ffi.rs b/src/x11/ffi.rs
index 5b35e7b..39a6ae5 100644
--- a/src/x11/ffi.rs
+++ b/src/x11/ffi.rs
@@ -3,33 +3,30 @@
#![allow(non_camel_case_types)]
#![allow(non_uppercase_statics)]
+pub use self::glx::types::*;
use libc;
+/// GLX bindings
+pub mod glx {
+ generate_gl_bindings!("glx", "core", "1.4", "static")
+}
+
+/// Functions that are not necessarly always available
+pub mod glx_extra {
+ generate_gl_bindings!("glx", "core", "1.4", "struct", [ "GLX_ARB_create_context" ])
+}
+
pub type Atom = libc::c_ulong;
-pub type Bool = libc::c_int;
pub type Colormap = XID;
pub type Cursor = XID;
-pub type Display = ();
pub type Drawable = XID; // TODO: not sure
-pub type GLXContext = *const ();
-pub type GLXContextID = XID;
-pub type GLXDrawable = XID;
-pub type GLXFBConfig = *const ();
-pub type GLXPbuffer = XID;
-pub type GLXPixmap = XID;
-pub type GLXWindow = XID;
pub type KeyCode = libc::c_ulong;
pub type KeySym = XID;
pub type OSMesaContext = *const ();
-pub type Pixmap = XID;
pub type Status = libc::c_int; // TODO: not sure
pub type Time = libc::c_ulong;
-pub type Visual = (); // TODO: not sure
-pub type VisualID = libc::c_ulong; // TODO: not sure
-pub type Window = XID;
pub type XrmDatabase = *const (); // TODO: not sure
pub type XIC = *mut ();
-pub type XID = libc::uintptr_t;
pub type XIM = *mut ();
pub type Screen = ();
@@ -1221,19 +1218,6 @@ pub const XK_hebrew_taf: libc::c_uint = 0xcfa;
pub const XK_Hebrew_switch: libc::c_uint = 0xFF7E;
-#[repr(C)]
-pub struct XVisualInfo {
- pub visual: *mut Visual,
- pub visualid: VisualID,
- pub screen: libc::c_int,
- pub depth: libc::c_int,
- pub class: libc::c_int,
- pub red_mask: libc::c_ulong,
- pub green_mask: libc::c_ulong,
- pub blue_mask: libc::c_ulong,
- pub colormap_size: libc::c_int,
- pub bits_per_rgb: libc::c_int,
-}
#[repr(C)]
pub struct XSetWindowAttributes {
@@ -1440,21 +1424,6 @@ extern "C" {
buffer_return: *mut libc::c_char, bytes_buffer: libc::c_int,
keysym_return: *mut KeySym, status_return: *mut Status) -> libc::c_int;
- pub fn glXCreateContext(dpy: *mut Display, vis: *const XVisualInfo,
- shareList: GLXContext, direct: Bool) -> GLXContext;
- pub fn glXCreateNewContext(dpy: *mut Display, config: GLXFBConfig, render_type: libc::c_int,
- shareList: GLXContext, direct: Bool) -> GLXContext;
- pub fn glXDestroyContext(dpy: *mut Display, ctx: GLXContext);
- pub fn glXChooseFBConfig(dpy: *mut Display, screen: libc::c_int,
- attrib_list: *const libc::c_int, nelements: *mut libc::c_int) -> *mut GLXFBConfig;
- pub fn glXChooseVisual(dpy: *mut Display, screen: libc::c_int,
- attribList: *const libc::c_int) -> *const XVisualInfo;
- pub fn glXGetProcAddress(procName: *const libc::c_uchar) -> *const ();
- pub fn glXGetVisualFromFBConfig(dpy: *mut Display, config: GLXFBConfig) -> *mut XVisualInfo;
- pub fn glXMakeCurrent(dpy: *mut Display, drawable: GLXDrawable,
- ctx: GLXContext) -> Bool;
- pub fn glXSwapBuffers(dpy: *mut Display, drawable: GLXDrawable);
-
pub fn XkbSetDetectableAutoRepeat(dpy: *mut Display, detectable: bool, supported_rtm: *mut bool) -> bool;
pub fn XF86VidModeSwitchToMode(dpy: *mut Display, screen: libc::c_int,