]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
Issue #19288: Fixed the "in" operator of dbm.gnu databases for string
authorSerhiy Storchaka <storchaka@gmail.com>
Thu, 24 Oct 2013 21:06:52 +0000 (00:06 +0300)
committerSerhiy Storchaka <storchaka@gmail.com>
Thu, 24 Oct 2013 21:06:52 +0000 (00:06 +0300)
argument.  Original patch by Arfrever Frehtes Taifersar Arahesis.

Lib/test/test_dbm_gnu.py
Misc/NEWS
Modules/_gdbmmodule.c

index bf6294685a319a022e82ecfa42b230aed6b1b1f7..4fb66c54b8c6afbdee59d48e910636b8be8fe3b5 100755 (executable)
@@ -24,6 +24,7 @@ class TestGdbm(unittest.TestCase):
         self.g[b'bytes'] = b'data'
         key_set = set(self.g.keys())
         self.assertEqual(key_set, set([b'a', b'bytes', b'12345678910']))
+        self.assertIn('a', self.g)
         self.assertIn(b'a', self.g)
         self.assertEqual(self.g[b'bytes'], b'data')
         key = self.g.firstkey()
index b43fa9a058b05b34cb9233a657ab6439405eb84c..854a4a09c6ed1dd049fdbfe00ddc8b05ada47b35 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -81,6 +81,9 @@ Core and Builtins
 Library
 -------
 
+- Issue #19288: Fixed the "in" operator of dbm.gnu databases for string
+  argument.  Original patch by Arfrever Frehtes Taifersar Arahesis.
+
 - Issue #19287: Fixed the "in" operator of dbm.ndbm databases for string
   argument.  Original patch by Arfrever Frehtes Taifersar Arahesis.
 
index 474561b235f28f805ae2bc1655fda85ec8dc9ccf..0bd59c8aa28ecbdfce5b8e1b8af8694fa0dd1f6d 100644 (file)
@@ -290,20 +290,29 @@ dbm_contains(PyObject *self, PyObject *arg)
 {
     dbmobject *dp = (dbmobject *)self;
     datum key;
+    Py_ssize_t size;
 
     if ((dp)->di_dbm == NULL) {
         PyErr_SetString(DbmError,
                         "GDBM object has already been closed");
         return -1;
     }
-    if (!PyBytes_Check(arg)) {
+    if (PyUnicode_Check(arg)) {
+        key.dptr = PyUnicode_AsUTF8AndSize(arg, &size);
+        key.dsize = size;
+        if (key.dptr == NULL)
+            return -1;
+    }
+    else if (!PyBytes_Check(arg)) {
         PyErr_Format(PyExc_TypeError,
-                     "gdbm key must be bytes, not %.100s",
+                     "gdbm key must be bytes or string, not %.100s",
                      arg->ob_type->tp_name);
         return -1;
     }
-    key.dptr = PyBytes_AS_STRING(arg);
-    key.dsize = PyBytes_GET_SIZE(arg);
+    else {
+        key.dptr = PyBytes_AS_STRING(arg);
+        key.dsize = PyBytes_GET_SIZE(arg);
+    }
     return gdbm_exists(dp->di_dbm, key);
 }