タプルオブジェクト (tuple object)
*********************************

type PyTupleObject

   この "PyObject" のサブタイプは Python のタプルオブジェクトを表現し
   ます。

PyTypeObject PyTuple_Type
    * Part of the Stable ABI.*

   この "PyTypeObject" のインスタンスは Python のタプル型を表現します;
   Python レイヤにおける "tuple" と同じオブジェクトです。

int PyTuple_Check(PyObject *p)

   *p* がタプルオブジェクトかタプル型のサブタイプのインスタンスである
   場合に真を返します。この関数は常に成功します。

int PyTuple_CheckExact(PyObject *p)

   *p* がタプルオブジェクトだがタプル型のサブタイプのインスタンスでな
   い場合に真を返します。この関数は常に成功します。

PyObject *PyTuple_New(Py_ssize_t len)
    *Return value: New reference.** Part of the Stable ABI.*

   サイズが *len* の新たなタプルオブジェクトを返します。失敗すると
   "NULL" を返します。

PyObject *PyTuple_Pack(Py_ssize_t n, ...)
    *Return value: New reference.** Part of the Stable ABI.*

   サイズが *n* の新たなタプルオブジェクトを返します。失敗すると
   "NULL" を返します。タプルの値は後続の *n* 個の Python オブジェクト
   を指す C 引数になります。"PyTuple_Pack(2, a, b)" は
   "Py_BuildValue("(OO)", a, b)" と同じです。

Py_ssize_t PyTuple_Size(PyObject *p)
    * Part of the Stable ABI.*

   タプルオブジェクトへのポインタを引数にとり、そのタプルのサイズを返
   します。

Py_ssize_t PyTuple_GET_SIZE(PyObject *p)

   タプル *p* のサイズを返しますが、*p* は非 "NULL" でなくてはならず、
   タプルオブジェクトを指していなければなりません; この関数はエラーチ
   ェックを行いません。

PyObject *PyTuple_GetItem(PyObject *p, Py_ssize_t pos)
    *Return value: Borrowed reference.** Part of the Stable ABI.*

   *p* の指すタプルオブジェクト内の、位置 *pos* にあるオブジェクトを返
   します。 *pos* が負であるか範囲を超えている場合、 "NULL" を返して
   "IndexError" 例外をセットします。

PyObject *PyTuple_GET_ITEM(PyObject *p, Py_ssize_t pos)
    *Return value: Borrowed reference.*

   "PyTuple_GetItem()" に似ていますが、引数に対するエラーチェックを行
   いません。

PyObject *PyTuple_GetSlice(PyObject *p, Py_ssize_t low, Py_ssize_t high)
    *Return value: New reference.** Part of the Stable ABI.*

   成功すると *p* の *low* から *high* までの間を指し示すタプルのスラ
   イスを返し、失敗すると "NULL" を返します。Python の式 "p[low:high]"
   と同じです。リストの終端からのインデックスはサポートされていません
   。

int PyTuple_SetItem(PyObject *p, Py_ssize_t pos, PyObject *o)
    * Part of the Stable ABI.*

   *p* の指すタプルオブジェクト内の、位置 *pos* にあるオブジェクトへの
   参照を入れます。成功すれば "0" を返します。 *pos* が範囲を超えてい
   る場合、 "-1" を返して "IndexError" 例外をセットします。

   注釈:

     この関数は *o* への参照を "盗み取り" ます。また、変更先のインデク
     スにすでに別の要素が入っている場合、その要素に対する参照を放棄し
     ます。

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

   "PyTuple_SetItem()" に似ていますが、エラーチェックを行わず、新たな
   タプルに値を入れるとき *以外には使ってはなりません* 。

   注釈:

     このマクロは *o* への参照を "盗み取り" ます。また、
     "PyTuple_SetItem()" と違って、要素の置き換えが生じても置き換えら
     れるオブジェクトへの参照を放棄 *しません* ; その結果、タプル中の
     位置 *pos* で参照されていたオブジェクトがメモリリークを引き起こし
     ます。

int _PyTuple_Resize(PyObject **p, Py_ssize_t newsize)

   タプルをリサイズする際に使えます。 *newsize* はタプルの新たな長さで
   す。タプルは変更不能なオブジェクト *ということになっている* ので、
   この関数はこのオブジェクトに対してただ一つしか参照がない時以外には
   使ってはなりません。タプルがコード中の他の部分ですでに参照されてい
   る場合には、この関数を *使ってはなりません* 。タプルは常に指定サイ
   ズの末尾まで伸縮します。成功した場合には "0" を返します。クライアン
   トコードは、 "*p" の値が呼び出し前と同じになると期待してはなりませ
   ん。 "*p" が置き換えられた場合、オリジナルの "*p" は破壊されます。
   失敗すると "-1" を返し、 "*p" を "NULL" に設定して、  "MemoryError"
   または "SystemError" を送出します。


Struct Sequence オブジェクト
****************************

struct sequence オブジェクトは "namedtuple()" オブジェクトと等価なC オ
ブジェクトです。 つまり、その要素に属性を通してアクセスすることができ
るシーケンスです。 struct sequence を生成するには、まず特定のstruct
sequence 型を生成しなければなりません。

PyTypeObject *PyStructSequence_NewType(PyStructSequence_Desc *desc)
    *Return value: New reference.** Part of the Stable ABI.*

   後述の *desc* 中のデータから新しい struct sequence 型を生成します。
   返される型のインスタンスは "PyStructSequence_New()" で生成できます
   。

void PyStructSequence_InitType(PyTypeObject *type, PyStructSequence_Desc *desc)

   struct sequence 型である *type* を *desc* をもとにその場で初期化し
   ます。

int PyStructSequence_InitType2(PyTypeObject *type, PyStructSequence_Desc *desc)

   "PyStructSequence_InitType" と同じですが、成功した場合には "0" を、
   失敗した場合には "-1" を返します。

   バージョン 3.4 で追加.

type PyStructSequence_Desc
    * Part of the Stable ABI (including all members).*

   生成するstruct sequence 型のメタデータを保持します。

   +---------------------+--------------------------------+----------------------------------------+
   | フィールド          | C の型                         | 意味                                   |
   |=====================|================================|========================================|
   | "name"              | "const char *"                 | 生成するstruct sequence 型の名前       |
   +---------------------+--------------------------------+----------------------------------------+
   | "doc"               | "const char *"                 | 生成する型のdocstringへのポインタ、ま  |
   |                     |                                | たは省略する場合は "NULL"              |
   +---------------------+--------------------------------+----------------------------------------+
   | "fields"            | "PyStructSequence_Field *"     | 新しい型のフィールド名を格納した       |
   |                     |                                | "NULL" 終端された配列へのポインタ      |
   +---------------------+--------------------------------+----------------------------------------+
   | "n_in_sequence"     | "int"                          | Python 側で可視となるフィールドの数 (  |
   |                     |                                | もしタプルとして使用する場合)          |
   +---------------------+--------------------------------+----------------------------------------+

type PyStructSequence_Field
    * Part of the Stable ABI (including all members).*

   struct sequenceのフィールドについて記述します。struct sequence はタ
   プルをモデルにしているため、全てのフィールドは "PyObject*" として型
   付けされます。 "PyStructSequence_Desc" の "fields" 配列の添え字によ
   って struct sequenceのどのフィールドについて記載しているかが決まり
   ます。

   +-------------+--------------------+-------------------------------------------+
   | フィールド  | C の型             | 意味                                      |
   |=============|====================|===========================================|
   | "name"      | "const char *"     | フィールドの名前。もし名前づけされたフィ  |
   |             |                    | ールドのリストの終端を表す 場合は "NULL"  |
   |             |                    | 。名前がないままにする場合は、            |
   |             |                    | "PyStructSequence_UnnamedField" を設定し  |
   |             |                    | ます                                      |
   +-------------+--------------------+-------------------------------------------+
   | "doc"       | "const char *"     | フィールドのdocstring、省略する場合は     |
   |             |                    | "NULL"                                    |
   +-------------+--------------------+-------------------------------------------+

const char *const PyStructSequence_UnnamedField

   フィールド名を名前がないままするための特殊な値。

   バージョン 3.9 で変更: 型が "char *" から変更されました。

PyObject *PyStructSequence_New(PyTypeObject *type)
    *Return value: New reference.** Part of the Stable ABI.*

   *type* のインスタンスを生成します。 *type* は
   "PyStructSequence_NewType()" によって事前に生成していなければなりま
   せん。

PyObject *PyStructSequence_GetItem(PyObject *p, Py_ssize_t pos)
    *Return value: Borrowed reference.** Part of the Stable ABI.*

   *p* の指すstruct sequence内の、位置 *pos* にあるオブジェクトを返し
   ます。境界チェックを行いません。

PyObject *PyStructSequence_GET_ITEM(PyObject *p, Py_ssize_t pos)
    *Return value: Borrowed reference.*

   "PyStructSequence_GetItem()" と同等のマクロです。

void PyStructSequence_SetItem(PyObject *p, Py_ssize_t pos, PyObject *o)
    * Part of the Stable ABI.*

   struct sequence *p* の *pos* の位置にあるフィールドに値 *o* を設定
   します。"PyTuple_SET_ITEM()" のように、生成したてのインスタンスに対
   してのみ使用すべきです。

   注釈:

     この関数は *o* への参照を "盗み取り" ます。

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

   "PyStructSequence_SetItem()" と同等のマクロ。

   注釈:

     この関数は *o* への参照を "盗み取り" ます。
