From 5741991b1a1e4dbd69b1bd767938e8552faae4ed Mon Sep 17 00:00:00 2001 From: Piotr Caban Date: Thu, 30 Mar 2017 22:48:03 +0200 Subject: [PATCH] msvcrt: Add CurrentScheduler::Detach implementation. Signed-off-by: Piotr Caban Signed-off-by: Alexandre Julliard --- dlls/msvcrt/scheduler.c | 25 ++++++++++++++++++++++++- 1 file changed, 24 insertions(+), 1 deletion(-) diff --git a/dlls/msvcrt/scheduler.c b/dlls/msvcrt/scheduler.c index 8487752a03b..3c94bd33c8f 100644 --- a/dlls/msvcrt/scheduler.c +++ b/dlls/msvcrt/scheduler.c @@ -802,7 +802,30 @@ void __cdecl CurrentScheduler_Create(const SchedulerPolicy *policy) /* ?Detach@CurrentScheduler@Concurrency@@SAXXZ */ void __cdecl CurrentScheduler_Detach(void) { - FIXME("() stub\n"); + ExternalContextBase *context = (ExternalContextBase*)try_get_current_context(); + + TRACE("()\n"); + + if(!context) + throw_exception(EXCEPTION_IMPROPER_SCHEDULER_DETACH, 0, NULL); + + if(context->context.vtable != &MSVCRT_ExternalContextBase_vtable) { + ERR("unknown context set\n"); + return; + } + + if(!context->scheduler.next) + throw_exception(EXCEPTION_IMPROPER_SCHEDULER_DETACH, 0, NULL); + + call_Scheduler_Release(context->scheduler.scheduler); + if(!context->scheduler.next) { + context->scheduler.scheduler = NULL; + }else { + struct scheduler_list *entry = context->scheduler.next; + context->scheduler.scheduler = entry->scheduler; + context->scheduler.next = entry->next; + MSVCRT_operator_delete(entry); + } } static void create_default_scheduler(void)