summaryrefslogtreecommitdiffstats
path: root/Doc/api
diff options
context:
space:
mode:
authorFred Drake <fdrake@acm.org>2005-01-19 04:13:14 (GMT)
committerFred Drake <fdrake@acm.org>2005-01-19 04:13:14 (GMT)
commit96ee1c4b8a1fe64dd9b4cd03258920d1ab723247 (patch)
tree1aa0f7ecbdb7d82ff734d3e594cdd99e4e14e698 /Doc/api
parent94505a7cc0a40f2b4a5256f27d8ab32266e6b0d4 (diff)
downloadcpython-96ee1c4b8a1fe64dd9b4cd03258920d1ab723247.zip
cpython-96ee1c4b8a1fe64dd9b4cd03258920d1ab723247.tar.gz
cpython-96ee1c4b8a1fe64dd9b4cd03258920d1ab723247.tar.bz2
Clean up discussion of new C thread idiom
(closes SF patch #1031233; modified)
Diffstat (limited to 'Doc/api')
-rw-r--r--Doc/api/init.tex24
1 files changed, 11 insertions, 13 deletions
diff --git a/Doc/api/init.tex b/Doc/api/init.tex
index 764c932..e8d3583 100644
--- a/Doc/api/init.tex
+++ b/Doc/api/init.tex
@@ -455,19 +455,10 @@ Python/C API. When they are done, they should reset the thread state
pointer, release the lock, and finally free their thread state data
structure.
-When creating a thread data structure, you need to provide an
-interpreter state data structure. The interpreter state data
-structure holds global data that is shared by all threads in an
-interpreter, for example the module administration
-(\code{sys.modules}). Depending on your needs, you can either create
-a new interpreter state data structure, or share the interpreter state
-data structure used by the Python main thread (to access the latter,
-you must obtain the thread state and access its \member{interp} member;
-this must be done by a thread that is created by Python or by the main
-thread after Python is initialized).
-
-Assuming you have access to an interpreter object, the typical idiom
-for calling into Python from a C thread is
+Beginning with version 2.3, threads can now take advantage of the
+\cfunction{PyGILState_*()} functions to do all of the above
+automatically. The typical idiom for calling into Python from a C
+thread is now:
\begin{verbatim}
PyGILState_STATE gstate;
@@ -481,6 +472,13 @@ for calling into Python from a C thread is
PyGILState_Release(gstate);
\end{verbatim}
+Note that the \cfunction{PyGILState_*()} functions assume there is only
+one global interpreter (created automatically by
+\cfunction{Py_Initialize()}). Python still supports the creation of
+additional interpreters (using \cfunction{Py_NewInterpreter()}), but
+mixing multiple interpreters and the \cfunction{PyGILState_*()} API is
+unsupported.
+
\begin{ctypedesc}{PyInterpreterState}
This data structure represents the state shared by a number of
cooperating threads. Threads belonging to the same interpreter