404

[ Avaa Bypassed ]




Upload:

Command:

elspacio@3.139.69.53: ~ $
#ifndef Py_PYTHREAD_H
#define Py_PYTHREAD_H

typedef void *PyThread_type_lock;

#ifdef __cplusplus
extern "C" {
#endif

/* Return status codes for Python lock acquisition.  Chosen for maximum
 * backwards compatibility, ie failure -> 0, success -> 1.  */
typedef enum PyLockStatus {
    PY_LOCK_FAILURE = 0,
    PY_LOCK_ACQUIRED = 1,
    PY_LOCK_INTR
} PyLockStatus;

#ifndef Py_LIMITED_API
#define PYTHREAD_INVALID_THREAD_ID ((unsigned long)-1)
#endif

PyAPI_FUNC(void) PyThread_init_thread(void);
PyAPI_FUNC(unsigned long) PyThread_start_new_thread(void (*)(void *), void *);
PyAPI_FUNC(void) _Py_NO_RETURN PyThread_exit_thread(void);
PyAPI_FUNC(unsigned long) PyThread_get_thread_ident(void);

#if defined(__APPLE__) || defined(__linux__) || defined(__FreeBSD__) || defined(__OpenBSD__) || defined(__NetBSD__) || defined(_WIN32) || defined(_AIX)
#define PY_HAVE_THREAD_NATIVE_ID
PyAPI_FUNC(unsigned long) PyThread_get_thread_native_id(void);
#endif

PyAPI_FUNC(PyThread_type_lock) PyThread_allocate_lock(void);
PyAPI_FUNC(void) PyThread_free_lock(PyThread_type_lock);
PyAPI_FUNC(int) PyThread_acquire_lock(PyThread_type_lock, int);
#define WAIT_LOCK       1
#define NOWAIT_LOCK     0

#ifndef Py_LIMITED_API
#ifdef HAVE_FORK
/* Private function to reinitialize a lock at fork in the child process.
   Reset the lock to the unlocked state.
   Return 0 on success, return -1 on error. */
PyAPI_FUNC(int) _PyThread_at_fork_reinit(PyThread_type_lock *lock);
#endif  /* HAVE_FORK */
#endif  /* !Py_LIMITED_API */

/* PY_TIMEOUT_T is the integral type used to specify timeouts when waiting
   on a lock (see PyThread_acquire_lock_timed() below).
   PY_TIMEOUT_MAX is the highest usable value (in microseconds) of that
   type, and depends on the system threading API.

   NOTE: this isn't the same value as `_thread.TIMEOUT_MAX`.  The _thread
   module exposes a higher-level API, with timeouts expressed in seconds
   and floating-point numbers allowed.
*/
#define PY_TIMEOUT_T long long

#if defined(_POSIX_THREADS)
   /* PyThread_acquire_lock_timed() uses _PyTime_FromNanoseconds(us * 1000),
      convert microseconds to nanoseconds. */
#  define PY_TIMEOUT_MAX (LLONG_MAX / 1000)
#elif defined (NT_THREADS)
   /* In the NT API, the timeout is a DWORD and is expressed in milliseconds */
#  if 0xFFFFFFFFLL * 1000 < LLONG_MAX
#    define PY_TIMEOUT_MAX (0xFFFFFFFFLL * 1000)
#  else
#    define PY_TIMEOUT_MAX LLONG_MAX
#  endif
#else
#  define PY_TIMEOUT_MAX LLONG_MAX
#endif


/* If microseconds == 0, the call is non-blocking: it returns immediately
   even when the lock can't be acquired.
   If microseconds > 0, the call waits up to the specified duration.
   If microseconds < 0, the call waits until success (or abnormal failure)

   microseconds must be less than PY_TIMEOUT_MAX. Behaviour otherwise is
   undefined.

   If intr_flag is true and the acquire is interrupted by a signal, then the
   call will return PY_LOCK_INTR.  The caller may reattempt to acquire the
   lock.
*/
PyAPI_FUNC(PyLockStatus) PyThread_acquire_lock_timed(PyThread_type_lock,
                                                     PY_TIMEOUT_T microseconds,
                                                     int intr_flag);

PyAPI_FUNC(void) PyThread_release_lock(PyThread_type_lock);

PyAPI_FUNC(size_t) PyThread_get_stacksize(void);
PyAPI_FUNC(int) PyThread_set_stacksize(size_t);

#if !defined(Py_LIMITED_API) || Py_LIMITED_API+0 >= 0x03030000
PyAPI_FUNC(PyObject*) PyThread_GetInfo(void);
#endif


/* Thread Local Storage (TLS) API
   TLS API is DEPRECATED.  Use Thread Specific Storage (TSS) API.

   The existing TLS API has used int to represent TLS keys across all
   platforms, but it is not POSIX-compliant.  Therefore, the new TSS API uses
   opaque data type to represent TSS keys to be compatible (see PEP 539).
*/
Py_DEPRECATED(3.7) PyAPI_FUNC(int) PyThread_create_key(void);
Py_DEPRECATED(3.7) PyAPI_FUNC(void) PyThread_delete_key(int key);
Py_DEPRECATED(3.7) PyAPI_FUNC(int) PyThread_set_key_value(int key,
                                                          void *value);
Py_DEPRECATED(3.7) PyAPI_FUNC(void *) PyThread_get_key_value(int key);
Py_DEPRECATED(3.7) PyAPI_FUNC(void) PyThread_delete_key_value(int key);

/* Cleanup after a fork */
Py_DEPRECATED(3.7) PyAPI_FUNC(void) PyThread_ReInitTLS(void);


#if !defined(Py_LIMITED_API) || Py_LIMITED_API+0 >= 0x03070000
/* New in 3.7 */
/* Thread Specific Storage (TSS) API */

typedef struct _Py_tss_t Py_tss_t;  /* opaque */

#ifndef Py_LIMITED_API
#if defined(_POSIX_THREADS)
    /* Darwin needs pthread.h to know type name the pthread_key_t. */
#   include <pthread.h>
#   define NATIVE_TSS_KEY_T     pthread_key_t
#elif defined(NT_THREADS)
    /* In Windows, native TSS key type is DWORD,
       but hardcode the unsigned long to avoid errors for include directive.
    */
#   define NATIVE_TSS_KEY_T     unsigned long
#else
#   error "Require native threads. See https://bugs.python.org/issue31370"
#endif

/* When Py_LIMITED_API is not defined, the type layout of Py_tss_t is
   exposed to allow static allocation in the API clients.  Even in this case,
   you must handle TSS keys through API functions due to compatibility.
*/
struct _Py_tss_t {
    int _is_initialized;
    NATIVE_TSS_KEY_T _key;
};

#undef NATIVE_TSS_KEY_T

/* When static allocation, you must initialize with Py_tss_NEEDS_INIT. */
#define Py_tss_NEEDS_INIT   {0}
#endif  /* !Py_LIMITED_API */

PyAPI_FUNC(Py_tss_t *) PyThread_tss_alloc(void);
PyAPI_FUNC(void) PyThread_tss_free(Py_tss_t *key);

/* The parameter key must not be NULL. */
PyAPI_FUNC(int) PyThread_tss_is_created(Py_tss_t *key);
PyAPI_FUNC(int) PyThread_tss_create(Py_tss_t *key);
PyAPI_FUNC(void) PyThread_tss_delete(Py_tss_t *key);
PyAPI_FUNC(int) PyThread_tss_set(Py_tss_t *key, void *value);
PyAPI_FUNC(void *) PyThread_tss_get(Py_tss_t *key);
#endif  /* New in 3.7 */

#ifdef __cplusplus
}
#endif

