summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorWalter Dörwald <walter@livinglogic.de>2003-02-10 17:36:40 (GMT)
committerWalter Dörwald <walter@livinglogic.de>2003-02-10 17:36:40 (GMT)
commit8dd19321bbb3b4f94d15ca3a405053265b99e91e (patch)
tree8fd34769278798e5b54dfe4f9248cef56f2e3977
parent8d326b8581e8246d006bd4c5ab1d9f30972ef5cb (diff)
downloadcpython-8dd19321bbb3b4f94d15ca3a405053265b99e91e.zip
cpython-8dd19321bbb3b4f94d15ca3a405053265b99e91e.tar.gz
cpython-8dd19321bbb3b4f94d15ca3a405053265b99e91e.tar.bz2
Change filtertuple() to use tp_as_sequence->sq_item
instead of PyTuple_GetItem, so an overwritten __getitem__ in a tuple subclass works. SF bug #665835.
-rw-r--r--Lib/test/test_builtin.py3
-rw-r--r--Python/bltinmodule.c7
2 files changed, 7 insertions, 3 deletions
diff --git a/Lib/test/test_builtin.py b/Lib/test/test_builtin.py
index 9af3233..f52d9c6 100644
--- a/Lib/test/test_builtin.py
+++ b/Lib/test/test_builtin.py
@@ -419,7 +419,6 @@ class BuiltinTest(unittest.TestCase):
def test_filter_subclasses(self):
# test, that filter() never returns tuple, str or unicode subclasses
# and that the result always go's through __getitem__
- # FIXME: For tuple currently it doesn't go through __getitem__
funcs = (None, lambda x: True)
class tuple2(tuple):
def __getitem__(self, index):
@@ -428,7 +427,7 @@ class BuiltinTest(unittest.TestCase):
def __getitem__(self, index):
return 2*str.__getitem__(self, index)
inputs = {
- tuple2: {(): (), (1, 2, 3): (1, 2, 3)}, # FIXME
+ tuple2: {(): (), (1, 2, 3): (2, 4, 6)},
str2: {"": "", "123": "112233"}
}
if have_unicode:
diff --git a/Python/bltinmodule.c b/Python/bltinmodule.c
index b9aa85c..338e38d 100644
--- a/Python/bltinmodule.c
+++ b/Python/bltinmodule.c
@@ -1888,8 +1888,13 @@ filtertuple(PyObject *func, PyObject *tuple)
PyObject *item, *good;
int ok;
- if ((item = PyTuple_GetItem(tuple, i)) == NULL)
+ if (tuple->ob_type->tp_as_sequence &&
+ tuple->ob_type->tp_as_sequence->sq_item) {
+ item = tuple->ob_type->tp_as_sequence->sq_item(tuple, i);
+ } else {
+ PyErr_SetString(PyExc_TypeError, "unsubscriptable object");
goto Fail_1;
+ }
if (func == Py_None) {
Py_INCREF(item);
good = item;