aboutsummaryrefslogtreecommitdiffstats
path: root/src/api/wgl/make_current_guard.rs
diff options
context:
space:
mode:
authortomaka <pierre.krieger1708@gmail.com>2015-05-21 18:15:20 +0200
committertomaka <pierre.krieger1708@gmail.com>2015-05-21 18:15:20 +0200
commite606281862dfd016051e2ee66e67eddb71c6d0ac (patch)
tree14673f9745e4760e5e93412a5126d229828ec7de /src/api/wgl/make_current_guard.rs
parentb72ac990e67771ca8c256859ce3fc472458becd9 (diff)
parentea17038ac2a25982ffc8e9308eec312864938d20 (diff)
downloadglutin-e606281862dfd016051e2ee66e67eddb71c6d0ac.tar.gz
glutin-e606281862dfd016051e2ee66e67eddb71c6d0ac.zip
Merge pull request #458 from tomaka/detach-wgl
Detach wgl and win32
Diffstat (limited to 'src/api/wgl/make_current_guard.rs')
-rw-r--r--src/api/wgl/make_current_guard.rs47
1 files changed, 47 insertions, 0 deletions
diff --git a/src/api/wgl/make_current_guard.rs b/src/api/wgl/make_current_guard.rs
new file mode 100644
index 0000000..b890c82
--- /dev/null
+++ b/src/api/wgl/make_current_guard.rs
@@ -0,0 +1,47 @@
+use std::marker::PhantomData;
+use std::io;
+
+use libc;
+use winapi;
+use CreationError;
+
+use super::gl;
+/// A guard for when you want to make the context current. Destroying the guard restores the
+/// previously-current context.
+pub struct CurrentContextGuard<'a, 'b> {
+ previous_hdc: winapi::HDC,
+ previous_hglrc: winapi::HGLRC,
+ marker1: PhantomData<&'a ()>,
+ marker2: PhantomData<&'b ()>,
+}
+
+impl<'a, 'b> CurrentContextGuard<'a, 'b> {
+ pub unsafe fn make_current(hdc: winapi::HDC, context: winapi::HGLRC)
+ -> Result<CurrentContextGuard<'a, 'b>, CreationError>
+ {
+ let previous_hdc = gl::wgl::GetCurrentDC() as winapi::HDC;
+ let previous_hglrc = gl::wgl::GetCurrentContext() as winapi::HGLRC;
+
+ let result = gl::wgl::MakeCurrent(hdc as *const _, context as *const _);
+ if result == 0 {
+ return Err(CreationError::OsError(format!("wglMakeCurrent function failed: {}",
+ format!("{}", io::Error::last_os_error()))));
+ }
+
+ Ok(CurrentContextGuard {
+ previous_hdc: previous_hdc,
+ previous_hglrc: previous_hglrc,
+ marker1: PhantomData,
+ marker2: PhantomData,
+ })
+ }
+}
+
+impl<'a, 'b> Drop for CurrentContextGuard<'a, 'b> {
+ fn drop(&mut self) {
+ unsafe {
+ gl::wgl::MakeCurrent(self.previous_hdc as *const libc::c_void,
+ self.previous_hglrc as *const libc::c_void);
+ }
+ }
+}