static void Register( intf_thread_t *p_intf );
static void Unregister( intf_thread_t *p_intf );
static void *Thread( void *p_data );
+static int X11ErrorHandler( Display *, XErrorEvent * );
/*****************************************************************************
* Open:
Display *p_display = XOpenDisplay( NULL );
if( !p_display )
return VLC_EGENERIC;
+ XSetErrorHandler( X11ErrorHandler );
p_intf->p_sys = p_sys = malloc( sizeof(*p_sys) );
if( !p_sys )
}
/*****************************************************************************
- * Thread:
+ *
*****************************************************************************/
+static int X11ErrorHandler( Display *p_display, XErrorEvent *p_event )
+{
+#if 0
+ char psz_txt[1024];
+
+ XGetErrorText( p_display, p_event->error_code, psz_txt, sizeof(psz_txt) );
+ fprintf( stderr,
+ "[????????] globalhotkeys interface error: X11 request %u.%u failed "
+ "with error code %u:\n %s\n",
+ p_event->request_code, p_event->minor_code, p_event->error_code, psz_txt );
+#else
+ VLC_UNUSED(p_display); VLC_UNUSED(p_event);
+#endif
+ /* Ignore them */
+ return 0;
+}
static unsigned GetModifier( Display *p_display, KeySym sym )
{
static const unsigned pi_mask[8] = {
}
}
- vlc_restorecancel( canc );
return NULL;
}
* Always load the hotkeys interface if it exists
*/
libvlc_InternalAddIntf( p_libvlc, "hotkeys,none" );
-#ifdef WIN32
- libvlc_InternalAddIntf( p_libvlc, "globalhotkeys,none" );
-#endif
+ if( module_exists( "globalhotkeys" ) )
+ libvlc_InternalAddIntf( p_libvlc, "globalhotkeys,none" );
#ifdef HAVE_DBUS
/* loads dbus control interface if in one-instance mode