summaryrefslogtreecommitdiffstats
path: root/Objects
diff options
context:
space:
mode:
authorNeil Schemenauer <nascheme@enme.ucalgary.ca>2004-09-24 19:17:26 (GMT)
committerNeil Schemenauer <nascheme@enme.ucalgary.ca>2004-09-24 19:17:26 (GMT)
commit927a57fbeb584f8f0cc71cd04619f040d5ba872a (patch)
treef4c9e190a6eb47600e24f454ad163dca86ba26fc /Objects
parentfb6ba07d9c6cccee260a70aef8f3cf52c5d26776 (diff)
downloadcpython-927a57fbeb584f8f0cc71cd04619f040d5ba872a.zip
cpython-927a57fbeb584f8f0cc71cd04619f040d5ba872a.tar.gz
cpython-927a57fbeb584f8f0cc71cd04619f040d5ba872a.tar.bz2
Ensure negative offsets cannot be passed to buffer(). When composing
buffers, compute the new buffer size based on the old buffer size. Fixes SF bug #1034242.
Diffstat (limited to 'Objects')
-rw-r--r--Objects/bufferobject.c17
1 files changed, 15 insertions, 2 deletions
diff --git a/Objects/bufferobject.c b/Objects/bufferobject.c
index e0344d8..674d2b5 100644
--- a/Objects/bufferobject.c
+++ b/Objects/bufferobject.c
@@ -90,10 +90,23 @@ buffer_from_memory(PyObject *base, int size, int offset, void *ptr,
static PyObject *
buffer_from_object(PyObject *base, int size, int offset, int readonly)
{
+ if (offset < 0) {
+ PyErr_SetString(PyExc_ValueError,
+ "offset must be zero or positive");
+ return NULL;
+ }
if ( PyBuffer_Check(base) && (((PyBufferObject *)base)->b_base) ) {
/* another buffer, refer to the base object */
- offset += ((PyBufferObject *)base)->b_offset;
- base = ((PyBufferObject *)base)->b_base;
+ PyBufferObject *b = (PyBufferObject *)base;
+ if (b->b_size != Py_END_OF_BUFFER) {
+ int base_size = b->b_size - offset;
+ if (base_size < 0)
+ base_size = 0;
+ if (size == Py_END_OF_BUFFER || size > base_size)
+ size = base_size;
+ }
+ offset += b->b_offset;
+ base = b->b_base;
}
return buffer_from_memory(base, size, offset, NULL, readonly);
}