*n*-uplets
**********

type PyTupleObject

   Ce sous-type de "PyObject" représente un objet Python "tuple".

PyTypeObject PyTuple_Type
    * Fait partie de l' ABI stable.*

   Cette instance de "PyTypeObject" représente le type Python "tuple",
   c'est le même que l’objet Python "tuple".

int PyTuple_Check(PyObject *p)

   Renvoie vrai si *p* est un "tuple" ou un instance d’un de ses sous-
   type. Cette fonction n’échoue jamais.

int PyTuple_CheckExact(PyObject *p)

   Renvoie vrai uniquement si *p* est un "tuple", mais pas une
   instance d’un des sous-types. Cette fonction n’échoue jamais.

PyObject *PyTuple_New(Py_ssize_t len)
    *Valeur de retour : nouvelle référence.** Fait partie de l' ABI
   stable.*

   Return a new tuple object of size *len*, or "NULL" with an
   exception set on failure.

PyObject *PyTuple_Pack(Py_ssize_t n, ...)
    *Valeur de retour : nouvelle référence.** Fait partie de l' ABI
   stable.*

   Return a new tuple object of size *n*, or "NULL" with an exception
   set on failure. The tuple values are initialized to the subsequent
   *n* C arguments pointing to Python objects. "PyTuple_Pack(2, a, b)"
   is equivalent to "Py_BuildValue("(OO)", a, b)".

Py_ssize_t PyTuple_Size(PyObject *p)
    * Fait partie de l' ABI stable.*

   Take a pointer to a tuple object, and return the size of that
   tuple. On error, return "-1" with an exception set.

Py_ssize_t PyTuple_GET_SIZE(PyObject *p)

   Like "PyTuple_Size()", but without error checking.

PyObject *PyTuple_GetItem(PyObject *p, Py_ssize_t pos)
    *Valeur de retour : référence empruntée.** Fait partie de l' ABI
   stable.*

   Renvoie l’objet à la position *pos* dans le *n*-uplet *p*. Si *pos*
   est négatif ou hors limites, "NULL" est renvoyé et l’exception
   "IndexError" est levée.

   The returned reference is borrowed from the tuple *p* (that is: it
   is only valid as long as you hold a reference to *p*). To get a
   *strong reference*, use "Py_NewRef(PyTuple_GetItem(...))" or
   "PySequence_GetItem()".

PyObject *PyTuple_GET_ITEM(PyObject *p, Py_ssize_t pos)
    *Valeur de retour : référence empruntée.*

   Similaire à la fonction "PyTuple_GetItem()", mais ne contrôle pas
   les arguments.

PyObject *PyTuple_GetSlice(PyObject *p, Py_ssize_t low, Py_ssize_t high)
    *Valeur de retour : nouvelle référence.** Fait partie de l' ABI
   stable.*

   Return the slice of the tuple pointed to by *p* between *low* and
   *high*, or "NULL" with an exception set on failure.

   This is the equivalent of the Python expression "p[low:high]".
   Indexing from the end of the tuple is not supported.

int PyTuple_SetItem(PyObject *p, Py_ssize_t pos, PyObject *o)
    * Fait partie de l' ABI stable.*

   Insère une référence à l’objet *o* à la position *pos* du *n*-uplet
   pointé par *p*. Renvoie "0" si l’opération réussit. Si *pos* est
   hors limite, l’exception "IndexError" est levée et la fonction
   renvoie "-1".

   Note:

     Cette fonction « s’accapare » une référence à l’objet *o* et
     dé-référence l’objet présent dans le *n*-uplet à cette position.

void PyTuple_SET_ITEM(PyObject *p, Py_ssize_t pos, PyObject *o)

   Semblable à la fonction "PyTuple_SetItem()", mais ne contrôle pas
   les erreurs et *ne doit être utilisée que* pour remplir un
   *n*-uplet nouvellement créé.

   Bounds checking is performed as an assertion if Python is built in
   debug mode or "with assertions".

   Note:

     Cette fonction «  s’accapare » une référence à l’objet *o* et,
     contrairement à "PyTuple_SetItem()", ne dé-référence **pas**
     l’élément remplacé : la référence à l’objet présent dans le
     *n*-uplet à la position *pos* est perdue.

   Avertissement:

     This macro should *only* be used on tuples that are newly
     created. Using this macro on a tuple that is already in use (or
     in other words, has a refcount > 1) could lead to undefined
     behavior.

