]> git.sur5r.net Git - i3/i3/blobdiff - include/xinerama.h
add xcb_set_window_rect which configures a window according to a Rect
[i3/i3] / include / xinerama.h
index 99ee01613bdb9c726bc8ae42c025c4074a043111..135ab1ab25e4c69d4d76f37c576bd10556eb7a10 100644 (file)
 #define _XINERAMA_H
 
 TAILQ_HEAD(screens_head, Screen);
-extern struct screens_head virtual_screens;
+extern struct screens_head *virtual_screens;
 
+/**
+ * Returns true if both screen objects describe the same screen (checks their
+ * size and position).
+ *
+ */
+bool screens_are_equal(i3Screen *screen1, i3Screen *screen2);
+
+/**
+ * We have just established a connection to the X server and need the initial
+ * Xinerama information to setup workspaces for each screen.
+ *
+ */
 void initialize_xinerama(xcb_connection_t *conn);
-i3Screen *get_screen_at(int x, int y);
+
+/**
+ * This is called when the rootwindow receives a configure_notify event and
+ * therefore the number/position of the Xinerama screens could have changed.
+ *
+ */
+void xinerama_requery_screens(xcb_connection_t *conn);
+
+/**
+ * Looks in virtual_screens for the i3Screen whose start coordinates are x, y
+ *
+ */
+i3Screen *get_screen_at(int x, int y, struct screens_head *screenlist);
+
+/**
+ * Looks in virtual_screens for the i3Screen which contains coordinates x, y
+ *
+ */
 i3Screen *get_screen_containing(int x, int y);
 
+/**
+ * Gets the screen which is the last one in the given direction, for example
+ * the screen on the most bottom when direction == D_DOWN, the screen most
+ * right when direction == D_RIGHT and so on.
+ *
+ * This function always returns a screen.
+ *
+ */
+i3Screen *get_screen_most(direction_t direction, i3Screen *current);
+
 #endif