aboutsummaryrefslogtreecommitdiffstats
path: root/src/api/android
diff options
context:
space:
mode:
authorPierre Krieger <pierre.krieger1708@gmail.com>2015-07-27 10:18:45 +0200
committerPierre Krieger <pierre.krieger1708@gmail.com>2015-07-27 10:18:45 +0200
commit1f6c4d65a61b399d1a476dc19ca3d6a152856286 (patch)
treeca9705dc5d60fd720c769e24fb690d2a00dc8a86 /src/api/android
parent991b15df873136d4e7e41590cf2ffc54619b14dd (diff)
downloadglutin-1f6c4d65a61b399d1a476dc19ca3d6a152856286.tar.gz
glutin-1f6c4d65a61b399d1a476dc19ca3d6a152856286.zip
Implement headless contexts on android
Diffstat (limited to 'src/api/android')
-rw-r--r--src/api/android/mod.rs40
1 files changed, 40 insertions, 0 deletions
diff --git a/src/api/android/mod.rs b/src/api/android/mod.rs
index 83ef12b..7c09a7b 100644
--- a/src/api/android/mod.rs
+++ b/src/api/android/mod.rs
@@ -249,3 +249,43 @@ impl WindowProxy {
unimplemented!()
}
}
+
+pub struct HeadlessContext(EglContext);
+
+impl HeadlessContext {
+ /// See the docs in the crate root file.
+ pub fn new(builder: BuilderAttribs) -> Result<HeadlessContext, CreationError> {
+ let context = try!(EglContext::new(egl::ffi::egl::Egl, &builder, None));
+ let context = try!(context.finish_pbuffer());
+ Ok(context)
+ }
+}
+
+unsafe impl Send for HeadlessContext {}
+unsafe impl Sync for HeadlessContext {}
+
+impl GlContext for HeadlessContext {
+ unsafe fn make_current(&self) -> Result<(), ContextError> {
+ self.0.make_current()
+ }
+
+ fn is_current(&self) -> bool {
+ self.0.is_current()
+ }
+
+ fn get_proc_address(&self, addr: &str) -> *const libc::c_void {
+ self.0.get_proc_address(addr)
+ }
+
+ fn swap_buffers(&self) -> Result<(), ContextError> {
+ self.0.swap_buffers()
+ }
+
+ fn get_api(&self) -> Api {
+ self.0.get_api()
+ }
+
+ fn get_pixel_format(&self) -> PixelFormat {
+ self.0.get_pixel_format()
+ }
+}