]> git.sur5r.net Git - i3/i3/commitdiff
Bugfix: Set focus to where the mouse pointer is when starting (Thanks nutron)
authorMichael Stapelberg <michael@stapelberg.de>
Wed, 17 Aug 2011 11:37:08 +0000 (13:37 +0200)
committerMichael Stapelberg <michael@stapelberg.de>
Wed, 17 Aug 2011 11:37:08 +0000 (13:37 +0200)
Fixes #477

src/main.c

index 39b9ec9a6531df7885198105532aa4e1ef9498a8..90e5eb06b323c06f9208ced7d0820517281e9b4e 100644 (file)
@@ -279,6 +279,7 @@ int main(int argc, char *argv[]) {
     root = root_screen->root;
     root_depth = root_screen->root_depth;
     xcb_get_geometry_cookie_t gcookie = xcb_get_geometry(conn, root);
+    xcb_query_pointer_cookie_t pointercookie = xcb_query_pointer(conn, root);
 
     load_configuration(conn, override_configpath, false);
     if (only_check_config) {
@@ -428,6 +429,20 @@ int main(int argc, char *argv[]) {
         randr_init(&randr_base);
     }
 
+    xcb_query_pointer_reply_t *pointerreply;
+    if (!(pointerreply = xcb_query_pointer_reply(conn, pointercookie, NULL)))
+        die("Could not query pointer position\n");
+
+    DLOG("Pointer at %d, %d\n", pointerreply->root_x, pointerreply->root_y);
+    Output *output = get_output_containing(pointerreply->root_x, pointerreply->root_y);
+    if (!output) {
+        ELOG("ERROR: No screen at (%d, %d), starting on the first screen\n",
+             pointerreply->root_x, pointerreply->root_y);
+        output = get_first_output();
+    }
+
+    con_focus(con_descend_focused(output_get_content(output->con)));
+
     tree_render();
 
     /* Create the UNIX domain socket for IPC */