Merge 3.5.
This commit is contained in:
commit
3407cc26cb
|
@ -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'
|
||||||
|
|
|
@ -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()
|
||||||
|
|
|
@ -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 *
|
||||||
|
|
Loading…
Reference in New Issue