diff options
author | Antoine Pitrou <solipsis@pitrou.net> | 2014-04-28 19:12:11 (GMT) |
---|---|---|
committer | Antoine Pitrou <solipsis@pitrou.net> | 2014-04-28 19:12:11 (GMT) |
commit | 285a163a4ceba7ef9d307f87e5e691732e52b760 (patch) | |
tree | fbb2ed132b38434f31fa4eeea1bc8ea4eba8a6a8 /Python/thread_foobar.h | |
parent | c695c95626ad776e3e378a376a7752c2bd039326 (diff) | |
download | cpython-285a163a4ceba7ef9d307f87e5e691732e52b760.zip cpython-285a163a4ceba7ef9d307f87e5e691732e52b760.tar.gz cpython-285a163a4ceba7ef9d307f87e5e691732e52b760.tar.bz2 |
Issue #21312: Update the thread_foobar.h template file to include newer threading APIs. Patch by Jack McCracken.
Diffstat (limited to 'Python/thread_foobar.h')
-rw-r--r-- | Python/thread_foobar.h | 63 |
1 files changed, 60 insertions, 3 deletions
diff --git a/Python/thread_foobar.h b/Python/thread_foobar.h index d2b78c5..ea96f9c 100644 --- a/Python/thread_foobar.h +++ b/Python/thread_foobar.h @@ -1,4 +1,3 @@ - /* * Initialization. */ @@ -61,10 +60,18 @@ PyThread_free_lock(PyThread_type_lock lock) int PyThread_acquire_lock(PyThread_type_lock lock, int waitflag) { + return PyThread_acquire_lock_timed(lock, waitflag ? -1 : 0, 0); +} + +PyLockStatus +PyThread_acquire_lock_timed(PyThread_type_lock lock, PY_TIMEOUT_T microseconds, + int intr_flag) +{ int success; - dprintf(("PyThread_acquire_lock(%p, %d) called\n", lock, waitflag)); - dprintf(("PyThread_acquire_lock(%p, %d) -> %d\n", lock, waitflag, success)); + dprintf(("PyThread_acquire_lock_timed(%p, %lld, %d) called\n", lock, microseconds, intr_flag)); + dprintf(("PyThread_acquire_lock_timed(%p, %lld, %d) -> %d\n", + lock, microseconds, intr_flag, success)); return success; } @@ -73,3 +80,53 @@ PyThread_release_lock(PyThread_type_lock lock) { dprintf(("PyThread_release_lock(%p) called\n", lock)); } + +/* The following are only needed if native TLS support exists */ +#define Py_HAVE_NATIVE_TLS + +#ifdef Py_HAVE_NATIVE_TLS +int +PyThread_create_key(void) +{ + int result; + return result; +} + +void +PyThread_delete_key(int key) +{ + +} + +int +PyThread_set_key_value(int key, void *value) +{ + int ok; + + /* A failure in this case returns -1 */ + if (!ok) + return -1; + return 0; +} + +void * +PyThread_get_key_value(int key) +{ + void *result; + + return result; +} + +void +PyThread_delete_key_value(int key) +{ + +} + +void +PyThread_ReInitTLS(void) +{ + +} + +#endif |