diff options
| author | Guido van Rossum <guido@python.org> | 1998-04-10 20:18:25 +0000 |
|---|---|---|
| committer | Guido van Rossum <guido@python.org> | 1998-04-10 20:18:25 +0000 |
| commit | f140674439670c9810195dc56b62b455e4d48077 (patch) | |
| tree | f4854a2a22544b46be1144dd643dcf9cc9311317 /Python/pystate.c | |
| parent | 376b0a3cb5d6f27310d32d791969442d6aef4d52 (diff) | |
| download | cpython-f140674439670c9810195dc56b62b455e4d48077.tar.gz | |
/* An extension mechanism to store arbitrary additional per-thread state.
PyThreadState_GetDict() returns a dictionary that can be used to hold such
state; the caller should pick a unique key and store its state there. If
PyThreadState_GetDict() returns NULL, an exception has been raised (most
likely MemoryError) and the caller should pass on the exception. */
PyObject *
PyThreadState_GetDict()
Diffstat (limited to 'Python/pystate.c')
| -rw-r--r-- | Python/pystate.c | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/Python/pystate.c b/Python/pystate.c index f1dc4138db..e74e34ca4a 100644 --- a/Python/pystate.c +++ b/Python/pystate.c @@ -126,6 +126,8 @@ PyThreadState_New(interp) tstate->ticker = 0; tstate->tracing = 0; + tstate->dict = NULL; + tstate->curexc_type = NULL; tstate->curexc_value = NULL; tstate->curexc_traceback = NULL; @@ -155,6 +157,8 @@ PyThreadState_Clear(tstate) ZAP(tstate->frame); + ZAP(tstate->dict); + ZAP(tstate->curexc_type); ZAP(tstate->curexc_value); ZAP(tstate->curexc_traceback); @@ -213,3 +217,20 @@ PyThreadState_Swap(new) return old; } + +/* An extension mechanism to store arbitrary additional per-thread state. + PyThreadState_GetDict() returns a dictionary that can be used to hold such + state; the caller should pick a unique key and store its state there. If + PyThreadState_GetDict() returns NULL, an exception has been raised (most + likely MemoryError) and the caller should pass on the exception. */ + +PyObject * +PyThreadState_GetDict() +{ + if (current_tstate == NULL) + Py_FatalError("PyThreadState_GetDict: no current thread"); + + if (current_tstate->dict == NULL) + current_tstate->dict = PyDict_New(); + return current_tstate->dict; +} |
