Commit b79cadf8 authored by Rémi Denis-Courmont's avatar Rémi Denis-Courmont

XCB Window: ugly hack to get focus with Matchbox window manager...

...and derivatives
parent dbbe0df4
...@@ -90,6 +90,8 @@ vlc_module_end () ...@@ -90,6 +90,8 @@ vlc_module_end ()
static int Control (vout_window_t *, int, va_list ap); static int Control (vout_window_t *, int, va_list ap);
static void *Thread (void *); static void *Thread (void *);
#define MATCHBOX_HACK 1 /* Matchbox focus hack */
struct vout_window_sys_t struct vout_window_sys_t
{ {
xcb_connection_t *conn; xcb_connection_t *conn;
...@@ -100,6 +102,9 @@ struct vout_window_sys_t ...@@ -100,6 +102,9 @@ struct vout_window_sys_t
xcb_atom_t wm_state; xcb_atom_t wm_state;
xcb_atom_t wm_state_above; xcb_atom_t wm_state_above;
xcb_atom_t wm_state_fullscreen; xcb_atom_t wm_state_fullscreen;
#ifdef MATCHBOX_HACK
xcb_atom_t mb_current_app_window;
#endif
}; };
/** Set an X window property from a nul-terminated string */ /** Set an X window property from a nul-terminated string */
...@@ -185,10 +190,17 @@ static void CacheAtoms (vout_window_sys_t *p_sys) ...@@ -185,10 +190,17 @@ static void CacheAtoms (vout_window_sys_t *p_sys)
wm_state_ck = intern_string (conn, "_NET_WM_STATE"); wm_state_ck = intern_string (conn, "_NET_WM_STATE");
wm_state_above_ck = intern_string (conn, "_NET_WM_STATE_ABOVE"); wm_state_above_ck = intern_string (conn, "_NET_WM_STATE_ABOVE");
wm_state_fs_ck = intern_string (conn, "_NET_WM_STATE_FULLSCREEN"); wm_state_fs_ck = intern_string (conn, "_NET_WM_STATE_FULLSCREEN");
#ifdef MATCHBOX_HACK
xcb_intern_atom_cookie_t mb_current_app_window;
mb_current_app_window = intern_string (conn, "_MB_CURRENT_APP_WINDOW");
#endif
p_sys->wm_state = get_atom (conn, wm_state_ck); p_sys->wm_state = get_atom (conn, wm_state_ck);
p_sys->wm_state_above = get_atom (conn, wm_state_above_ck); p_sys->wm_state_above = get_atom (conn, wm_state_above_ck);
p_sys->wm_state_fullscreen = get_atom (conn, wm_state_fs_ck); p_sys->wm_state_fullscreen = get_atom (conn, wm_state_fs_ck);
#ifdef MATCHBOX_HACK
p_sys->mb_current_app_window = get_atom (conn, mb_current_app_window);
#endif
} }
/** /**
...@@ -302,6 +314,12 @@ static int Open (vlc_object_t *obj) ...@@ -302,6 +314,12 @@ static int Open (vlc_object_t *obj)
xcb_atom_t wm_window_role = get_atom (conn, wm_window_role_ck); xcb_atom_t wm_window_role = get_atom (conn, wm_window_role_ck);
set_ascii_prop (conn, window, wm_window_role, "vlc-video"); set_ascii_prop (conn, window, wm_window_role, "vlc-video");
#ifdef MATCHBOX_HACK
uint32_t value = XCB_EVENT_MASK_PROPERTY_CHANGE;
xcb_change_window_attributes (conn, scr->root,
XCB_CW_EVENT_MASK, &value);
#endif
/* Make the window visible */ /* Make the window visible */
xcb_map_window (conn, window); xcb_map_window (conn, window);
...@@ -314,8 +332,11 @@ static int Open (vlc_object_t *obj) ...@@ -314,8 +332,11 @@ static int Open (vlc_object_t *obj)
&& vlc_clone (&p_sys->thread, Thread, wnd, VLC_THREAD_PRIORITY_LOW)) && vlc_clone (&p_sys->thread, Thread, wnd, VLC_THREAD_PRIORITY_LOW))
DestroyKeyHandler (p_sys->keys); DestroyKeyHandler (p_sys->keys);
#ifdef MATCHBOX_HACK
xcb_set_input_focus (p_sys->conn, XCB_INPUT_FOCUS_POINTER_ROOT,
wnd->handle.xid, XCB_CURRENT_TIME);
#endif
xcb_flush (conn); /* Make sure map_window is sent (should be useless) */ xcb_flush (conn); /* Make sure map_window is sent (should be useless) */
return VLC_SUCCESS; return VLC_SUCCESS;
error: error:
...@@ -368,6 +389,33 @@ static void *Thread (void *data) ...@@ -368,6 +389,33 @@ static void *Thread (void *data)
{ {
if (ProcessKeyEvent (p_sys->keys, ev) == 0) if (ProcessKeyEvent (p_sys->keys, ev) == 0)
continue; continue;
#ifdef MATCHBOX_HACK
if ((ev->response_type & 0x7f) == XCB_PROPERTY_NOTIFY)
{
const xcb_property_notify_event_t *pne =
(xcb_property_notify_event_t *)ev;
if (pne->atom == p_sys->mb_current_app_window
&& pne->state == XCB_PROPERTY_NEW_VALUE)
{
xcb_get_property_reply_t *r =
xcb_get_property_reply (conn,
xcb_get_property (conn, 0, pne->window, pne->atom,
XA_WINDOW, 0, 4), NULL);
if (r != NULL
&& !memcmp (xcb_get_property_value (r), &wnd->handle.xid,
4))
{
msg_Dbg (wnd, "asking Matchbox for input focus");
xcb_set_input_focus (conn,
XCB_INPUT_FOCUS_POINTER_ROOT,
wnd->handle.xid, pne->time);
xcb_flush (conn);
}
free (r);
}
}
else
#endif
msg_Dbg (wnd, "unhandled event: %"PRIu8, ev->response_type); msg_Dbg (wnd, "unhandled event: %"PRIu8, ev->response_type);
free (ev); free (ev);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment