リストオブジェクト
******************

PyListObject

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

PyTypeObject PyList_Type

   This instance of "PyTypeObject" represents the Python list type.
   This is the same object as "list" in the Python layer.

int PyList_Check(PyObject *p)

   *p* がリストオブジェクトか、リスト型のサブタイプのインスタンスであ
   る場合に真を返します。

   バージョン 2.2 で変更: Allowed subtypes to be accepted.

int PyList_CheckExact(PyObject *p)

   *p* がリスト型オブジェクトであり、かつリスト型のサブクラスのインス
   タンスでない場合に真を返します。

   バージョン 2.2 で追加.

PyObject* PyList_New(Py_ssize_t len)
    *Return value: New reference.*

   サイズが *len* 新たなリストオブジェクトを返します。失敗すると
   *NULL* を返します。

   注釈: *len* が0より大きいとき、返されるリストオブジェクトの要素に
     は "NULL" がセットされています。なので、 "PyList_SetItem()" で本
     当に オブジェクトをセットするまでは、Pythonコードにこのオブジェク
     トを 渡したり、 "PySequence_SetItem()" のような抽象APIを利用して
     はいけ ません。

   バージョン 2.5 で変更: This function used an "int" for *size*. This
   might require changes in your code for properly supporting 64-bit
   systems.

Py_ssize_t PyList_Size(PyObject *list)

   リストオブジェクト *list* の長さを返します; リストオブジェクトにお
   ける "len(list)" と同じです。

   バージョン 2.5 で変更: This function returned an "int". This might
   require changes in your code for properly supporting 64-bit
   systems.

Py_ssize_t PyList_GET_SIZE(PyObject *list)

   マクロ形式でできた "PyList_Size()" で、エラーチェックをしません。

   バージョン 2.5 で変更: This macro returned an "int". This might
   require changes in your code for properly supporting 64-bit
   systems.

PyObject* PyList_GetItem(PyObject *list, Py_ssize_t index)
    *Return value: Borrowed reference.*

   *list* の指すリストオブジェクト内の、位置 *index* にあるオブジェク
   トを返します。位置は正である必要があり、リスト終端からのインデック
   スはサポートされていません。 *index* が範囲を超えている場合、
   *NULL* を返して "IndexError" 例外をセットします。

   バージョン 2.5 で変更: This function used an "int" for *index*.
   This might require changes in your code for properly supporting
   64-bit systems.

PyObject* PyList_GET_ITEM(PyObject *list, Py_ssize_t i)
    *Return value: Borrowed reference.*

   マクロ形式でできた "PyList_GetItem()" で、エラーチェックをしません
   。

   バージョン 2.5 で変更: This macro used an "int" for *i*. This might
   require changes in your code for properly supporting 64-bit
   systems.

int PyList_SetItem(PyObject *list, Py_ssize_t index, PyObject *item)

   リストオブジェクト内の位置 *index* に、オブジェクト *item* を挿入し
   ます。成功した場合には "0" を返し、失敗すると "-1" を返します。

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

   バージョン 2.5 で変更: This function used an "int" for *index*.
   This might require changes in your code for properly supporting
   64-bit systems.

void PyList_SET_ITEM(PyObject *list, Py_ssize_t i, PyObject *o)

   "PyList_SetItem()" をマクロによる実装で、エラーチェックを行いません
   。このマクロは、新たなリストのまだ要素を入れたことのない位置に要素
   を入れるときにのみ使います。

   注釈: This macro 「steals」 a reference to *item*, and, unlike
     "PyList_SetItem()", does *not* discard a reference to any item
     that it being replaced; any reference in *list* at position *i*
     will be leaked.

   バージョン 2.5 で変更: This macro used an "int" for *i*. This might
   require changes in your code for properly supporting 64-bit
   systems.

int PyList_Insert(PyObject *list, Py_ssize_t index, PyObject *item)

   要素 *item* をリスト *list* のインデックス *index* の前に挿入します
   。成功すると "0" を返します。失敗すると "-1" を返し、例外をセットし
   ます。"list.insert(index, item)" に類似した機能です。

   バージョン 2.5 で変更: This function used an "int" for *index*.
   This might require changes in your code for properly supporting
   64-bit systems.

int PyList_Append(PyObject *list, PyObject *item)

   オブジェクト *item* を *list* の末尾に追加します。成功すると "0" を
   返します; 失敗すると "-1" を返し、例外をセットします。
   "list.append(item)"  に類似した機能です。

PyObject* PyList_GetSlice(PyObject *list, Py_ssize_t low, Py_ssize_t high)
    *Return value: New reference.*

   *list* 内の、*low* から *high* の *間の* オブジェクトからなるリスト
   を返します。失敗すると *NULL* を返し、例外をセットします。
   "list[low:high]" に類似した機能です。ただし、Python のスライスにあ
   る負のインデックスはサポートされていません。

   バージョン 2.5 で変更: This function used an "int" for *low* and
   *high*. This might require changes in your code for properly
   supporting 64-bit systems.

int PyList_SetSlice(PyObject *list, Py_ssize_t low, Py_ssize_t high, PyObject *itemlist)

   *list* 内の、*low* から *high* の間のオブジェクトを、*itemlist* の
   内容にします。"list[low:high] = itemlist" と類似の機能です。
   *itemlist* は *NULL* でもよく、空リストの代入 (指定スライスの削除)
   になります。成功した場合には "0" を、失敗した場合には "-1" を返しま
   す。Python のスライスにある負のインデックスはサポートされていません
   。

   バージョン 2.5 で変更: This function used an "int" for *low* and
   *high*. This might require changes in your code for properly
   supporting 64-bit systems.

int PyList_Sort(PyObject *list)

   *list* の内容をインプレースでソートします。成功した場合には "0" を
   、失敗した場合には "-1" を返します。"list.sort()" と同じです。

int PyList_Reverse(PyObject *list)

   *list* の要素をインプレースで反転します。成功した場合には "0" を、
   失敗した場合には "-1" を返します。"list.reverse()" と同じです。

PyObject* PyList_AsTuple(PyObject *list)
    *Return value: New reference.*

   *list* の内容が入った新たなタプルオブジェクトを返します;
   "tuple(list)" と同じです。
