mirror of
https://github.com/python/cpython.git
synced 2025-10-07 15:42:02 +00:00
bpo-29649: Improve struct.pack_into() boundary error messages (#424)
This commit is contained in:
parent
5de85a1702
commit
f78b119364
3 changed files with 53 additions and 4 deletions
|
@ -578,6 +578,26 @@ class StructTest(unittest.TestCase):
|
||||||
self.check_sizeof('0s', 1)
|
self.check_sizeof('0s', 1)
|
||||||
self.check_sizeof('0c', 0)
|
self.check_sizeof('0c', 0)
|
||||||
|
|
||||||
|
def test_boundary_error_message(self):
|
||||||
|
regex = (
|
||||||
|
r'pack_into requires a buffer of at least 6 '
|
||||||
|
r'bytes for packing 1 bytes at offset 5 '
|
||||||
|
r'\(actual buffer size is 1\)'
|
||||||
|
)
|
||||||
|
with self.assertRaisesRegex(struct.error, regex):
|
||||||
|
struct.pack_into('b', bytearray(1), 5, 1)
|
||||||
|
|
||||||
|
def test_boundary_error_message_with_negative_offset(self):
|
||||||
|
byte_list = bytearray(10)
|
||||||
|
with self.assertRaisesRegex(
|
||||||
|
struct.error,
|
||||||
|
r'no space to pack 4 bytes at offset -2'):
|
||||||
|
struct.pack_into('<I', byte_list, -2, 123)
|
||||||
|
|
||||||
|
with self.assertRaisesRegex(
|
||||||
|
struct.error,
|
||||||
|
'offset -11 out of range for 10-byte buffer'):
|
||||||
|
struct.pack_into('<B', byte_list, -11, 123)
|
||||||
|
|
||||||
class UnpackIteratorTest(unittest.TestCase):
|
class UnpackIteratorTest(unittest.TestCase):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -303,6 +303,9 @@ Extension Modules
|
||||||
Library
|
Library
|
||||||
-------
|
-------
|
||||||
|
|
||||||
|
- bpo-29649: Improve struct.pack_into() exception messages for problems
|
||||||
|
with the buffer size and offset. Patch by Andrew Nester.
|
||||||
|
|
||||||
- bpo-29654: Support If-Modified-Since HTTP header (browser cache). Patch
|
- bpo-29654: Support If-Modified-Since HTTP header (browser cache). Patch
|
||||||
by Pierre Quentel.
|
by Pierre Quentel.
|
||||||
|
|
||||||
|
|
|
@ -1931,14 +1931,40 @@ s_pack_into(PyObject *self, PyObject **args, Py_ssize_t nargs, PyObject *kwnames
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Support negative offsets. */
|
/* Support negative offsets. */
|
||||||
if (offset < 0)
|
if (offset < 0) {
|
||||||
|
/* Check that negative offset is low enough to fit data */
|
||||||
|
if (offset + soself->s_size > 0) {
|
||||||
|
PyErr_Format(StructError,
|
||||||
|
"no space to pack %zd bytes at offset %zd",
|
||||||
|
soself->s_size,
|
||||||
|
offset);
|
||||||
|
PyBuffer_Release(&buffer);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Check that negative offset is not crossing buffer boundary */
|
||||||
|
if (offset + buffer.len < 0) {
|
||||||
|
PyErr_Format(StructError,
|
||||||
|
"offset %zd out of range for %zd-byte buffer",
|
||||||
|
offset,
|
||||||
|
buffer.len);
|
||||||
|
PyBuffer_Release(&buffer);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
offset += buffer.len;
|
offset += buffer.len;
|
||||||
|
}
|
||||||
|
|
||||||
/* Check boundaries */
|
/* Check boundaries */
|
||||||
if (offset < 0 || (buffer.len - offset) < soself->s_size) {
|
if ((buffer.len - offset) < soself->s_size) {
|
||||||
PyErr_Format(StructError,
|
PyErr_Format(StructError,
|
||||||
"pack_into requires a buffer of at least %zd bytes",
|
"pack_into requires a buffer of at least %zd bytes for "
|
||||||
soself->s_size);
|
"packing %zd bytes at offset %zd "
|
||||||
|
"(actual buffer size is %zd)",
|
||||||
|
soself->s_size + offset,
|
||||||
|
soself->s_size,
|
||||||
|
offset,
|
||||||
|
buffer.len);
|
||||||
PyBuffer_Release(&buffer);
|
PyBuffer_Release(&buffer);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue