# Thread and interpreter state structures and their interfaces from .object cimport PyObject cdef extern from "Python.h": # We make these an opaque types. If the user wants specific attributes, # they can be declared manually. ctypedef long PY_INT64_T # FIXME: Py2.7+, not defined here but used here ctypedef struct PyInterpreterState: pass ctypedef struct PyThreadState: pass ctypedef struct PyFrameObject: pass # This is not actually a struct, but make sure it can never be coerced to # an int or used in arithmetic expressions ctypedef struct PyGILState_STATE: pass # The type of the trace function registered using PyEval_SetProfile() and # PyEval_SetTrace(). # Py_tracefunc return -1 when raising an exception, or 0 for success. ctypedef int (*Py_tracefunc)(PyObject *, PyFrameObject *, int, PyObject *) # The following values are used for 'what' for tracefunc functions enum: PyTrace_CALL PyTrace_EXCEPTION PyTrace_LINE PyTrace_RETURN PyTrace_C_CALL PyTrace_C_EXCEPTION PyTrace_C_RETURN PyInterpreterState * PyInterpreterState_New() void PyInterpreterState_Clear(PyInterpreterState *) void PyInterpreterState_Delete(PyInterpreterState *) PY_INT64_T PyInterpreterState_GetID(PyInterpreterState *) PyThreadState * PyThreadState_New(PyInterpreterState *) void PyThreadState_Clear(PyThreadState *) void PyThreadState_Delete(PyThreadState *) PyThreadState * PyThreadState_Get() PyThreadState * PyThreadState_Swap(PyThreadState *) # NOTE: DO NOT USE IN CYTHON CODE ! PyObject * PyThreadState_GetDict() int PyThreadState_SetAsyncExc(long, PyObject *) # 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. PyGILState_STATE PyGILState_Ensure() # 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. void PyGILState_Release(PyGILState_STATE) # Routines for advanced debuggers, requested by David Beazley. # Don't use unless you know what you are doing! PyInterpreterState * PyInterpreterState_Head() PyInterpreterState * PyInterpreterState_Next(PyInterpreterState *) PyThreadState * PyInterpreterState_ThreadHead(PyInterpreterState *) PyThreadState * PyThreadState_Next(PyThreadState *)