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)