Issue #29444: Fixed out-of-bounds buffer access in the group() method of
the match object. Based on patch by WGH.
This commit is contained in:
commit
ef5176769d
|
@ -1821,6 +1821,16 @@ SUBPATTERN None 0 0
|
|||
warnings.simplefilter('error', BytesWarning)
|
||||
self.assertNotEqual(pattern3, pattern1)
|
||||
|
||||
def test_bug_29444(self):
|
||||
s = bytearray(b'abcdefgh')
|
||||
m = re.search(b'[a-h]+', s)
|
||||
m2 = re.search(b'[e-h]+', s)
|
||||
self.assertEqual(m.group(), b'abcdefgh')
|
||||
self.assertEqual(m2.group(), b'efgh')
|
||||
s[:] = b'xyz'
|
||||
self.assertEqual(m.group(), b'xyz')
|
||||
self.assertEqual(m2.group(), b'')
|
||||
|
||||
|
||||
class PatternReprTests(unittest.TestCase):
|
||||
def check(self, pattern, expected):
|
||||
|
|
|
@ -223,6 +223,9 @@ Extension Modules
|
|||
Library
|
||||
-------
|
||||
|
||||
- Issue #29444: Fixed out-of-bounds buffer access in the group() method of
|
||||
the match object. Based on patch by WGH.
|
||||
|
||||
- Issue #29377: Add SlotWrapperType, MethodWrapperType, and
|
||||
MethodDescriptorType built-in types to types module.
|
||||
Original patch by Manuel Krebber.
|
||||
|
|
|
@ -1945,6 +1945,7 @@ match_getslice_by_index(MatchObject* self, Py_ssize_t index, PyObject* def)
|
|||
Py_buffer view;
|
||||
PyObject *result;
|
||||
void* ptr;
|
||||
Py_ssize_t i, j;
|
||||
|
||||
if (index < 0 || index >= self->groups) {
|
||||
/* raise IndexError if we were given a bad group number */
|
||||
|
@ -1966,8 +1967,12 @@ match_getslice_by_index(MatchObject* self, Py_ssize_t index, PyObject* def)
|
|||
ptr = getstring(self->string, &length, &isbytes, &charsize, &view);
|
||||
if (ptr == NULL)
|
||||
return NULL;
|
||||
result = getslice(isbytes, ptr,
|
||||
self->string, self->mark[index], self->mark[index+1]);
|
||||
|
||||
i = self->mark[index];
|
||||
j = self->mark[index+1];
|
||||
i = Py_MIN(i, length);
|
||||
j = Py_MIN(j, length);
|
||||
result = getslice(isbytes, ptr, self->string, i, j);
|
||||
if (isbytes && view.buf != NULL)
|
||||
PyBuffer_Release(&view);
|
||||
return result;
|
||||
|
|
Loading…
Reference in New Issue