]> git.sesse.net Git - vlc/commitdiff
XCB/window: do not depend on xcb-aux for one trivial function call
authorRémi Denis-Courmont <remi@remlab.net>
Wed, 13 May 2009 20:13:10 +0000 (23:13 +0300)
committerRémi Denis-Courmont <remi@remlab.net>
Wed, 13 May 2009 20:13:10 +0000 (23:13 +0300)
configure.ac
modules/video_output/xcb/window.c

index be6e24cdd612620160f5e822355f4e47d8e3fb9f..fea513b45ef063078cec9d7f17f05dabb8f1e90c 100644 (file)
@@ -4176,7 +4176,6 @@ AS_IF([test "${enable_xcb}" != "no"], [
   ])
 
   dnl xcb-utils
-  PKG_CHECK_MODULES(XCB_AUX, [xcb-aux])
   PKG_CHECK_MODULES(XCB_KEYSYMS, [xcb-keysyms])
 
   VLC_ADD_PLUGIN([xcb])
index 6b313519f2a2471e911d32e659169aaef3bf2ec0..dfc5020daaa3c8fdcdc5fe84d7ef8d4b73dcc488 100644 (file)
@@ -31,7 +31,6 @@
 #include <limits.h> /* HOST_NAME_MAX */
 
 #include <xcb/xcb.h>
-#include <xcb/xcb_aux.h>
 typedef xcb_atom_t Atom;
 #include <X11/Xatom.h> /* XA_WM_NAME */
 
@@ -140,8 +139,26 @@ static int Open (vlc_object_t *obj)
     if (xcb_connection_has_error (conn) /*== NULL*/)
         goto error;
 
+    /* Find configured screen */
+    const xcb_setup_t *setup = xcb_get_setup (conn);
+    xcb_screen_t *scr = NULL;
+    for (xcb_screen_iterator_t i = xcb_setup_roots_iterator (setup);
+         i.rem > 0; xcb_screen_next (&i))
+    {
+        if (snum == 0)
+        {
+            scr = i.data;
+            break;
+        }
+        snum--;
+    }
+    if (scr == NULL)
+    {
+        msg_Err (wnd, "bad X11 screen number");
+        goto error;
+    }
+
     /* Create window */
-    xcb_screen_t *scr = xcb_aux_get_screen (conn, snum);
     const uint32_t mask = XCB_CW_BACK_PIXEL | XCB_CW_EVENT_MASK;
     uint32_t values[2] = {
         /* XCB_CW_BACK_PIXEL */