Commit 2f575a61 authored by scoder's avatar scoder

Merge pull request #258 from zyv/fix_array_extend

Multiple fixes to array.extend()
parents 06363710 7f6ac8a3
...@@ -154,11 +154,10 @@ cdef inline int extend_buffer(array self, char* stuff, Py_ssize_t n): ...@@ -154,11 +154,10 @@ cdef inline int extend_buffer(array self, char* stuff, Py_ssize_t n):
return -1 return -1
memcpy(self.data.as_chars + orgsize * itemsize, stuff, n * itemsize) memcpy(self.data.as_chars + orgsize * itemsize, stuff, n * itemsize)
cdef inline int extend(array self, array other): cdef inline int extend(array self, array other) except -2:
""" extend array with data from another array; types must match. """ """ extend array with data from another array; types must match. """
if self.ob_descr.typecode != self.ob_descr.typecode: if self.ob_descr.typecode != other.ob_descr.typecode:
PyErr_BadArgument() PyErr_BadArgument()
return -1
return extend_buffer(self, other.data.as_chars, Py_SIZE(other)) return extend_buffer(self, other.data.as_chars, Py_SIZE(other))
cdef inline void zero(array op): cdef inline void zero(array op):
......
...@@ -147,8 +147,15 @@ def test_extend(): ...@@ -147,8 +147,15 @@ def test_extend():
""" """
cdef array.array ca = array.array('i', [1, 2, 3]) cdef array.array ca = array.array('i', [1, 2, 3])
cdef array.array cb = array.array('i', [4, 5]) cdef array.array cb = array.array('i', [4, 5])
cdef array.array cf = array.array('f', [1.0, 2.0, 3.0])
array.extend(ca, cb) array.extend(ca, cb)
assert list(ca) == [1, 2, 3, 4, 5], list(ca) assert list(ca) == [1, 2, 3, 4, 5], list(ca)
try:
array.extend(ca, cf)
except TypeError:
pass
else:
raise AssertionError('tried to extend with an incompatible array type')
def test_likes(a): def test_likes(a):
""" """
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment