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

xlib: don't abort if autodetection fails

(cherry picked from commit 3884bc644750dff5d9c29ca4d2c879ab9e8fd5eb)
parent d206be7b
...@@ -28,29 +28,29 @@ ...@@ -28,29 +28,29 @@
static inline bool vlc_xlib_init (vlc_object_t *obj) static inline bool vlc_xlib_init (vlc_object_t *obj)
{ {
if (!var_InheritBool (obj, "xlib"))
return false;
bool ok = false; bool ok = false;
if (var_InheritBool (obj, "xlib")) /* XInitThreads() can be called multiple times,
{ * but it is not reentrant, so we need this global lock. */
/* XInitThreads() can be called multiple times, vlc_global_lock (VLC_XLIB_MUTEX);
* but it is not reentrant, so we need this global lock. */
vlc_global_lock (VLC_XLIB_MUTEX); if (_Xglobal_lock == NULL && unlikely(_XErrorFunction != NULL))
/* (_Xglobal_lock == NULL) => Xlib threads not initialized */
if (_Xglobal_lock == NULL && unlikely(_XErrorFunction != NULL)) /* (_XErrorFunction != NULL) => Xlib already in use */
{ fprintf (stderr, "%s:%u:%s: Xlib not initialized for threads.\n"
/* (_Xglobal_lock == NULL) => Xlib threads not initialized */ "This process is probably using LibVLC incorrectly.\n"
/* (_XErrorFunction != NULL) => Xlib already in use */ "Pass \"--no-xlib\" to libvlc_new() to fix this.\n",
fprintf (stderr, "%s:%u:%s: Xlib not initialized for threads.\n" __FILE__, __LINE__, __func__);
"This process is probably using LibVLC incorrectly.\n" else if (XInitThreads ())
"Pass \"--no-xlib\" to libvlc_new() to fix this.\n", ok = true;
__FILE__, __LINE__, __func__);
/* Initiate core meltdown */ vlc_global_unlock (VLC_XLIB_MUTEX);
abort ();
} if (!ok)
else msg_Err (obj, "Xlib not initialized for threads");
ok = XInitThreads () != 0;
vlc_global_unlock (VLC_XLIB_MUTEX);
}
return ok; return ok;
} }
......
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