Iaaue #25598: Fix memory_hex from #9951 for non-contiguous buffers.

This commit is contained in:
Stefan Krah 2015-11-10 18:17:22 +01:00
parent e46e09d0f5
commit 0ce5b6e268
3 changed files with 28 additions and 1 deletions

View File

@ -841,6 +841,11 @@ class TestBufferProtocol(unittest.TestCase):
# test tobytes() # test tobytes()
self.assertEqual(result.tobytes(), b) self.assertEqual(result.tobytes(), b)
# test hex()
m = memoryview(result)
h = "".join("%02x" % c for c in b)
self.assertEqual(m.hex(), h)
# lst := expected multi-dimensional logical representation # lst := expected multi-dimensional logical representation
# flatten(lst) := elements in C-order # flatten(lst) := elements in C-order
ff = fmt if fmt else 'B' ff = fmt if fmt else 'B'

View File

@ -512,6 +512,13 @@ class OtherTest(unittest.TestCase):
m[2:] = memoryview(p6).cast(format)[2:] m[2:] = memoryview(p6).cast(format)[2:]
self.assertEqual(d.value, 0.6) self.assertEqual(d.value, 0.6)
def test_memoryview_hex(self):
# Issue #9951: memoryview.hex() segfaults with non-contiguous buffers.
x = b'0' * 200000
m1 = memoryview(x)
m2 = m1[::-1]
self.assertEqual(m2.hex(), '30' * 200000)
if __name__ == "__main__": if __name__ == "__main__":
unittest.main() unittest.main()

View File

@ -2156,8 +2156,23 @@ static PyObject *
memory_hex(PyMemoryViewObject *self, PyObject *dummy) memory_hex(PyMemoryViewObject *self, PyObject *dummy)
{ {
Py_buffer *src = VIEW_ADDR(self); Py_buffer *src = VIEW_ADDR(self);
PyObject *bytes;
PyObject *ret;
CHECK_RELEASED(self); CHECK_RELEASED(self);
return _Py_strhex(src->buf, src->len);
if (MV_C_CONTIGUOUS(self->flags)) {
return _Py_strhex(src->buf, src->len);
}
bytes = memory_tobytes(self, dummy);
if (bytes == NULL)
return NULL;
ret = _Py_strhex(PyBytes_AS_STRING(bytes), Py_SIZE(bytes));
Py_DECREF(bytes);
return ret;
} }
static PyObject * static PyObject *