diff options
| author | Guido van Rossum <guido@python.org> | 2001-10-16 21:13:49 +0000 | 
|---|---|---|
| committer | Guido van Rossum <guido@python.org> | 2001-10-16 21:13:49 +0000 | 
| commit | 3c28863e081986a232d4d2bba3cd9b63e14263c0 (patch) | |
| tree | 480d600501cb10db20d12907bf27644c0732269b /Python/thread_nt.h | |
| parent | 6f543b606d595fa16ce1ef0e636ca456dabc2212 (diff) | |
| download | cpython-git-3c28863e081986a232d4d2bba3cd9b63e14263c0.tar.gz | |
Partial patch from SF #452266, by Jason Petrone.
This changes Pythread_start_thread() to return the thread ID, or -1
for an error.  (It's technically an incompatible API change, but I
doubt anyone calls it.)
Diffstat (limited to 'Python/thread_nt.h')
| -rw-r--r-- | Python/thread_nt.h | 48 | 
1 files changed, 45 insertions, 3 deletions
| diff --git a/Python/thread_nt.h b/Python/thread_nt.h index 1d276274eb..21aac29a49 100644 --- a/Python/thread_nt.h +++ b/Python/thread_nt.h @@ -5,6 +5,7 @@  #include <windows.h>  #include <limits.h>  #include <process.h> +#include <Python.h>  typedef struct NRMUTEX {  	LONG   owned ; @@ -12,6 +13,8 @@ typedef struct NRMUTEX {  	HANDLE hevent ;  } NRMUTEX, *PNRMUTEX ; +/* dictionary to correlate thread ids with the handle needed to terminate them*/ +static PyObject *threads = NULL;  typedef PVOID WINAPI interlocked_cmp_xchg_t(PVOID *dest, PVOID exc, PVOID comperand) ; @@ -145,28 +148,67 @@ long PyThread_get_thread_ident(void);   */  static void PyThread__init_thread(void)  { +	threads = PyDict_New();  }  /*   * Thread support.   */ -int PyThread_start_new_thread(void (*func)(void *), void *arg) + +typedef struct { +	void (*func)(void*); +	void *arg;			 +	long id; +	HANDLE done; +} callobj; + +static int +bootstrap(void *call) +{ +	callobj *obj = (callobj*)call; +	/* copy callobj since other thread might free it before we're done */ +	void (*func)(void*) = obj->func; +	void *arg = obj->arg; + +	obj->id = PyThread_get_thread_ident(); +	ReleaseSemaphore(obj->done, 1, NULL); +	func(arg); +	return 0; +} + +long PyThread_start_new_thread(void (*func)(void *), void *arg)  {  	unsigned long rv;  	int success = 0; +	callobj *obj; +	int id; +	PyObject *key, *val;  	dprintf(("%ld: PyThread_start_new_thread called\n", PyThread_get_thread_ident()));  	if (!initialized)  		PyThread_init_thread(); -	rv = _beginthread(func, 0, arg); /* use default stack size */ +	obj = malloc(sizeof(callobj));  +	obj->func = func; +	obj->arg = arg; +	obj->done = CreateSemaphore(NULL, 0, 1, NULL); + +	rv = _beginthread(func, 0, obj); /* use default stack size */  	if (rv != (unsigned long)-1) {  		success = 1;  		dprintf(("%ld: PyThread_start_new_thread succeeded: %p\n", PyThread_get_thread_ident(), rv));  	} -	return success; +	/* wait for thread to initialize and retrieve id */ +	WaitForSingleObject(obj->done, 5000);  /* maybe INFINITE instead of 5000? */ +	CloseHandle((HANDLE)obj->done); +	key = PyLong_FromLong(obj->id); +	val = PyLong_FromLong((long)rv); +	PyDict_SetItem(threads, key, val); +	id = obj->id; +	free(obj); +	return id;  }  /* | 
