##// END OF EJS Templates
shelve: directly handle the abort process...
shelve: directly handle the abort process Shelve is currently sub-contracting some of its work to the rebase extension. In order to make shelve more independent and flexible we would like shelve to handle the parent alignment directly. This change starts with the simplest bits, handling the abort process. It turns out we have all the necessary bits in the `shelvestate` file. So we do not need anything from the interrupted rebase. As a nice side effect, a test about missing `shelverebasestate` state file now behave better. Differential Revision: https://phab.mercurial-scm.org/D3688

File last commit:

r37513:b1fb341d default
r38480:61e4cf1b default
Show More
threading.c
75 lines | 1.8 KiB | text/x-c | CLexer
Gregory Szorc
zstd: vendor python-zstandard 0.7.0...
r30895 /**
* Copyright (c) 2016 Tino Reichardt
* All rights reserved.
*
Gregory Szorc
zstandard: vendor python-zstandard 0.9.0...
r37513 * This source code is licensed under both the BSD-style license (found in the
* LICENSE file in the root directory of this source tree) and the GPLv2 (found
* in the COPYING file in the root directory of this source tree).
Gregory Szorc
zstd: vendor python-zstandard 0.7.0...
r30895 *
* You can contact the author at:
* - zstdmt source repository: https://github.com/mcmilk/zstdmt
*/
/**
* This file will hold wrapper for systems, which do not support pthreads
*/
Gregory Szorc
zstandard: vendor python-zstandard 0.9.0...
r37513 /* create fake symbol to avoid empty trnaslation unit warning */
int g_ZSTD_threading_useles_symbol;
Gregory Szorc
zstd: vendor python-zstandard 0.7.0...
r30895
#if defined(ZSTD_MULTITHREAD) && defined(_WIN32)
/**
* Windows minimalist Pthread Wrapper, based on :
* http://www.cse.wustl.edu/~schmidt/win32-cv-1.html
*/
/* === Dependencies === */
#include <process.h>
#include <errno.h>
#include "threading.h"
/* === Implementation === */
static unsigned __stdcall worker(void *arg)
{
Gregory Szorc
zstandard: vendor python-zstandard 0.9.0...
r37513 ZSTD_pthread_t* const thread = (ZSTD_pthread_t*) arg;
Gregory Szorc
zstd: vendor python-zstandard 0.7.0...
r30895 thread->arg = thread->start_routine(thread->arg);
return 0;
}
Gregory Szorc
zstandard: vendor python-zstandard 0.9.0...
r37513 int ZSTD_pthread_create(ZSTD_pthread_t* thread, const void* unused,
Gregory Szorc
zstd: vendor python-zstandard 0.7.0...
r30895 void* (*start_routine) (void*), void* arg)
{
(void)unused;
thread->arg = arg;
thread->start_routine = start_routine;
thread->handle = (HANDLE) _beginthreadex(NULL, 0, worker, thread, 0, NULL);
if (!thread->handle)
return errno;
else
return 0;
}
Gregory Szorc
zstandard: vendor python-zstandard 0.9.0...
r37513 int ZSTD_pthread_join(ZSTD_pthread_t thread, void **value_ptr)
Gregory Szorc
zstd: vendor python-zstandard 0.7.0...
r30895 {
DWORD result;
Gregory Szorc
zstandard: vendor python-zstandard 0.9.0...
r37513 if (!thread.handle) return 0;
Gregory Szorc
zstd: vendor python-zstandard 0.7.0...
r30895
Gregory Szorc
zstandard: vendor python-zstandard 0.9.0...
r37513 result = WaitForSingleObject(thread.handle, INFINITE);
Gregory Szorc
zstd: vendor python-zstandard 0.7.0...
r30895 switch (result) {
case WAIT_OBJECT_0:
Gregory Szorc
zstandard: vendor python-zstandard 0.9.0...
r37513 if (value_ptr) *value_ptr = thread.arg;
Gregory Szorc
zstd: vendor python-zstandard 0.7.0...
r30895 return 0;
case WAIT_ABANDONED:
return EINVAL;
default:
return GetLastError();
}
}
#endif /* ZSTD_MULTITHREAD */