diff options
author | Tim Peters <tim.peters@gmail.com> | 2001-09-11 19:48:03 (GMT) |
---|---|---|
committer | Tim Peters <tim.peters@gmail.com> | 2001-09-11 19:48:03 (GMT) |
commit | 7b07a41e9f078065b966a2414a24c0e5b7889ef7 (patch) | |
tree | 60d61099c526136f5b3674857ef0fb3651d3be22 /Objects/tupleobject.c | |
parent | f0b0f680fe2c8fb4af1c563c57efea29bec1bff6 (diff) | |
download | cpython-7b07a41e9f078065b966a2414a24c0e5b7889ef7.zip cpython-7b07a41e9f078065b966a2414a24c0e5b7889ef7.tar.gz cpython-7b07a41e9f078065b966a2414a24c0e5b7889ef7.tar.bz2 |
The endless 460020 bug.
Disable t[:], t*0, t*1 optimizations when t is of a tuple subclass type.
Diffstat (limited to 'Objects/tupleobject.c')
-rw-r--r-- | Objects/tupleobject.c | 15 |
1 files changed, 9 insertions, 6 deletions
diff --git a/Objects/tupleobject.c b/Objects/tupleobject.c index b07eb74..f371e1e 100644 --- a/Objects/tupleobject.c +++ b/Objects/tupleobject.c @@ -298,8 +298,7 @@ tupleslice(register PyTupleObject *a, register int ilow, register int ihigh) ihigh = a->ob_size; if (ihigh < ilow) ihigh = ilow; - if (ilow == 0 && ihigh == a->ob_size) { - /* XXX can only do this if tuples are immutable! */ + if (ilow == 0 && ihigh == a->ob_size && PyTuple_CheckExact(a)) { Py_INCREF(a); return (PyObject *)a; } @@ -366,10 +365,14 @@ tuplerepeat(PyTupleObject *a, int n) if (n < 0) n = 0; if (a->ob_size == 0 || n == 1) { - /* Since tuples are immutable, we can return a shared - copy in this case */ - Py_INCREF(a); - return (PyObject *)a; + if (PyTuple_CheckExact(a)) { + /* Since tuples are immutable, we can return a shared + copy in this case */ + Py_INCREF(a); + return (PyObject *)a; + } + if (a->ob_size == 0) + return PyTuple_New(0); } size = a->ob_size * n; if (size/a->ob_size != n) |