int _PyTuple_Resize(PyObject **p, Py_ssize_t newsize)

   Permet de redimensionner un *n*-uplet. *newsize* est la nouvelle
   taille de ce *n*-uplet. Comme les *n*-uplets sont *supposés* être
   immuables cette fonction doit être utilisée uniquement s’il
   n’existe qu’une référence vers cet objet. *N’utilisez pas* cette
   fonction s’il est possible que le *n*-uplet soit connu d’une autre
   partie du code. Le *n*-uplet sera toujours agrandi ou réduit à
   partir de la fin. Cette fonction est plus performante que de
   détruire le "tuple" puis d’en créer un nouveau. Renvoie "0" si
   l’opération réussit. Le code ne devrait jamais supposer que la
   valeur de "*p" sera la même après l’appel à cette fonction. Si
   l’objet référencé par "*p" doit être remplacé, alors il est d’abord
   détruit. En cas d’erreur cette fonction renvoie "-1" , stocke
   "NULL" dans "*p" et lève soit "MemoryError" soit "SystemError".


Objets structure-séquence
*************************

Les objets *structure-séquence* sont l’équivalent C des objets
"namedtuple()", c’est-à-dire une liste d’objets dont les éléments
peuvent être désignés par des attributs. Pour créer un objet
structure-séquence vous devez d’abord définir son type.

PyTypeObject *PyStructSequence_NewType(PyStructSequence_Desc *desc)
    *Valeur de retour : nouvelle référence.** Fait partie de l' ABI
   stable.*

   Crée un nouveau type d’objet *structure-séquence* à partir des
   données dans *desc*, décrit ci-dessous. Le type ainsi créé peut
   être instancié en appelant "PyStructSequence_New()".

   Return "NULL" with an exception set on failure.

void PyStructSequence_InitType(PyTypeObject *type, PyStructSequence_Desc *desc)

   Initialise un type de structure-séquence à partir de *desc*, sur
   place.

int PyStructSequence_InitType2(PyTypeObject *type, PyStructSequence_Desc *desc)

   Like "PyStructSequence_InitType()", but returns "0" on success and
   "-1" with an exception set on failure.

   Ajouté dans la version 3.4.

type PyStructSequence_Desc
    * Fait partie de l' ABI stable (incluant tous les attributs).*

   Contient les méta-données d’un type structure-séquence à créer.

   const char *name

      Fully qualified name of the type; null-terminated UTF-8 encoded.
      The name must contain the module name.

   const char *doc

      Pointer to docstring for the type or "NULL" to omit.

   PyStructSequence_Field *fields

      Pointer to "NULL"-terminated array with field names of the new
      type.

   int n_in_sequence

      Number of fields visible to the Python side (if used as tuple).

type PyStructSequence_Field
    * Fait partie de l' ABI stable (incluant tous les attributs).*

   Describes a field of a struct sequence. As a struct sequence is
   modeled as a tuple, all fields are typed as PyObject*.  The index
   in the "fields" array of the "PyStructSequence_Desc" determines
   which field of the struct sequence is described.

   const char *name

      Name for the field or "NULL" to end the list of named fields,
      set to "PyStructSequence_UnnamedField" to leave unnamed.

   const char *doc

      Field docstring or "NULL" to omit.

const char *const PyStructSequence_UnnamedField
    * Fait partie de l' ABI stable depuis la version 3.11.*

   Une valeur sentinelle pour indiquer qu’un champ n’est pas nommé.

   Modifié dans la version 3.9: Le type était "char *".

PyObject *PyStructSequence_New(PyTypeObject *type)
    *Valeur de retour : nouvelle référence.** Fait partie de l' ABI
   stable.*

   Crée une instance de *type*, qui doit avoir été créé via
   "PyStructSequence_NewType()".

   Return "NULL" with an exception set on failure.

PyObject *PyStructSequence_GetItem(PyObject *p, Py_ssize_t pos)
    *Valeur de retour : référence empruntée.** Fait partie de l' ABI
   stable.*

   Return the object at position *pos* in the struct sequence pointed
   to by *p*.

   Bounds checking is performed as an assertion if Python is built in
   debug mode or "with assertions".

PyObject *PyStructSequence_GET_ITEM(PyObject *p, Py_ssize_t pos)
    *Valeur de retour : référence empruntée.*

   Alias to "PyStructSequence_GetItem()".

   Modifié dans la version 3.13: Now implemented as an alias to
   "PyStructSequence_GetItem()".

void PyStructSequence_SetItem(PyObject *p, Py_ssize_t pos, PyObject *o)
    * Fait partie de l' ABI stable.*

   Insère un l’objet *o* dans la structure-séquence *p* à la position
   *pos*. Pour les mêmes raisons que "PyTuple_SET_ITEM()", cette
   fonction ne doit être utilisée que pour des objets nouvellement
   créés.

   Bounds checking is performed as an assertion if Python is built in
   debug mode or "with assertions".

   Note:

     Cette fonction « s’accapare » une référence à *o*.

void PyStructSequence_SET_ITEM(PyObject *p, Py_ssize_t *pos, PyObject *o)

   Alias to "PyStructSequence_SetItem()".

   Modifié dans la version 3.13: Now implemented as an alias to
   "PyStructSequence_SetItem()".
