aboutsummaryrefslogtreecommitdiffstats
path: root/src/x11/monitor.rs
diff options
context:
space:
mode:
authortomaka <pierre.krieger1708@gmail.com>2014-09-19 20:36:50 +0200
committertomaka <pierre.krieger1708@gmail.com>2014-09-19 20:36:50 +0200
commit3ac5f6d115afa3907047a8a55b58c698b47d3b28 (patch)
tree6f5a29b567d863c7e8d42ce46498c575ffdb6151 /src/x11/monitor.rs
parentd8171a0c73921a28b2005030df741ef11a262900 (diff)
parent9b06c973a2569c43ed0c95d72423fe5c3146efdb (diff)
downloadglutin-3ac5f6d115afa3907047a8a55b58c698b47d3b28.tar.gz
glutin-3ac5f6d115afa3907047a8a55b58c698b47d3b28.zip
Merge pull request #38 from tomaka/x11_fullscreen
X11 fullscreen
Diffstat (limited to 'src/x11/monitor.rs')
-rw-r--r--src/x11/monitor.rs55
1 files changed, 55 insertions, 0 deletions
diff --git a/src/x11/monitor.rs b/src/x11/monitor.rs
new file mode 100644
index 0000000..f1b861b
--- /dev/null
+++ b/src/x11/monitor.rs
@@ -0,0 +1,55 @@
+use std::{ptr};
+use super::ffi;
+
+pub struct MonitorID(uint);
+
+pub fn get_available_monitors() -> Vec<MonitorID> {
+ let nb_monitors = unsafe {
+ let display = ffi::XOpenDisplay(ptr::null());
+ if display.is_null() {
+ fail!("get_available_monitors failed");
+ }
+ let nb_monitors = ffi::XScreenCount(display);
+ ffi::XCloseDisplay(display);
+ nb_monitors
+ };
+
+ let mut vec = Vec::new();
+ vec.grow_fn(nb_monitors as uint, |i| MonitorID(i));
+ vec
+}
+
+pub fn get_primary_monitor() -> MonitorID {
+ let primary_monitor = unsafe {
+ let display = ffi::XOpenDisplay(ptr::null());
+ if display.is_null() {
+ fail!("get_available_monitors failed");
+ }
+ let primary_monitor = ffi::XDefaultScreen(display);
+ ffi::XCloseDisplay(display);
+ primary_monitor
+ };
+
+ MonitorID(primary_monitor as uint)
+}
+
+impl MonitorID {
+ pub fn get_name(&self) -> Option<String> {
+ let MonitorID(screen_num) = *self;
+ Some(format!("Monitor #{}", screen_num))
+ }
+
+ pub fn get_dimensions(&self) -> (uint, uint) {
+ let dimensions = unsafe {
+ let display = ffi::XOpenDisplay(ptr::null());
+ let MonitorID(screen_num) = *self;
+ let screen = ffi::XScreenOfDisplay(display, screen_num as i32);
+ let width = ffi::XWidthOfScreen(screen);
+ let height = ffi::XHeightOfScreen(screen);
+ (width as uint, height as uint)
+ };
+
+ dimensions
+ }
+}
+