매핑 프로토콜
*************

"PyObject_GetItem()", "PyObject_SetItem()" 및 "PyObject_DelItem()"도
참조하십시오.

int PyMapping_Check(PyObject *o)

   객체가 매핑 프로토콜을 제공하거나 슬라이싱을 지원하면 "1"을 반환하
   고, 그렇지 않으면 "0"을 반환합니다. "__getitem__()" 메서드가 있는
   파이썬 클래스의 경우 "1"을 반환한다는 점에 유의하십시오; 일반적으로
   지원하는 키 형을 판단할 수 없기 때문입니다. 이 함수는 항상 성공합니
   다.

Py_ssize_t PyMapping_Size(PyObject *o)
Py_ssize_t PyMapping_Length(PyObject *o)

   성공 시 객체 *o*의 키 수를 반환하고, 실패하면 "-1"을 반환합니다. 이
   는 파이썬 표현식 "len(o)"와 동등합니다.

PyObject* PyMapping_GetItemString(PyObject *o, const char *key)
    *Return value: New reference.*

   문자열 *key*에 해당하는 *o*의 요소나 실패 시 "NULL"을 반환합니다.
   이는 파이썬 표현식 "o[key]"와 동등합니다. "PyObject_GetItem()"도 참
   조하십시오.

int PyMapping_SetItemString(PyObject *o, const char *key, PyObject *v)

   객체 *o*에서 문자열 *key*를 값 *v*에 매핑합니다. 실패하면 "-1"을 반
   환합니다. 이것은 파이썬 문장 "o[key] = v"와 동등합니다.
   "PyObject_SetItem()"도 참조하십시오. 이 함수는 *v*에 대한 참조를 훔
   치지 *않습니다*.

int PyMapping_DelItem(PyObject *o, PyObject *key)

   객체 *o*에서 객체 *key*에 대한 매핑을 제거합니다. 실패하면 "-1"을
   반환합니다. 이것은 파이썬 문장 "del o[key]"와 동등합니다. 이것은
   "PyObject_DelItem()"의 별칭입니다.

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

   객체 *o*에서 문자열 *key*에 대한 매핑을 제거합니다. 실패하면 "-1"을
   반환합니다. 이것은 파이썬 문장 "del o[key]"와 동등합니다.

int PyMapping_HasKey(PyObject *o, PyObject *key)

   매핑 객체에 *key* 키가 있으면 "1"을 반환하고, 그렇지 않으면 "0"을
   반환합니다. 이는 파이썬 표현식 "key in o"와 동등합니다. 이 함수는
   항상 성공합니다.

   "__getitem__()" 메서드를 호출하는 동안 발생하는 예외는 억제됨에 유
   의하십시오. 에러 보고를 받으려면 대신 "PyObject_GetItem()"을 사용하
   십시오.

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

   매핑 객체에 *key* 키가 있으면 "1"을 반환하고, 그렇지 않으면 "0"을
   반환합니다. 이는 파이썬 표현식 "key in o"와 동등합니다. 이 함수는
   항상 성공합니다.

   "__getitem__()" 메서드를 호출하고 임시 문자열 객체를 만드는 동안 발
   생하는 예외는 억제됨에 유의하십시오. 에러 보고를 받으려면 대신
   "PyMapping_GetItemString()"을 사용하십시오.

PyObject* PyMapping_Keys(PyObject *o)
    *Return value: New reference.*

   성공하면, 객체 *o*의 키 리스트를 반환합니다. 실패하면, "NULL"을 반
   환합니다.

   버전 3.7에서 변경: 이전에는 함수가 리스트나 튜플을 반환했습니다.

PyObject* PyMapping_Values(PyObject *o)
    *Return value: New reference.*

   성공하면, 객체 *o*의 값 리스트를 반환합니다. 실패하면, "NULL"을 반
   환합니다.

   버전 3.7에서 변경: 이전에는 함수가 리스트나 튜플을 반환했습니다.

PyObject* PyMapping_Items(PyObject *o)
    *Return value: New reference.*

   성공하면, 객체 *o*에 있는 항목 리스트를 반환합니다. 여기서 각 항목
   은 키-값 쌍을 포함하는 튜플입니다. 실패하면, "NULL"을 반환합니다.

   버전 3.7에서 변경: 이전에는 함수가 리스트나 튜플을 반환했습니다.
