Merge pull request #99 from tomaka/update-glrs

Update for changes in gl-rs
This commit is contained in:
tomaka 2014-11-05 15:39:20 +01:00
commit c63511e9e6
4 changed files with 59 additions and 37 deletions

View file

@ -31,7 +31,7 @@ pub struct Context {
} }
pub fn load(window: &glutin::Window) -> Context { pub fn load(window: &glutin::Window) -> Context {
let gl = gl::Gl::load_with(|symbol| window.get_proc_address(symbol)); let gl = gl::Gl::load(window);
let version = { let version = {
use std::c_str::CString; use std::c_str::CString;
@ -46,6 +46,7 @@ pub fn load(window: &glutin::Window) -> Context {
impl Context { impl Context {
#[cfg(not(target_os = "android"))] #[cfg(not(target_os = "android"))]
pub fn draw_frame(&self, color: (f32, f32, f32, f32)) { pub fn draw_frame(&self, color: (f32, f32, f32, f32)) {
unsafe {
self.gl.ClearColor(color.0, color.1, color.2, color.3); self.gl.ClearColor(color.0, color.1, color.2, color.3);
self.gl.Clear(gl::COLOR_BUFFER_BIT); self.gl.Clear(gl::COLOR_BUFFER_BIT);
@ -60,9 +61,11 @@ impl Context {
self.gl.Flush(); self.gl.Flush();
} }
}
#[cfg(target_os = "android")] #[cfg(target_os = "android")]
pub fn draw_frame(&self, color: (f32, f32, f32, f32)) { pub fn draw_frame(&self, color: (f32, f32, f32, f32)) {
unsafe {
self.gl.ClearColor(color.0, color.1, color.2, color.3); self.gl.ClearColor(color.0, color.1, color.2, color.3);
self.gl.Clear(gl::COLOR_BUFFER_BIT); self.gl.Clear(gl::COLOR_BUFFER_BIT);
@ -83,6 +86,7 @@ impl Context {
self.gl.Flush(); self.gl.Flush();
} }
}
} }
#[cfg(target_os = "android")] #[cfg(target_os = "android")]

View file

@ -31,6 +31,8 @@
#[phase(plugin)] extern crate compile_msg; #[phase(plugin)] extern crate compile_msg;
#[phase(plugin)] extern crate gl_generator; #[phase(plugin)] extern crate gl_generator;
extern crate gl_common;
extern crate libc; extern crate libc;
#[cfg(target_os = "macos")] #[cfg(target_os = "macos")]
@ -397,6 +399,13 @@ impl Window {
} }
} }
#[cfg(feature = "window")]
impl gl_common::GlFunctionsSource for Window {
fn get_proc_addr(&self, addr: &str) -> *const libc::c_void {
self.get_proc_address(addr)
}
}
/// Represents a headless OpenGL context. /// Represents a headless OpenGL context.
#[cfg(feature = "headless")] #[cfg(feature = "headless")]
pub struct HeadlessContext { pub struct HeadlessContext {
@ -421,6 +430,13 @@ impl HeadlessContext {
} }
} }
#[cfg(feature = "headless")]
impl gl_common::GlFunctionsSource for HeadlessContext {
fn get_proc_addr(&self, addr: &str) -> *const libc::c_void {
self.get_proc_address(addr)
}
}
/// An iterator for the `poll_events` function. /// An iterator for the `poll_events` function.
// Implementation note: we retreive the list once, then serve each element by one by one. // Implementation note: we retreive the list once, then serve each element by one by one.
// This may change in the future. // This may change in the future.

View file

@ -350,7 +350,7 @@ pub fn new_window(builder_dimensions: Option<(uint, uint)>, builder_title: Strin
if builder_vsync { if builder_vsync {
if extra_functions.SwapIntervalEXT.is_loaded() { if extra_functions.SwapIntervalEXT.is_loaded() {
unsafe { ffi::wgl::MakeCurrent(hdc, context) }; unsafe { ffi::wgl::MakeCurrent(hdc, context) };
if extra_functions.SwapIntervalEXT(1) == 0 { if unsafe { extra_functions.SwapIntervalEXT(1) } == 0 {
tx.send(Err(format!("wglSwapIntervalEXT failed"))); tx.send(Err(format!("wglSwapIntervalEXT failed")));
unsafe { ffi::wgl::DeleteContext(context); } unsafe { ffi::wgl::DeleteContext(context); }
unsafe { ffi::DestroyWindow(real_window); } unsafe { ffi::DestroyWindow(real_window); }

View file

@ -24,12 +24,14 @@ fn main() {
let gl = gl::Gl::load_with(|symbol| window.get_proc_address(symbol)); let gl = gl::Gl::load_with(|symbol| window.get_proc_address(symbol));
unsafe {
gl.ClearColor(0.0, 1.0, 0.0, 1.0); gl.ClearColor(0.0, 1.0, 0.0, 1.0);
gl.Clear(gl::COLOR_BUFFER_BIT); gl.Clear(gl::COLOR_BUFFER_BIT);
let mut value: (u8, u8, u8, u8) = unsafe { std::mem::uninitialized() }; let mut value: (u8, u8, u8, u8) = std::mem::uninitialized();
unsafe { gl.ReadPixels(0, 0, 1, 1, gl::RGBA, gl::UNSIGNED_BYTE, std::mem::transmute(&mut value)) }; gl.ReadPixels(0, 0, 1, 1, gl::RGBA, gl::UNSIGNED_BYTE, std::mem::transmute(&mut value));
assert!(value == (0, 255, 0, 255) || value == (0, 64, 0, 255) || assert!(value == (0, 255, 0, 255) || value == (0, 64, 0, 255) ||
value == (0, 64, 0, 255) || value == (0, 64, 0, 0)); value == (0, 64, 0, 255) || value == (0, 64, 0, 0));
}
} }