404

[ Avaa Bypassed ]




Upload:

Command:

elspacio@18.188.27.67: ~ $
/* Thread and interpreter state structures and their interfaces */


#ifndef Py_PYSTATE_H
#define Py_PYSTATE_H
#ifdef __cplusplus
extern "C" {
#endif

/* This limitation is for performance and simplicity. If needed it can be
removed (with effort). */
#define MAX_CO_EXTRA_USERS 255

/* Forward declarations for PyFrameObject, PyThreadState
   and PyInterpreterState */
struct _ts;
struct _is;

/* struct _ts is defined in cpython/pystate.h */
typedef struct _ts PyThreadState;
/* struct _is is defined in internal/pycore_interp.h */
typedef struct _is PyInterpreterState;

PyAPI_FUNC(PyInterpreterState *) PyInterpreterState_New(void);
PyAPI_FUNC(void) PyInterpreterState_Clear(PyInterpreterState *);
PyAPI_FUNC(void) PyInterpreterState_Delete(PyInterpreterState *);

#if !defined(Py_LIMITED_API) || Py_LIMITED_API+0 >= 0x03090000
/* New in 3.9 */
/* Get the current interpreter state.

   Issue a fatal error if there no current Python thread state or no current
   interpreter. It cannot return NULL.

   The caller must hold the GIL. */
PyAPI_FUNC(PyInterpreterState *) PyInterpreterState_Get(void);
#endif

#if !defined(Py_LIMITED_API) || Py_LIMITED_API+0 >= 0x03080000
/* New in 3.8 */
PyAPI_FUNC(PyObject *) PyInterpreterState_GetDict(PyInterpreterState *);
#endif

#if !defined(Py_LIMITED_API) || Py_LIMITED_API+0 >= 0x03070000
/* New in 3.7 */
PyAPI_FUNC(int64_t) PyInterpreterState_GetID(PyInterpreterState *);
#endif
#if !defined(Py_LIMITED_API) || Py_LIMITED_API+0 >= 0x03030000

/* State unique per thread */

/* New in 3.3 */
PyAPI_FUNC(int) PyState_AddModule(PyObject*, struct PyModuleDef*);
PyAPI_FUNC(int) PyState_RemoveModule(struct PyModuleDef*);
#endif
PyAPI_FUNC(PyObject*) PyState_FindModule(struct PyModuleDef*);

PyAPI_FUNC(PyThreadState *) PyThreadState_New(PyInterpreterState *);
PyAPI_FUNC(void) PyThreadState_Clear(PyThreadState *);
PyAPI_FUNC(void) PyThreadState_Delete(PyThreadState *);

/* Get the current thread state.

   When the current thread state is NULL, this issues a fatal error (so that
   the caller needn't check for NULL).

   The caller must hold the GIL.

   See also PyThreadState_GET() and _PyThreadState_GET(). */
PyAPI_FUNC(PyThreadState *) PyThreadState_Get(void);

/* Get the current Python thread state.

   Macro using PyThreadState_Get() or _PyThreadState_GET() depending if
   pycore_pystate.h is included or not (this header redefines the macro).

   If PyThreadState_Get() is used, issue a fatal error if the current thread
   state is NULL.

   See also PyThreadState_Get() and _PyThreadState_GET(). */
#define PyThreadState_GET() PyThreadState_Get()

PyAPI_FUNC(PyThreadState *) PyThreadState_Swap(PyThreadState *);
PyAPI_FUNC(PyObject *) PyThreadState_GetDict(void);
PyAPI_FUNC(int) PyThreadState_SetAsyncExc(unsigned long, PyObject *);

#if !defined(Py_LIMITED_API) || Py_LIMITED_API+0 >= 0x03090000
/* New in 3.9 */
PyAPI_FUNC(PyInterpreterState*) PyThreadState_GetInterpreter(PyThreadState *tstate);
PyAPI_FUNC(PyFrameObject*) PyThreadState_GetFrame(PyThreadState *tstate);
PyAPI_FUNC(uint64_t) PyThreadState_GetID(PyThreadState *tstate);
#endif

typedef
    enum {PyGILState_LOCKED, PyGILState_UNLOCKED}
        PyGILState_STATE;


/* Ensure that the current thread is ready to call the Python
   C API, regardless of the current state of Python, or of its
   thread lock.  This may be called as many times as desired
   by a thread so long as each call is matched with a call to
   PyGILState_Release().  In general, other thread-state APIs may
   be used between _Ensure() and _Release() calls, so long as the
   thread-state is restored to its previous state before the Release().
   For example, normal use of the Py_BEGIN_ALLOW_THREADS/
   Py_END_ALLOW_THREADS macros are acceptable.

   The return value is an opaque "handle" to the thread state when
   PyGILState_Ensure() was called, and must be passed to
   PyGILState_Release() to ensure Python is left in the same state. Even
   though recursive calls are allowed, these handles can *not* be shared -
   each unique call to PyGILState_Ensure must save the handle for its
   call to PyGILState_Release.

   When the function returns, the current thread will hold the GIL.

   Failure is a fatal error.
*/
PyAPI_FUNC(PyGILState_STATE) PyGILState_Ensure(void);

/* Release any resources previously acquired.  After this call, Python's
   state will be the same as it was prior to the corresponding
   PyGILState_Ensure() call (but generally this state will be unknown to
   the caller, hence the use of the GILState API.)

   Every call to PyGILState_Ensure must be matched by a call to
   PyGILState_Release on the same thread.
*/
PyAPI_FUNC(void) PyGILState_Release(PyGILState_STATE);

/* Helper/diagnostic function - get the current thread state for
   this thread.  May return NULL if no GILState API has been used
   on the current thread.  Note that the main thread always has such a
   thread-state, even if no auto-thread-state call has been made
   on the main thread.
*/
PyAPI_FUNC(PyThreadState *) PyGILState_GetThisThreadState(void);


#ifndef Py_LIMITED_API
#  define Py_CPYTHON_PYSTATE_H
#  include  "cpython/pystate.h"
#  undef Py_CPYTHON_PYSTATE_H
#endif

#ifdef __cplusplus
}
#endif
#endif /* !Py_PYSTATE_H */

