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] | 
