Commit 1b24465c authored by Gregory P. Smith's avatar Gregory P. Smith

issue9014: Properly document PyObject_HEAD and friends post-PEP-3123.

parent 23a6a0da
...@@ -21,53 +21,65 @@ the definition of all other Python objects. ...@@ -21,53 +21,65 @@ the definition of all other Python objects.
All object types are extensions of this type. This is a type which All object types are extensions of this type. This is a type which
contains the information Python needs to treat a pointer to an object as an contains the information Python needs to treat a pointer to an object as an
object. In a normal "release" build, it contains only the object's object. In a normal "release" build, it contains only the object's
reference count and a pointer to the corresponding type object. It reference count and a pointer to the corresponding type object.
corresponds to the fields defined by the expansion of the ``PyObject_HEAD`` Nothing is actually declared to be a PyObject, but every pointer to a
macro. Python object can be cast to a PyObject*. Access to the members
must be done by using the macros :c:macro:`Py_REFCNT` and
:c:macro:`Py_TYPE`.
.. c:type:: PyVarObject .. c:type:: PyVarObject
This is an extension of :c:type:`PyObject` that adds the :attr:`ob_size` This is an extension of :c:type:`PyObject` that adds the :attr:`ob_size`
field. This is only used for objects that have some notion of *length*. field. This is only used for objects that have some notion of *length*.
This type does not often appear in the Python/C API. It corresponds to the This type does not often appear in the Python/C API.
fields defined by the expansion of the ``PyObject_VAR_HEAD`` macro. Access to the members must be done by using the macros
:c:macro:`Py_REFCNT`, :c:macro:`Py_TYPE`, and :c:macro:`Py_SIZE`.
These macros are used in the definition of :c:type:`PyObject` and
:c:type:`PyVarObject`:
.. XXX need to document PEP 3123 changes here
.. c:macro:: PyObject_HEAD .. c:macro:: PyObject_HEAD
This is a macro which expands to the declarations of the fields of the This is a macro used when declaring new types which represent objects
:c:type:`PyObject` type; it is used when declaring new types which represent without a varying length. The PyObject_HEAD macro expands to::
objects without a varying length. The specific fields it expands to depend
on the definition of :c:macro:`Py_TRACE_REFS`. By default, that macro is
not defined, and :c:macro:`PyObject_HEAD` expands to::
Py_ssize_t ob_refcnt;
PyTypeObject *ob_type;
When :c:macro:`Py_TRACE_REFS` is defined, it expands to:: PyObject ob_base;
PyObject *_ob_next, *_ob_prev; See documentation of :c:type::`PyObject` above.
Py_ssize_t ob_refcnt;
PyTypeObject *ob_type;
.. c:macro:: PyObject_VAR_HEAD .. c:macro:: PyObject_VAR_HEAD
This is a macro which expands to the declarations of the fields of the This is a macro used when declaring new types which represent objects
:c:type:`PyVarObject` type; it is used when declaring new types which with a length that varies from instance to instance.
represent objects with a length that varies from instance to instance. The PyObject_VAR_HEAD macro expands to::
This macro always expands to::
PyVarObject ob_base;
See documentation of :c:type:`PyVarObject` above.
.. c:macro:: Py_TYPE(o)
This macro is used to access the `ob_type` member of a Python object.
It expands to::
(((PyObject*)(o))->ob_type)
.. c:macro:: Py_REFCNT(o)
This macro is used to access the `ob_refcnt` member of a Python object.
It expands to::
(((PyObject*)(o))->ob_refcnt)
.. c:macro:: Py_SIZE(o)
PyObject_HEAD This macro is used to access the `ob_size` member of a Python object.
Py_ssize_t ob_size; It expands to::
Note that :c:macro:`PyObject_HEAD` is part of the expansion, and that its own (((PyVarObject*)(o))->ob_size)
expansion varies depending on the definition of :c:macro:`Py_TRACE_REFS`.
.. c:macro:: PyObject_HEAD_INIT(type) .. c:macro:: PyObject_HEAD_INIT(type)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment