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

Win32: implement thread return value

parent c84a46bb
...@@ -550,7 +550,7 @@ static unsigned __stdcall vlc_entry (void *p) ...@@ -550,7 +550,7 @@ static unsigned __stdcall vlc_entry (void *p)
vlc_threadvar_set (thread_key, th); vlc_threadvar_set (thread_key, th);
th->killable = true; th->killable = true;
th->entry (th->data); th->data = th->entry (th->data);
vlc_threadvar_cleanup (); vlc_threadvar_cleanup ();
if (th->detached) if (th->detached)
free (th); free (th);
...@@ -628,10 +628,11 @@ void vlc_join (vlc_thread_t th, void **result) ...@@ -628,10 +628,11 @@ void vlc_join (vlc_thread_t th, void **result)
== WAIT_IO_COMPLETION); == WAIT_IO_COMPLETION);
CloseHandle (th->id); CloseHandle (th->id);
assert (result == NULL); /* <- FIXME if ever needed */
#ifdef UNDER_CE #ifdef UNDER_CE
CloseHandle (th->cancel_event); CloseHandle (th->cancel_event);
#endif #endif
if (result != NULL)
*result = th->data;
free (th); free (th);
} }
...@@ -694,6 +695,8 @@ void vlc_testcancel (void) ...@@ -694,6 +695,8 @@ void vlc_testcancel (void)
/* Detached threads cannot be cancelled */ /* Detached threads cannot be cancelled */
assert (!th->detached); assert (!th->detached);
th->data = NULL; /* TODO: special value? */
for (vlc_cleanup_t *p = th->cleaners; p != NULL; p = p->next) for (vlc_cleanup_t *p = th->cleaners; p != NULL; p = p->next)
p->proc (p->data); p->proc (p->data);
vlc_threadvar_cleanup (); vlc_threadvar_cleanup ();
......
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