1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192 |
- # 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 *)
|