From 8c6a27d42615fc97b1aed31c20c3aff3d25c88d4 Mon Sep 17 00:00:00 2001 From: Pierre Krieger Date: Fri, 25 Sep 2015 18:04:55 +0200 Subject: [PATCH] Add an `os` module containing platform-specific traits --- src/api/x11/window.rs | 10 ++++++++++ src/lib.rs | 31 ++++++++++++++++++++++++++++++- src/os/mod.rs | 9 +++++++++ src/os/unix.rs | 40 ++++++++++++++++++++++++++++++++++++++++ src/os/windows.rs | 21 +++++++++++++++++++++ src/window.rs | 31 +++---------------------------- 6 files changed, 113 insertions(+), 29 deletions(-) create mode 100644 src/os/mod.rs create mode 100644 src/os/unix.rs create mode 100644 src/os/windows.rs diff --git a/src/api/x11/window.rs b/src/api/x11/window.rs index 50dd5057..cf7854e1 100644 --- a/src/api/x11/window.rs +++ b/src/api/x11/window.rs @@ -658,11 +658,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 diff --git a/src/lib.rs b/src/lib.rs index 8e54560a..a9c9befc 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -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 00000000..251a8d46 --- /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 00000000..4fef6efb --- /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 00000000..e9ab0567 --- /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 d9386dfa..7a87806d 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]