Protocolo de Mapeamento
***********************

Veja também "PyObject_GetItem()", "PyObject_SetItem()" e
"PyObject_DelItem()".

int PyMapping_Check(PyObject *o)

   Retorna "1" se o objeto fornece protocolo de mapeamento ou suporta
   fatiamento e "0" caso contrário. Note que ele retorna "1" para
   classes Python com um método "__getitem__()" visto que no caso
   geral é impossível determinar que tipo de chaves ele suporta. Esta
   função sempre tem sucesso.

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

   Retorna o número de chaves no objeto *o* em caso de sucesso e "-1"
   em caso de falha. Isso é equivalente à expressão Python "len(o)".

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

   Retorna o elemento de *o* correspondente à string *key* ou "NULL"
   em caso de falha. Este é o equivalente da expressão Python
   "o[key]". Veja também "PyObject_GetItem()".

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

   Map the string *key* to the value *v* in object *o*.  Returns "-1"
   on failure.  This is the equivalent of the Python statement "o[key]
   = v". See also "PyObject_SetItem()".

int PyMapping_DelItem(PyObject *o, PyObject *key)

   Remove o mapeamento para o objeto *key* do objeto *o*. Retorna "-1"
   em caso de falha. Isso é equivalente à instrução Python "del
   o[key]". Este é um alias de "PyObject_DelItem()".

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

   Remove o mapeamento para a string *key* do objeto *o*. Retorna "-1"
   em caso de falha. Isso é equivalente à instrução Python "del
   o[key]".

int PyMapping_HasKey(PyObject *o, PyObject *key)

   Retorna "1" se o objeto de mapeamento tiver a chave *key* e "0"
   caso contrário. Isso é equivalente à expressão Python "key in o".
   Esta função sempre tem sucesso.

   Observe que as exceções que ocorrem ao chamar o método
   "__getitem__()" serão suprimidas. Para obter relatórios de erros,
   use "PyObject_GetItem()".

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

   Retorna "1" se o objeto de mapeamento tiver a chave *key* e "0"
   caso contrário. Isso é equivalente à expressão Python "key in o".
   Esta função sempre tem sucesso.

   Observe que as exceções que ocorrem ao chamar o método
   "__getitem__()" e criar um objeto string temporário serão
   suprimidas. Para obter relatórios de erros, use
   "PyMapping_GetItemString()".

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

   Em caso de sucesso, retorna uma lista das chaves no objeto *o*. Em
   caso de falha, retorna "NULL".

   Alterado na versão 3.7: Anteriormente, a função retornava uma lista
   ou tupla.

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

   Em caso de sucesso, retorna uma lista dos valores no objeto *o*. Em
   caso de falha, retorna "NULL".

   Alterado na versão 3.7: Anteriormente, a função retornava uma lista
   ou tupla.

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

   Em caso de sucesso, retorna uma lista dos itens no objeto *o*, onde
   cada item é uma tupla contendo um par de valores-chave. Em caso de
   falha, retorna "NULL".

   Alterado na versão 3.7: Anteriormente, a função retornava uma lista
   ou tupla.
