summaryrefslogtreecommitdiffstats
path: root/Doc
diff options
context:
space:
mode:
authorGeorg Brandl <georg@python.org>2006-02-18 22:55:59 (GMT)
committerGeorg Brandl <georg@python.org>2006-02-18 22:55:59 (GMT)
commit4caeff9867dcc3fce66d4bb73199e2ef7bec62be (patch)
treef5cb01fe6573a7805307791326f80291e0e15cfe /Doc
parentf4f4415a18cebdc6e0498c8b178e12978414f5d0 (diff)
downloadcpython-4caeff9867dcc3fce66d4bb73199e2ef7bec62be.zip
cpython-4caeff9867dcc3fce66d4bb73199e2ef7bec62be.tar.gz
cpython-4caeff9867dcc3fce66d4bb73199e2ef7bec62be.tar.bz2
Patch #1415507: clarify docs on reference stealing
Diffstat (limited to 'Doc')
-rw-r--r--Doc/api/intro.tex16
1 files changed, 13 insertions, 3 deletions
diff --git a/Doc/api/intro.tex b/Doc/api/intro.tex
index 752100d..d84b654 100644
--- a/Doc/api/intro.tex
+++ b/Doc/api/intro.tex
@@ -179,7 +179,7 @@ calling Py_DECREF on it when the reference is no longer needed.
Ownership can also be transferred, meaning that the code that receives
ownership of the reference then becomes responsible for eventually
decref'ing it by calling \cfunction{Py_DECREF()} or
-\cfunction{Py_XDECREF()} when it's no longer needed --or passing on
+\cfunction{Py_XDECREF()} when it's no longer needed---or passing on
this responsibility (usually to its caller).
When a function passes ownership of a reference on to its caller, the
caller is said to receive a \emph{new} reference. When no ownership
@@ -188,8 +188,12 @@ Nothing needs to be done for a borrowed reference.
Conversely, when a calling function passes it a reference to an
object, there are two possibilities: the function \emph{steals} a
-reference to the object, or it does not. Few functions steal
-references; the two notable exceptions are
+reference to the object, or it does not. \emph{Stealing a reference}
+means that when you pass a reference to a function, that function
+assumes that it now owns that reference, and you are not responsible
+for it any longer.
+
+Few functions steal references; the two notable exceptions are
\cfunction{PyList_SetItem()}\ttindex{PyList_SetItem()} and
\cfunction{PyTuple_SetItem()}\ttindex{PyTuple_SetItem()}, which
steal a reference to the item (but not to the tuple or list into which
@@ -208,6 +212,12 @@ PyTuple_SetItem(t, 1, PyInt_FromLong(2L));
PyTuple_SetItem(t, 2, PyString_FromString("three"));
\end{verbatim}
+Here, \cfunction{PyInt_FromLong()} returns a new reference which is
+immediately stolen by \cfunction{PyTuple_SetItem()}. When you want to
+keep using an object although the reference to it will be stolen,
+use \cfunction{Py_INCREF()} to grab another reference before calling the
+reference-stealing function.
+
Incidentally, \cfunction{PyTuple_SetItem()} is the \emph{only} way to
set tuple items; \cfunction{PySequence_SetItem()} and
\cfunction{PyObject_SetItem()} refuse to do this since tuples are an