#endif /* !Py_PYTHREAD_H */

Filemanager

Name Type Size Permission Actions
cpython Folder 0755
internal Folder 0755
Python-ast.h File 25.58 KB 0644
Python.h File 3.45 KB 0644
abstract.h File 29.76 KB 0644
asdl.h File 1.2 KB 0644
ast.h File 947 B 0644
bitset.h File 468 B 0644
bltinmodule.h File 264 B 0644
boolobject.h File 885 B 0644
bytearrayobject.h File 1.45 KB 0644
bytesobject.h File 2.98 KB 0644
cellobject.h File 712 B 0644
ceval.h File 5.81 KB 0644
classobject.h File 1.62 KB 0644
code.h File 318 B 0644
codecs.h File 6.63 KB 0644
compile.h File 3.69 KB 0644
complexobject.h File 1.76 KB 0644
context.h File 1.92 KB 0644
datetime.h File 9.04 KB 0644
descrobject.h File 2.95 KB 0644
dictobject.h File 3.63 KB 0644
dynamic_annotations.h File 21.94 KB 0644
enumobject.h File 253 B 0644
errcode.h File 1.59 KB 0644
eval.h File 1.18 KB 0644
exports.h File 1.07 KB 0644
fileobject.h File 1.53 KB 0644
fileutils.h File 597 B 0644
floatobject.h File 4.26 KB 0644
frameobject.h File 337 B 0644
funcobject.h File 3.96 KB 0644
genericaliasobject.h File 334 B 0644
genobject.h File 3.44 KB 0644
graminit.h File 2.07 KB 0644
grammar.h File 1.78 KB 0644
import.h File 2.96 KB 0644
interpreteridobject.h File 334 B 0644
intrcheck.h File 861 B 0644
iterobject.h File 521 B 0644
listobject.h File 1.74 KB 0644
longintrepr.h File 3.71 KB 0644
longobject.h File 9.29 KB 0644
marshal.h File 803 B 0644
memoryobject.h File 2.7 KB 0644
methodobject.h File 3.69 KB 0644
modsupport.h File 9.73 KB 0644
moduleobject.h File 2.31 KB 0644
namespaceobject.h File 349 B 0644
node.h File 1.25 KB 0644
object.h File 24.05 KB 0644
objimpl.h File 8.23 KB 0644
odictobject.h File 1.27 KB 0644
opcode.h File 4.79 KB 0644
osdefs.h File 737 B 0644
osmodule.h File 291 B 0644
parsetok.h File 2.89 KB 0644
patchlevel.h File 1.27 KB 0644
picklebufobject.h File 846 B 0644
py_curses.h File 2.42 KB 0644
pyarena.h File 2.68 KB 0644
pycapsule.h File 1.68 KB 0644
pyconfig-64.h File 46.88 KB 0644
pyconfig.h File 162 B 0644
pyctype.h File 1.35 KB 0644
pydebug.h File 1.07 KB 0644
pydtrace.h File 2.36 KB 0644
pyerrors.h File 12.14 KB 0644
pyexpat.h File 2.51 KB 0644
pyfpe.h File 444 B 0644
pyframe.h File 466 B 0644
pyhash.h File 4.16 KB 0644
pylifecycle.h File 2.09 KB 0644
pymacconfig.h File 2.92 KB 0644
pymacro.h File 4.8 KB 0644
pymath.h File 8.38 KB 0644
pymem.h File 4.3 KB 0644
pyport.h File 30.54 KB 0644
pystate.h File 5.13 KB 0644
pystrcmp.h File 436 B 0644
pystrhex.h File 849 B 0644
pystrtod.h File 1.45 KB 0644
pythonrun.h File 7.49 KB 0644
pythread.h File 5.8 KB 0644
pytime.h File 8.72 KB 0644
rangeobject.h File 628 B 0644
setobject.h File 3.25 KB 0644
sliceobject.h File 2.46 KB 0644
structmember.h File 1.98 KB 0644
structseq.h File 1.36 KB 0644
symtable.h File 5.18 KB 0644
sysmodule.h File 1.21 KB 0644
token.h File 2.58 KB 0644
traceback.h File 584 B 0644
tracemalloc.h File 1.09 KB 0644
tupleobject.h File 1.58 KB 0644
typeslots.h File 2.29 KB 0644
ucnhash.h File 1.03 KB 0644
unicodeobject.h File 34.6 KB 0644
warnings.h File 1.73 KB 0644
weakrefobject.h File 2.8 KB 0644