マップ型プロトコル (mapping protocol)
*************************************

"PyObject_GetItem()", "PyObject_SetItem()", "PyObject_DelItem()" も参
照してください。

int PyMapping_Check(PyObject *o)
    * 次に属します: Stable ABI.*

   Return "1" if the object provides the mapping protocol or supports
   slicing, and "0" otherwise.  Note that it returns "1" for Python
   classes with a "__getitem__()" method, since in general it is
   impossible to determine what type of keys the class supports. This
   function always succeeds.

Py_ssize_t PyMapping_Size(PyObject *o)
Py_ssize_t PyMapping_Length(PyObject *o)
    * 次に属します: Stable ABI.*

   成功するとオブジェクト *o* 中のキーの数を返し、失敗すると "-1" を返
   します。これは、Python の式 "len(o)" と同じになります。

PyObject *PyMapping_GetItemString(PyObject *o, const char *key)
    *戻り値: 新しい参照。** 次に属します: Stable ABI.*

   This is the same as "PyObject_GetItem()", but *key* is specified as
   a const char* UTF-8 encoded bytes string, rather than a PyObject*.

int PyMapping_GetOptionalItem(PyObject *obj, PyObject *key, PyObject **result)
    * 次に属します: Stable ABI (バージョン 3.13 より).*

   Variant of "PyObject_GetItem()" which doesn't raise "KeyError" if
   the key is not found.

   If the key is found, return "1" and set **result* to a new *strong
   reference* to the corresponding value. If the key is not found,
   return "0" and set **result* to "NULL"; the "KeyError" is silenced.
   If an error other than "KeyError" is raised, return "-1" and set
   **result* to "NULL".

   Added in version 3.13.

int PyMapping_GetOptionalItemString(PyObject *obj, const char *key, PyObject **result)
    * 次に属します: Stable ABI (バージョン 3.13 より).*

   This is the same as "PyMapping_GetOptionalItem()", but *key* is
   specified as a const char* UTF-8 encoded bytes string, rather than
   a PyObject*.

   Added in version 3.13.

int PyMapping_SetItemString(PyObject *o, const char *key, PyObject *v)
    * 次に属します: Stable ABI.*

   This is the same as "PyObject_SetItem()", but *key* is specified as
   a const char* UTF-8 encoded bytes string, rather than a PyObject*.

int PyMapping_DelItem(PyObject *o, PyObject *key)

   This is an alias of "PyObject_DelItem()".

int PyMapping_DelItemString(PyObject *o, const char *key)

   This is the same as "PyObject_DelItem()", but *key* is specified as
   a const char* UTF-8 encoded bytes string, rather than a PyObject*.

int PyMapping_HasKeyWithError(PyObject *o, PyObject *key)
    * 次に属します: Stable ABI (バージョン 3.13 より).*

   Return "1" if the mapping object has the key *key* and "0"
   otherwise. This is equivalent to the Python expression "key in o".
   On failure, return "-1".

   Added in version 3.13.

int PyMapping_HasKeyStringWithError(PyObject *o, const char *key)
    * 次に属します: Stable ABI (バージョン 3.13 より).*

   This is the same as "PyMapping_HasKeyWithError()", but *key* is
   specified as a const char* UTF-8 encoded bytes string, rather than
   a PyObject*.

   Added in version 3.13.

int PyMapping_HasKey(PyObject *o, PyObject *key)
    * 次に属します: Stable ABI.*

   マップ型オブジェクトがキー *key* を持つ場合に "1" を返し、そうでな
   いときには "0" を返します。これは、Python の式 "key in o" と等価で
   す。この関数呼び出しは常に成功します。

   注釈:

     Exceptions which occur when this calls "__getitem__()" method are
     silently ignored. For proper error handling, use
     "PyMapping_HasKeyWithError()", "PyMapping_GetOptionalItem()" or
     "PyObject_GetItem()" instead.

int PyMapping_HasKeyString(PyObject *o, const char *key)
    * 次に属します: Stable ABI.*

   This is the same as "PyMapping_HasKey()", but *key* is specified as
   a const char* UTF-8 encoded bytes string, rather than a PyObject*.

   注釈:

     Exceptions that occur when this calls "__getitem__()" method or
     while creating the temporary "str" object are silently ignored.
     For proper error handling, use
     "PyMapping_HasKeyStringWithError()",
     "PyMapping_GetOptionalItemString()" or
     "PyMapping_GetItemString()" instead.

PyObject *PyMapping_Keys(PyObject *o)
    *戻り値: 新しい参照。** 次に属します: Stable ABI.*

   成功するとオブジェクト *o* のキーからなるリストを返します。 失敗す
   ると "NULL" を返します。

   バージョン 3.7 で変更: 以前は、関数はリストもしくはタプルを返してい
   ました。

PyObject *PyMapping_Values(PyObject *o)
    *戻り値: 新しい参照。** 次に属します: Stable ABI.*

   成功するとオブジェクト *o* の値からなるリストを返します。 失敗する
   と "NULL" を返します。

   バージョン 3.7 で変更: 以前は、関数はリストもしくはタプルを返してい
   ました。

PyObject *PyMapping_Items(PyObject *o)
    *戻り値: 新しい参照。** 次に属します: Stable ABI.*

   成功するとオブジェクト *o* の要素からなるリストを返し、各要素はキー
   と値のペアが入ったタプルになっています。 失敗すると "NULL" を返しま
   す。

   バージョン 3.7 で変更: 以前は、関数はリストもしくはタプルを返してい
   ました。
