From: Martin v. Löwis <martin@v.loewis.de> Date: Sat, 5 Jan 2002 10:50:30 +0000 (+0000) Subject: Implement PyObject_DelItemString. Fixes #498915. X-Git-Tag: v2.3c1~6884 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=b0d71d0ec6e575b7c379d55cb8366b26509ece53;p=python Implement PyObject_DelItemString. Fixes #498915. --- diff --git a/Include/abstract.h b/Include/abstract.h index 682c2f2e13..226e5e8d0c 100644 --- a/Include/abstract.h +++ b/Include/abstract.h @@ -445,6 +445,14 @@ xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx*/ statement: o[key]=v. */ + DL_IMPORT(int) PyObject_DelItemString(PyObject *o, char *key); + + /* + Remove the mapping for object, key, from the object *o. + Returns -1 on failure. This is equivalent to + the Python statement: del o[key]. + */ + DL_IMPORT(int) PyObject_DelItem(PyObject *o, PyObject *key); /* diff --git a/Objects/abstract.c b/Objects/abstract.c index 59314497bd..2acfd0865c 100644 --- a/Objects/abstract.c +++ b/Objects/abstract.c @@ -174,6 +174,24 @@ PyObject_DelItem(PyObject *o, PyObject *key) return -1; } +int +PyObject_DelItemString(PyObject *o, char *key) +{ + PyObject *okey; + int ret; + + if (o == NULL || key == NULL) { + null_error(); + return -1; + } + okey = PyString_FromString(key); + if (okey == NULL) + return -1; + ret = PyObject_DelItem(o, okey); + Py_DECREF(okey); + return ret; +} + int PyObject_AsCharBuffer(PyObject *obj, const char **buffer, int *buffer_len)