diff options
author | Pierre Krieger <pierre.krieger1708@gmail.com> | 2015-09-25 18:04:55 +0200 |
---|---|---|
committer | Pierre Krieger <pierre.krieger1708@gmail.com> | 2015-10-03 09:53:37 +0200 |
commit | 8c6a27d42615fc97b1aed31c20c3aff3d25c88d4 (patch) | |
tree | 1e08975b0bbfa982ead924ac67b2c873ec55ea53 | |
parent | 9fccb2e06e15f56f270da4f7cbd5fa39b49b6826 (diff) | |
download | glutin-8c6a27d42615fc97b1aed31c20c3aff3d25c88d4.tar.gz glutin-8c6a27d42615fc97b1aed31c20c3aff3d25c88d4.zip |
Add an `os` module containing platform-specific traits
-rw-r--r-- | src/api/x11/window.rs | 10 | ||||
-rw-r--r-- | src/lib.rs | 31 | ||||
-rw-r--r-- | src/os/mod.rs | 9 | ||||
-rw-r--r-- | src/os/unix.rs | 40 | ||||
-rw-r--r-- | src/os/windows.rs | 21 | ||||
-rw-r--r-- | src/window.rs | 31 |
6 files changed, 113 insertions, 29 deletions
diff --git a/src/api/x11/window.rs b/src/api/x11/window.rs index 50dd505..cf7854e 100644 --- a/src/api/x11/window.rs +++ b/src/api/x11/window.rs @@ -659,11 +659,21 @@ impl Window { } #[inline] + pub fn get_xlib_display(&self) -> *mut libc::c_void { + self.x.display.display as *mut libc::c_void + } + + #[inline] pub fn platform_display(&self) -> *mut libc::c_void { self.x.display.display as *mut libc::c_void } #[inline] + pub fn get_xlib_window(&self) -> *mut libc::c_void { + self.x.window as *mut libc::c_void + } + + #[inline] pub fn platform_window(&self) -> *mut libc::c_void { self.x.window as *mut libc::c_void } @@ -61,7 +61,7 @@ extern crate x11_dl; pub use events::*; pub use headless::{HeadlessRendererBuilder, HeadlessContext}; #[cfg(feature = "window")] -pub use window::{WindowBuilder, Window, WindowProxy, PollEventsIterator, WaitEventsIterator}; +pub use window::{WindowBuilder, WindowProxy, PollEventsIterator, WaitEventsIterator}; #[cfg(feature = "window")] pub use window::{AvailableMonitorsIter, MonitorId, get_available_monitors, get_primary_monitor}; #[cfg(feature = "window")] @@ -78,6 +78,35 @@ mod headless; #[cfg(feature = "window")] mod window; +pub mod os; + +/// Represents an OpenGL context and the Window or environment around it. +/// +/// # Example +/// +/// ```ignore +/// let window = Window::new().unwrap(); +/// +/// unsafe { window.make_current() }; +/// +/// loop { +/// for event in window.poll_events() { +/// match(event) { +/// // process events here +/// _ => () +/// } +/// } +/// +/// // draw everything here +/// +/// window.swap_buffers(); +/// std::old_io::timer::sleep(17); +/// } +/// ``` +pub struct Window { + window: platform::Window, +} + /// Trait that describes objects that have access to an OpenGL context. pub trait GlContext { /// Sets the context as the current context. diff --git a/src/os/mod.rs b/src/os/mod.rs new file mode 100644 index 0000000..251a8d4 --- /dev/null +++ b/src/os/mod.rs @@ -0,0 +1,9 @@ +//! Contains traits with platform-specific methods in them. +//! +//! Contains the follow modules: +//! +//! - `unix` +//! - `windows` +//! +pub mod unix; +pub mod windows; diff --git a/src/os/unix.rs b/src/os/unix.rs new file mode 100644 index 0000000..4fef6ef --- /dev/null +++ b/src/os/unix.rs @@ -0,0 +1,40 @@ +#![cfg(any(target_os = "linux", target_os = "dragonfly", target_os = "freebsd"))] + +use libc; +use Window; +use platform::Window as LinuxWindow; + +/// Additional methods on `Window` that are specific to unix. +pub trait WindowExt { + /// Returns a pointer to the `Window` object of xlib that is used by this window. + /// + /// Returns `None` if the window doesn't use xlib (if it uses wayland for example). + /// + /// The pointer will become invalid when the glutin `Window` is destroyed. + fn get_xlib_window(&self) -> Option<*mut libc::c_void>; + + /// Returns a pointer to the `Display` object of xlib that is used by this window. + /// + /// Returns `None` if the window doesn't use xlib (if it uses wayland for example). + /// + /// The pointer will become invalid when the glutin `Window` is destroyed. + fn get_xlib_display(&self) -> Option<*mut libc::c_void>; +} + +impl WindowExt for Window { + #[inline] + fn get_xlib_window(&self) -> Option<*mut libc::c_void> { + match self.window { + LinuxWindow::X(ref w) => Some(w.get_xlib_window()), + _ => None + } + } + + #[inline] + fn get_xlib_display(&self) -> Option<*mut libc::c_void> { + match self.window { + LinuxWindow::X(ref w) => Some(w.get_xlib_window()), + _ => None + } + } +} diff --git a/src/os/windows.rs b/src/os/windows.rs new file mode 100644 index 0000000..e9ab056 --- /dev/null +++ b/src/os/windows.rs @@ -0,0 +1,21 @@ +#![cfg(target_os = "windows")] + +use libc; +use Window; + +/// Additional methods on `Window` that are specific to unix. +pub trait WindowExt { + /// Returns a pointer to the `Window` object of xlib that is used by this window. + /// + /// Returns `None` if the window doesn't use xlib (if it uses wayland for example). + /// + /// The pointer will become invalid when the glutin `Window` is destroyed. + fn get_hwnd(&self) -> *mut libc::c_void; +} + +impl WindowExt for Window { + #[inline] + fn get_hwnd(&self) -> *mut libc::c_void { + self.window.platform_window() + } +} diff --git a/src/window.rs b/src/window.rs index d9386df..7a87806 100644 --- a/src/window.rs +++ b/src/window.rs @@ -14,6 +14,7 @@ use MouseCursor; use PixelFormat; use PixelFormatRequirements; use Robustness; +use Window; use WindowAttributes; use native_monitor::NativeMonitorId; @@ -224,32 +225,6 @@ impl<'a> WindowBuilder<'a> { } } -/// Represents an OpenGL context and the Window or environment around it. -/// -/// # Example -/// -/// ```ignore -/// let window = Window::new().unwrap(); -/// -/// unsafe { window.make_current() }; -/// -/// loop { -/// for event in window.poll_events() { -/// match(event) { -/// // process events here -/// _ => () -/// } -/// } -/// -/// // draw everything here -/// -/// window.swap_buffers(); -/// std::old_io::timer::sleep(17); -/// } -/// ``` -pub struct Window { - window: platform::Window, -} impl Default for Window { #[inline] @@ -439,7 +414,7 @@ impl Window { self.window.swap_buffers() } - /// Gets the native platform specific display for this window. + /// DEPRECATED. Gets the native platform specific display for this window. /// This is typically only required when integrating with /// other libraries that need this information. #[inline] @@ -447,7 +422,7 @@ impl Window { self.window.platform_display() } - /// Gets the native platform specific window handle. This is + /// DEPRECATED. Gets the native platform specific window handle. This is /// typically only required when integrating with other libraries /// that need this information. #[inline] |