aboutsummaryrefslogtreecommitdiffstats
path: root/src/platform/emscripten
diff options
context:
space:
mode:
authortomaka <pierre.krieger1708@gmail.com>2015-05-03 11:10:32 +0200
committertomaka <pierre.krieger1708@gmail.com>2015-05-03 11:10:32 +0200
commite953e3d4ead7931bc32c49bcd9f4a637ef6d5fa7 (patch)
tree2e9a21dd41d06fd0a8cca4ef88e779021a213794 /src/platform/emscripten
parentb9aa741c261b12c3edd7f17d228f0b639f203952 (diff)
parentde7b1aa2ebb8fcf7a9e605bf720d6e644d2fa33a (diff)
downloadglutin-e953e3d4ead7931bc32c49bcd9f4a637ef6d5fa7.tar.gz
glutin-e953e3d4ead7931bc32c49bcd9f4a637ef6d5fa7.zip
Merge pull request #36 from tomaka/emscripten
[WIP] Support for emscripten
Diffstat (limited to 'src/platform/emscripten')
-rw-r--r--src/platform/emscripten/mod.rs49
1 files changed, 49 insertions, 0 deletions
diff --git a/src/platform/emscripten/mod.rs b/src/platform/emscripten/mod.rs
new file mode 100644
index 0000000..f9b011a
--- /dev/null
+++ b/src/platform/emscripten/mod.rs
@@ -0,0 +1,49 @@
+#![cfg(target_os = "emscripten")]
+
+use GlContext;
+
+pub use api::emscripten::{Window, WindowProxy, MonitorID, get_available_monitors};
+pub use api::emscripten::{get_primary_monitor, WaitEventsIterator, PollEventsIterator};
+
+#[cfg(feature = "headless")]
+pub struct HeadlessContext(Window);
+
+#[cfg(feature = "headless")]
+impl HeadlessContext {
+ /// See the docs in the crate root file.
+ pub fn new(builder: BuilderAttribs) -> Result<HeadlessContext, CreationError> {
+ Window::new(builder).map(|w| HeadlessContext(w))
+ }
+}
+
+#[cfg(feature = "headless")]
+impl GlContext for HeadlessContext {
+ unsafe fn make_current(&self) {
+ 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) {
+ self.0.swap_buffers()
+ }
+
+ fn get_api(&self) -> Api {
+ self.0.get_api()
+ }
+
+ fn get_pixel_format(&self) -> PixelFormat {
+ self.0.get_pixel_format()
+ }
+}
+
+#[cfg(feature = "headless")]
+unsafe impl Send for HeadlessContext {}
+#[cfg(feature = "headless")]
+unsafe impl Sync for HeadlessContext {}