| Guido van Rossum | a027efa | 1997-05-05 20:56:21 +0000 | [diff] [blame] | 1 |  | 
|  | 2 | /* Thread and interpreter state structures and their interfaces */ | 
|  | 3 |  | 
|  | 4 |  | 
| Fred Drake | 5eb6d4e | 2000-07-08 23:37:28 +0000 | [diff] [blame] | 5 | #ifndef Py_PYSTATE_H | 
|  | 6 | #define Py_PYSTATE_H | 
|  | 7 | #ifdef __cplusplus | 
|  | 8 | extern "C" { | 
|  | 9 | #endif | 
|  | 10 |  | 
| Guido van Rossum | a027efa | 1997-05-05 20:56:21 +0000 | [diff] [blame] | 11 | /* State shared between threads */ | 
|  | 12 |  | 
| Guido van Rossum | 29e46a9 | 1997-08-02 02:56:48 +0000 | [diff] [blame] | 13 | struct _ts; /* Forward */ | 
|  | 14 | struct _is; /* Forward */ | 
|  | 15 |  | 
| Martin v. Löwis | 4d0d471 | 2010-12-03 20:14:31 +0000 | [diff] [blame] | 16 | #ifdef Py_LIMITED_API | 
|  | 17 | typedef struct _is PyInterpreterState; | 
|  | 18 | #else | 
| Guido van Rossum | a027efa | 1997-05-05 20:56:21 +0000 | [diff] [blame] | 19 | typedef struct _is { | 
|  | 20 |  | 
| Fred Drake | 5eb6d4e | 2000-07-08 23:37:28 +0000 | [diff] [blame] | 21 | struct _is *next; | 
|  | 22 | struct _ts *tstate_head; | 
| Guido van Rossum | 29e46a9 | 1997-08-02 02:56:48 +0000 | [diff] [blame] | 23 |  | 
| Fred Drake | 5eb6d4e | 2000-07-08 23:37:28 +0000 | [diff] [blame] | 24 | PyObject *modules; | 
| Martin v. Löwis | 1a21451 | 2008-06-11 05:26:20 +0000 | [diff] [blame] | 25 | PyObject *modules_by_index; | 
| Fred Drake | 5eb6d4e | 2000-07-08 23:37:28 +0000 | [diff] [blame] | 26 | PyObject *sysdict; | 
|  | 27 | PyObject *builtins; | 
| Brett Cannon | fd07415 | 2012-04-14 14:10:13 -0400 | [diff] [blame] | 28 | PyObject *importlib; | 
| Guido van Rossum | a027efa | 1997-05-05 20:56:21 +0000 | [diff] [blame] | 29 |  | 
| Gustavo Niemeyer | 5ddd4c3 | 2003-03-19 00:35:36 +0000 | [diff] [blame] | 30 | PyObject *codec_search_path; | 
|  | 31 | PyObject *codec_search_cache; | 
|  | 32 | PyObject *codec_error_registry; | 
| Christian Heimes | 6a27efa | 2008-10-30 21:48:26 +0000 | [diff] [blame] | 33 | int codecs_initialized; | 
| Victor Stinner | 793b531 | 2011-04-27 00:24:21 +0200 | [diff] [blame] | 34 | int fscodec_initialized; | 
| Gustavo Niemeyer | 5ddd4c3 | 2003-03-19 00:35:36 +0000 | [diff] [blame] | 35 |  | 
| Brett Cannon | fd07415 | 2012-04-14 14:10:13 -0400 | [diff] [blame] | 36 |  | 
| Martin v. Löwis | f0473d5 | 2001-07-18 16:17:16 +0000 | [diff] [blame] | 37 | #ifdef HAVE_DLOPEN | 
|  | 38 | int dlopenflags; | 
|  | 39 | #endif | 
| Martin v. Löwis | f30d60e | 2004-06-08 08:17:44 +0000 | [diff] [blame] | 40 | #ifdef WITH_TSC | 
|  | 41 | int tscdump; | 
|  | 42 | #endif | 
| Guido van Rossum | a027efa | 1997-05-05 20:56:21 +0000 | [diff] [blame] | 43 |  | 
|  | 44 | } PyInterpreterState; | 
| Martin v. Löwis | 4d0d471 | 2010-12-03 20:14:31 +0000 | [diff] [blame] | 45 | #endif | 
| Guido van Rossum | a027efa | 1997-05-05 20:56:21 +0000 | [diff] [blame] | 46 |  | 
|  | 47 |  | 
|  | 48 | /* State unique per thread */ | 
|  | 49 |  | 
|  | 50 | struct _frame; /* Avoid including frameobject.h */ | 
|  | 51 |  | 
| Martin v. Löwis | 4d0d471 | 2010-12-03 20:14:31 +0000 | [diff] [blame] | 52 | #ifndef Py_LIMITED_API | 
| Fred Drake | 55fb6e0 | 2001-06-27 19:18:03 +0000 | [diff] [blame] | 53 | /* Py_tracefunc return -1 when raising an exception, or 0 for success. */ | 
|  | 54 | typedef int (*Py_tracefunc)(PyObject *, struct _frame *, int, PyObject *); | 
|  | 55 |  | 
|  | 56 | /* The following values are used for 'what' for tracefunc functions: */ | 
|  | 57 | #define PyTrace_CALL 0 | 
|  | 58 | #define PyTrace_EXCEPTION 1 | 
|  | 59 | #define PyTrace_LINE 2 | 
|  | 60 | #define PyTrace_RETURN 3 | 
| Nicholas Bastin | c69ebe8 | 2004-03-24 21:57:10 +0000 | [diff] [blame] | 61 | #define PyTrace_C_CALL 4 | 
|  | 62 | #define PyTrace_C_EXCEPTION 5 | 
|  | 63 | #define PyTrace_C_RETURN 6 | 
| Martin v. Löwis | 4d0d471 | 2010-12-03 20:14:31 +0000 | [diff] [blame] | 64 | #endif | 
| Fred Drake | 55fb6e0 | 2001-06-27 19:18:03 +0000 | [diff] [blame] | 65 |  | 
| Martin v. Löwis | 4d0d471 | 2010-12-03 20:14:31 +0000 | [diff] [blame] | 66 | #ifdef Py_LIMITED_API | 
|  | 67 | typedef struct _ts PyThreadState; | 
|  | 68 | #else | 
| Guido van Rossum | a027efa | 1997-05-05 20:56:21 +0000 | [diff] [blame] | 69 | typedef struct _ts { | 
| Brett Cannon | 55fa66d | 2005-06-25 07:07:35 +0000 | [diff] [blame] | 70 | /* See Python/ceval.c for comments explaining most fields */ | 
| Guido van Rossum | a027efa | 1997-05-05 20:56:21 +0000 | [diff] [blame] | 71 |  | 
| Charles-Francois Natali | f28dfdd | 2013-05-08 21:09:52 +0200 | [diff] [blame] | 72 | struct _ts *prev; | 
| Fred Drake | 5eb6d4e | 2000-07-08 23:37:28 +0000 | [diff] [blame] | 73 | struct _ts *next; | 
|  | 74 | PyInterpreterState *interp; | 
| Guido van Rossum | a027efa | 1997-05-05 20:56:21 +0000 | [diff] [blame] | 75 |  | 
| Fred Drake | 5eb6d4e | 2000-07-08 23:37:28 +0000 | [diff] [blame] | 76 | struct _frame *frame; | 
|  | 77 | int recursion_depth; | 
| Martin v. Löwis | 5b22213 | 2007-06-10 09:51:05 +0000 | [diff] [blame] | 78 | char overflowed; /* The stack has overflowed. Allow 50 more calls | 
| Victor Stinner | 8e4d407 | 2011-04-26 23:34:58 +0200 | [diff] [blame] | 79 | to handle the runtime error. */ | 
|  | 80 | char recursion_critical; /* The current calls must not cause | 
|  | 81 | a stack overflow. */ | 
| Brett Cannon | 55fa66d | 2005-06-25 07:07:35 +0000 | [diff] [blame] | 82 | /* 'tracing' keeps track of the execution depth when tracing/profiling. | 
|  | 83 | This is to prevent the actual trace/profile code from being recorded in | 
|  | 84 | the trace/profile. */ | 
| Fred Drake | 5eb6d4e | 2000-07-08 23:37:28 +0000 | [diff] [blame] | 85 | int tracing; | 
| Fred Drake | 9e3ad78 | 2001-07-03 23:39:52 +0000 | [diff] [blame] | 86 | int use_tracing; | 
| Guido van Rossum | a027efa | 1997-05-05 20:56:21 +0000 | [diff] [blame] | 87 |  | 
| Fred Drake | 55fb6e0 | 2001-06-27 19:18:03 +0000 | [diff] [blame] | 88 | Py_tracefunc c_profilefunc; | 
|  | 89 | Py_tracefunc c_tracefunc; | 
|  | 90 | PyObject *c_profileobj; | 
|  | 91 | PyObject *c_traceobj; | 
| Guido van Rossum | a027efa | 1997-05-05 20:56:21 +0000 | [diff] [blame] | 92 |  | 
| Fred Drake | 5eb6d4e | 2000-07-08 23:37:28 +0000 | [diff] [blame] | 93 | PyObject *curexc_type; | 
|  | 94 | PyObject *curexc_value; | 
|  | 95 | PyObject *curexc_traceback; | 
| Guido van Rossum | a027efa | 1997-05-05 20:56:21 +0000 | [diff] [blame] | 96 |  | 
| Fred Drake | 5eb6d4e | 2000-07-08 23:37:28 +0000 | [diff] [blame] | 97 | PyObject *exc_type; | 
|  | 98 | PyObject *exc_value; | 
|  | 99 | PyObject *exc_traceback; | 
| Guido van Rossum | a027efa | 1997-05-05 20:56:21 +0000 | [diff] [blame] | 100 |  | 
| Brett Cannon | 55fa66d | 2005-06-25 07:07:35 +0000 | [diff] [blame] | 101 | PyObject *dict;  /* Stores per-thread state */ | 
| Guido van Rossum | ee0a63b | 1998-04-13 20:24:05 +0000 | [diff] [blame] | 102 |  | 
| Mark Hammond | 8d98d2c | 2003-04-19 15:41:53 +0000 | [diff] [blame] | 103 | int gilstate_counter; | 
| Michael W. Hudson | 019a78e | 2002-11-08 12:53:11 +0000 | [diff] [blame] | 104 |  | 
| Guido van Rossum | b8b6d0c | 2003-06-28 21:53:52 +0000 | [diff] [blame] | 105 | PyObject *async_exc; /* Asynchronous exception to raise */ | 
|  | 106 | long thread_id; /* Thread id where this tstate was created */ | 
|  | 107 |  | 
| Antoine Pitrou | 2b0218a | 2012-09-06 00:59:49 +0200 | [diff] [blame] | 108 | int trash_delete_nesting; | 
|  | 109 | PyObject *trash_delete_later; | 
|  | 110 |  | 
| Antoine Pitrou | 7b47699 | 2013-09-07 23:38:37 +0200 | [diff] [blame] | 111 | /* Called when a thread state is deleted normally, but not when it | 
|  | 112 | * is destroyed after fork(). | 
|  | 113 | * Pain:  to prevent rare but fatal shutdown errors (issue 18808), | 
|  | 114 | * Thread.join() must wait for the join'ed thread's tstate to be unlinked | 
|  | 115 | * from the tstate chain.  That happens at the end of a thread's life, | 
|  | 116 | * in pystate.c. | 
|  | 117 | * The obvious way doesn't quite work:  create a lock which the tstate | 
|  | 118 | * unlinking code releases, and have Thread.join() wait to acquire that | 
|  | 119 | * lock.  The problem is that we _are_ at the end of the thread's life: | 
|  | 120 | * if the thread holds the last reference to the lock, decref'ing the | 
|  | 121 | * lock will delete the lock, and that may trigger arbitrary Python code | 
|  | 122 | * if there's a weakref, with a callback, to the lock.  But by this time | 
|  | 123 | * _PyThreadState_Current is already NULL, so only the simplest of C code | 
|  | 124 | * can be allowed to run (in particular it must not be possible to | 
|  | 125 | * release the GIL). | 
|  | 126 | * So instead of holding the lock directly, the tstate holds a weakref to | 
|  | 127 | * the lock:  that's the value of on_delete_data below.  Decref'ing a | 
|  | 128 | * weakref is harmless. | 
|  | 129 | * on_delete points to _threadmodule.c's static release_sentinel() function. | 
|  | 130 | * After the tstate is unlinked, release_sentinel is called with the | 
|  | 131 | * weakref-to-lock (on_delete_data) argument, and release_sentinel releases | 
|  | 132 | * the indirectly held lock. | 
|  | 133 | */ | 
|  | 134 | void (*on_delete)(void *); | 
|  | 135 | void *on_delete_data; | 
|  | 136 |  | 
| Fred Drake | 5eb6d4e | 2000-07-08 23:37:28 +0000 | [diff] [blame] | 137 | /* XXX signal handlers should also be here */ | 
| Guido van Rossum | a027efa | 1997-05-05 20:56:21 +0000 | [diff] [blame] | 138 |  | 
|  | 139 | } PyThreadState; | 
| Martin v. Löwis | 4d0d471 | 2010-12-03 20:14:31 +0000 | [diff] [blame] | 140 | #endif | 
| Guido van Rossum | a027efa | 1997-05-05 20:56:21 +0000 | [diff] [blame] | 141 |  | 
|  | 142 |  | 
| Mark Hammond | 91a681d | 2002-08-12 07:21:58 +0000 | [diff] [blame] | 143 | PyAPI_FUNC(PyInterpreterState *) PyInterpreterState_New(void); | 
|  | 144 | PyAPI_FUNC(void) PyInterpreterState_Clear(PyInterpreterState *); | 
|  | 145 | PyAPI_FUNC(void) PyInterpreterState_Delete(PyInterpreterState *); | 
| Martin v. Löwis | 1a21451 | 2008-06-11 05:26:20 +0000 | [diff] [blame] | 146 | PyAPI_FUNC(int) _PyState_AddModule(PyObject*, struct PyModuleDef*); | 
| Martin v. Löwis | 7800f75 | 2012-06-22 12:20:55 +0200 | [diff] [blame] | 147 | #if !defined(Py_LIMITED_API) || Py_LIMITED_API+0 >= 0x03030000 | 
|  | 148 | /* New in 3.3 */ | 
|  | 149 | PyAPI_FUNC(int) PyState_AddModule(PyObject*, struct PyModuleDef*); | 
|  | 150 | PyAPI_FUNC(int) PyState_RemoveModule(struct PyModuleDef*); | 
|  | 151 | #endif | 
| Martin v. Löwis | 1a21451 | 2008-06-11 05:26:20 +0000 | [diff] [blame] | 152 | PyAPI_FUNC(PyObject*) PyState_FindModule(struct PyModuleDef*); | 
| Antoine Pitrou | 40322e6 | 2013-08-11 00:30:09 +0200 | [diff] [blame] | 153 | #ifndef Py_LIMITED_API | 
|  | 154 | PyAPI_FUNC(void) _PyState_ClearModules(void); | 
|  | 155 | #endif | 
| Guido van Rossum | a027efa | 1997-05-05 20:56:21 +0000 | [diff] [blame] | 156 |  | 
| Mark Hammond | 91a681d | 2002-08-12 07:21:58 +0000 | [diff] [blame] | 157 | PyAPI_FUNC(PyThreadState *) PyThreadState_New(PyInterpreterState *); | 
| Victor Stinner | 45b9be5 | 2010-03-03 23:28:07 +0000 | [diff] [blame] | 158 | PyAPI_FUNC(PyThreadState *) _PyThreadState_Prealloc(PyInterpreterState *); | 
|  | 159 | PyAPI_FUNC(void) _PyThreadState_Init(PyThreadState *); | 
| Mark Hammond | 91a681d | 2002-08-12 07:21:58 +0000 | [diff] [blame] | 160 | PyAPI_FUNC(void) PyThreadState_Clear(PyThreadState *); | 
|  | 161 | PyAPI_FUNC(void) PyThreadState_Delete(PyThreadState *); | 
| Antoine Pitrou | 8408cea | 2013-05-05 23:47:09 +0200 | [diff] [blame] | 162 | PyAPI_FUNC(void) _PyThreadState_DeleteExcept(PyThreadState *tstate); | 
| Guido van Rossum | 2975786 | 2001-01-23 01:46:06 +0000 | [diff] [blame] | 163 | #ifdef WITH_THREAD | 
| Mark Hammond | 91a681d | 2002-08-12 07:21:58 +0000 | [diff] [blame] | 164 | PyAPI_FUNC(void) PyThreadState_DeleteCurrent(void); | 
| Antoine Pitrou | 0c759fe | 2011-04-27 19:28:05 +0200 | [diff] [blame] | 165 | PyAPI_FUNC(void) _PyGILState_Reinit(void); | 
| Guido van Rossum | 2975786 | 2001-01-23 01:46:06 +0000 | [diff] [blame] | 166 | #endif | 
| Guido van Rossum | a027efa | 1997-05-05 20:56:21 +0000 | [diff] [blame] | 167 |  | 
| Mark Hammond | 91a681d | 2002-08-12 07:21:58 +0000 | [diff] [blame] | 168 | PyAPI_FUNC(PyThreadState *) PyThreadState_Get(void); | 
|  | 169 | PyAPI_FUNC(PyThreadState *) PyThreadState_Swap(PyThreadState *); | 
|  | 170 | PyAPI_FUNC(PyObject *) PyThreadState_GetDict(void); | 
| Guido van Rossum | b8b6d0c | 2003-06-28 21:53:52 +0000 | [diff] [blame] | 171 | PyAPI_FUNC(int) PyThreadState_SetAsyncExc(long, PyObject *); | 
| Guido van Rossum | a027efa | 1997-05-05 20:56:21 +0000 | [diff] [blame] | 172 |  | 
| Guido van Rossum | 275ea67 | 1998-12-21 18:28:10 +0000 | [diff] [blame] | 173 |  | 
|  | 174 | /* Variable and macro for in-line access to current thread state */ | 
|  | 175 |  | 
| Jeffrey Yasskin | 3937083 | 2010-05-03 19:29:34 +0000 | [diff] [blame] | 176 | /* Assuming the current thread holds the GIL, this is the | 
|  | 177 | PyThreadState for the current thread. */ | 
| Martin v. Löwis | 4d0d471 | 2010-12-03 20:14:31 +0000 | [diff] [blame] | 178 | #ifndef Py_LIMITED_API | 
| Jeffrey Yasskin | 3937083 | 2010-05-03 19:29:34 +0000 | [diff] [blame] | 179 | PyAPI_DATA(_Py_atomic_address) _PyThreadState_Current; | 
| Martin v. Löwis | 4d0d471 | 2010-12-03 20:14:31 +0000 | [diff] [blame] | 180 | #endif | 
| Guido van Rossum | 275ea67 | 1998-12-21 18:28:10 +0000 | [diff] [blame] | 181 |  | 
| Martin v. Löwis | 4d0d471 | 2010-12-03 20:14:31 +0000 | [diff] [blame] | 182 | #if defined(Py_DEBUG) || defined(Py_LIMITED_API) | 
| Guido van Rossum | 275ea67 | 1998-12-21 18:28:10 +0000 | [diff] [blame] | 183 | #define PyThreadState_GET() PyThreadState_Get() | 
|  | 184 | #else | 
| Jeffrey Yasskin | 3937083 | 2010-05-03 19:29:34 +0000 | [diff] [blame] | 185 | #define PyThreadState_GET() \ | 
|  | 186 | ((PyThreadState*)_Py_atomic_load_relaxed(&_PyThreadState_Current)) | 
| Guido van Rossum | 275ea67 | 1998-12-21 18:28:10 +0000 | [diff] [blame] | 187 | #endif | 
|  | 188 |  | 
| Tim Peters | 174175b | 2004-03-29 02:24:26 +0000 | [diff] [blame] | 189 | typedef | 
| Mark Hammond | 8d98d2c | 2003-04-19 15:41:53 +0000 | [diff] [blame] | 190 | enum {PyGILState_LOCKED, PyGILState_UNLOCKED} | 
|  | 191 | PyGILState_STATE; | 
|  | 192 |  | 
| Victor Stinner | 8e4d407 | 2011-04-26 23:34:58 +0200 | [diff] [blame] | 193 | #ifdef WITH_THREAD | 
|  | 194 |  | 
| Mark Hammond | 8d98d2c | 2003-04-19 15:41:53 +0000 | [diff] [blame] | 195 | /* Ensure that the current thread is ready to call the Python | 
|  | 196 | C API, regardless of the current state of Python, or of its | 
|  | 197 | thread lock.  This may be called as many times as desired | 
| Tim Peters | 174175b | 2004-03-29 02:24:26 +0000 | [diff] [blame] | 198 | by a thread so long as each call is matched with a call to | 
|  | 199 | PyGILState_Release().  In general, other thread-state APIs may | 
|  | 200 | be used between _Ensure() and _Release() calls, so long as the | 
| Mark Hammond | 8d98d2c | 2003-04-19 15:41:53 +0000 | [diff] [blame] | 201 | thread-state is restored to its previous state before the Release(). | 
|  | 202 | For example, normal use of the Py_BEGIN_ALLOW_THREADS/ | 
|  | 203 | Py_END_ALLOW_THREADS macros are acceptable. | 
|  | 204 |  | 
|  | 205 | The return value is an opaque "handle" to the thread state when | 
| Raymond Hettinger | 4eec95a | 2004-03-13 20:45:47 +0000 | [diff] [blame] | 206 | PyGILState_Ensure() was called, and must be passed to | 
| Mark Hammond | 8d98d2c | 2003-04-19 15:41:53 +0000 | [diff] [blame] | 207 | PyGILState_Release() to ensure Python is left in the same state. Even | 
| Tim Peters | 174175b | 2004-03-29 02:24:26 +0000 | [diff] [blame] | 208 | though recursive calls are allowed, these handles can *not* be shared - | 
|  | 209 | each unique call to PyGILState_Ensure must save the handle for its | 
| Mark Hammond | 8d98d2c | 2003-04-19 15:41:53 +0000 | [diff] [blame] | 210 | call to PyGILState_Release. | 
|  | 211 |  | 
|  | 212 | When the function returns, the current thread will hold the GIL. | 
|  | 213 |  | 
|  | 214 | Failure is a fatal error. | 
|  | 215 | */ | 
|  | 216 | PyAPI_FUNC(PyGILState_STATE) PyGILState_Ensure(void); | 
|  | 217 |  | 
|  | 218 | /* Release any resources previously acquired.  After this call, Python's | 
|  | 219 | state will be the same as it was prior to the corresponding | 
| Tim Peters | 174175b | 2004-03-29 02:24:26 +0000 | [diff] [blame] | 220 | PyGILState_Ensure() call (but generally this state will be unknown to | 
| Mark Hammond | 8d98d2c | 2003-04-19 15:41:53 +0000 | [diff] [blame] | 221 | the caller, hence the use of the GILState API.) | 
|  | 222 |  | 
| Tim Peters | 174175b | 2004-03-29 02:24:26 +0000 | [diff] [blame] | 223 | Every call to PyGILState_Ensure must be matched by a call to | 
| Mark Hammond | 8d98d2c | 2003-04-19 15:41:53 +0000 | [diff] [blame] | 224 | PyGILState_Release on the same thread. | 
|  | 225 | */ | 
|  | 226 | PyAPI_FUNC(void) PyGILState_Release(PyGILState_STATE); | 
|  | 227 |  | 
|  | 228 | /* Helper/diagnostic function - get the current thread state for | 
| Tim Peters | 174175b | 2004-03-29 02:24:26 +0000 | [diff] [blame] | 229 | this thread.  May return NULL if no GILState API has been used | 
| Sandro Tosi | 61baee0 | 2011-08-08 00:16:54 +0200 | [diff] [blame] | 230 | on the current thread.  Note that the main thread always has such a | 
| Tim Peters | 174175b | 2004-03-29 02:24:26 +0000 | [diff] [blame] | 231 | thread-state, even if no auto-thread-state call has been made | 
| Mark Hammond | 8d98d2c | 2003-04-19 15:41:53 +0000 | [diff] [blame] | 232 | on the main thread. | 
|  | 233 | */ | 
|  | 234 | PyAPI_FUNC(PyThreadState *) PyGILState_GetThisThreadState(void); | 
|  | 235 |  | 
| Kristján Valur Jónsson | 684cd0e | 2013-03-23 03:36:16 -0700 | [diff] [blame] | 236 | /* Helper/diagnostic function - return 1 if the current thread | 
|  | 237 | * currently holds the GIL, 0 otherwise | 
|  | 238 | */ | 
| Martin v. Löwis | 1c0689c | 2014-01-03 21:36:49 +0100 | [diff] [blame] | 239 | #ifndef Py_LIMITED_API | 
| Kristján Valur Jónsson | 684cd0e | 2013-03-23 03:36:16 -0700 | [diff] [blame] | 240 | PyAPI_FUNC(int) PyGILState_Check(void); | 
| Martin v. Löwis | 1c0689c | 2014-01-03 21:36:49 +0100 | [diff] [blame] | 241 | #endif | 
| Kristján Valur Jónsson | 684cd0e | 2013-03-23 03:36:16 -0700 | [diff] [blame] | 242 |  | 
| Victor Stinner | 8e4d407 | 2011-04-26 23:34:58 +0200 | [diff] [blame] | 243 | #endif   /* #ifdef WITH_THREAD */ | 
|  | 244 |  | 
| Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 245 | /* The implementation of sys._current_frames()  Returns a dict mapping | 
|  | 246 | thread id to that thread's current frame. | 
|  | 247 | */ | 
| Martin v. Löwis | 4d0d471 | 2010-12-03 20:14:31 +0000 | [diff] [blame] | 248 | #ifndef Py_LIMITED_API | 
| Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 249 | PyAPI_FUNC(PyObject *) _PyThread_CurrentFrames(void); | 
| Martin v. Löwis | 4d0d471 | 2010-12-03 20:14:31 +0000 | [diff] [blame] | 250 | #endif | 
| Thomas Wouters | 0e3f591 | 2006-08-11 14:57:12 +0000 | [diff] [blame] | 251 |  | 
| Guido van Rossum | f5df46d | 2001-07-19 12:19:27 +0000 | [diff] [blame] | 252 | /* Routines for advanced debuggers, requested by David Beazley. | 
|  | 253 | Don't use unless you know what you are doing! */ | 
| Martin v. Löwis | 4d0d471 | 2010-12-03 20:14:31 +0000 | [diff] [blame] | 254 | #ifndef Py_LIMITED_API | 
| Mark Hammond | 91a681d | 2002-08-12 07:21:58 +0000 | [diff] [blame] | 255 | PyAPI_FUNC(PyInterpreterState *) PyInterpreterState_Head(void); | 
|  | 256 | PyAPI_FUNC(PyInterpreterState *) PyInterpreterState_Next(PyInterpreterState *); | 
|  | 257 | PyAPI_FUNC(PyThreadState *) PyInterpreterState_ThreadHead(PyInterpreterState *); | 
|  | 258 | PyAPI_FUNC(PyThreadState *) PyThreadState_Next(PyThreadState *); | 
| Guido van Rossum | f5df46d | 2001-07-19 12:19:27 +0000 | [diff] [blame] | 259 |  | 
| Guido van Rossum | 6297a7a | 2003-02-19 15:53:17 +0000 | [diff] [blame] | 260 | typedef struct _frame *(*PyThreadFrameGetter)(PyThreadState *self_); | 
| Martin v. Löwis | 4d0d471 | 2010-12-03 20:14:31 +0000 | [diff] [blame] | 261 | #endif | 
| Guido van Rossum | 6297a7a | 2003-02-19 15:53:17 +0000 | [diff] [blame] | 262 |  | 
| Michael W. Hudson | 019a78e | 2002-11-08 12:53:11 +0000 | [diff] [blame] | 263 | /* hook for PyEval_GetFrame(), requested for Psyco */ | 
| Martin v. Löwis | 4d0d471 | 2010-12-03 20:14:31 +0000 | [diff] [blame] | 264 | #ifndef Py_LIMITED_API | 
| Guido van Rossum | 6297a7a | 2003-02-19 15:53:17 +0000 | [diff] [blame] | 265 | PyAPI_DATA(PyThreadFrameGetter) _PyThreadState_GetFrame; | 
| Martin v. Löwis | 4d0d471 | 2010-12-03 20:14:31 +0000 | [diff] [blame] | 266 | #endif | 
| Michael W. Hudson | 019a78e | 2002-11-08 12:53:11 +0000 | [diff] [blame] | 267 |  | 
| Guido van Rossum | a027efa | 1997-05-05 20:56:21 +0000 | [diff] [blame] | 268 | #ifdef __cplusplus | 
|  | 269 | } | 
|  | 270 | #endif | 
|  | 271 | #endif /* !Py_PYSTATE_H */ |