summaryrefslogtreecommitdiff
path: root/msgpack/_msgpack.pyx
diff options
context:
space:
mode:
authorJoel Nothman <joel.nothman@gmail.com>2012-09-23 11:13:44 +1000
committerJoel Nothman <joel.nothman@gmail.com>2012-09-23 20:46:49 +1000
commite7c51d9089e9270ce197c00a6af1c60e45f36e97 (patch)
tree8d5c683b5406bcdf7abc37d1a6e866e1413a7435 /msgpack/_msgpack.pyx
parentffec10dff3839ae182cff3d9fff67ab3fe6165be (diff)
downloadmsgpack-python-e7c51d9089e9270ce197c00a6af1c60e45f36e97.tar.gz
Cleaner read_bytes and a test case
No longer reads via buffer for unbuffered bytes
Diffstat (limited to 'msgpack/_msgpack.pyx')
-rw-r--r--msgpack/_msgpack.pyx12
1 files changed, 5 insertions, 7 deletions
diff --git a/msgpack/_msgpack.pyx b/msgpack/_msgpack.pyx
index d7ea4b4..30fb9fc 100644
--- a/msgpack/_msgpack.pyx
+++ b/msgpack/_msgpack.pyx
@@ -458,13 +458,11 @@ cdef class Unpacker(object):
def read_bytes(self, Py_ssize_t nbytes):
"""read a specified number of raw bytes from the stream"""
cdef size_t nread
- ret = ''
- while len(ret) < nbytes and self.file_like is not None:
- if self.buf_head == self.buf_tail:
- self.fill_buffer()
- nread = min(self.buf_tail - self.buf_head, nbytes - len(ret))
- ret += PyBytes_FromStringAndSize(self.buf + self.buf_head, nread)
- self.buf_head += nread
+ nread = min(self.buf_tail - self.buf_head, nbytes)
+ ret = PyBytes_FromStringAndSize(self.buf + self.buf_head, nread)
+ self.buf_head += nread
+ if len(ret) < nbytes and self.file_like is not None:
+ ret += self.file_like.read(nbytes - len(ret))
return ret
def __iter__(self):