Filemanager

Name Type Size Permission Actions
cpython Folder 0755
internal Folder 0755
Python.h File 3.15 KB 0644
abstract.h File 30.67 KB 0644
bltinmodule.h File 264 B 0644
boolobject.h File 1.2 KB 0644
bytearrayobject.h File 1.45 KB 0644
bytesobject.h File 2.53 KB 0644
cellobject.h File 720 B 0644
ceval.h File 5.57 KB 0644
classobject.h File 1.62 KB 0644
code.h File 318 B 0644
codecs.h File 6.91 KB 0644
compile.h File 520 B 0644
complexobject.h File 1.76 KB 0644
context.h File 1.92 KB 0644
datetime.h File 9.41 KB 0644
descrobject.h File 2.93 KB 0644
dictobject.h File 3.76 KB 0644
dynamic_annotations.h File 21.94 KB 0644
enumobject.h File 253 B 0644
errcode.h File 1.66 KB 0644
eval.h File 831 B 0644
exports.h File 1.07 KB 0644
fileobject.h File 1.53 KB 0644
fileutils.h File 508 B 0644
floatobject.h File 4.26 KB 0644
frameobject.h File 337 B 0644
funcobject.h File 4.16 KB 0644
genericaliasobject.h File 334 B 0644
genobject.h File 3.27 KB 0644
import.h File 2.96 KB 0644
interpreteridobject.h File 334 B 0644
intrcheck.h File 772 B 0644
iterobject.h File 593 B 0644
listobject.h File 1.74 KB 0644
longintrepr.h File 3.71 KB 0644
longobject.h File 8.4 KB 0644
marshal.h File 803 B 0644
memoryobject.h File 2.7 KB 0644
methodobject.h File 4.05 KB 0644
modsupport.h File 10.09 KB 0644
moduleobject.h File 2.4 KB 0644
namespaceobject.h File 349 B 0644
object.h File 27.68 KB 0644
objimpl.h File 8.25 KB 0644
opcode.h File 5.38 KB 0644
osdefs.h File 737 B 0644
osmodule.h File 291 B 0644
patchlevel.h File 1.27 KB 0644
py_curses.h File 2.42 KB 0644
pycapsule.h File 1.68 KB 0644
pyconfig-64.h File 47.55 KB 0644
pyconfig.h File 162 B 0644
pydtrace.h File 2.36 KB 0644
pyerrors.h File 12.13 KB 0644
pyexpat.h File 2.51 KB 0644
pyframe.h File 466 B 0644
pyhash.h File 4.12 KB 0644
pylifecycle.h File 2.03 KB 0644
pymacconfig.h File 2.92 KB 0644
pymacro.h File 4.8 KB 0644
pymath.h File 8.12 KB 0644
pymem.h File 3.8 KB 0644
pyport.h File 30.94 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 1.08 KB 0644
pythread.h File 5.8 KB 0644
rangeobject.h File 628 B 0644
setobject.h File 3.3 KB 0644
sliceobject.h File 2.46 KB 0644
structmember.h File 2.03 KB 0644
structseq.h File 1.36 KB 0644
sysmodule.h File 1.21 KB 0644
token.h File 2.61 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.4 KB 0644
unicodeobject.h File 35.3 KB 0644
warnings.h File 1.73 KB 0644
weakrefobject.h File 2.8 KB 0644