diff options
| author | Tomoyuki Sahara <[email protected]> | 2017-06-15 10:53:01 +0900 |
|---|---|---|
| committer | GitHub <[email protected]> | 2017-06-15 10:53:01 +0900 |
| commit | 7c62d89348e4fb4258e177bb434582edd18ffdd4 (patch) | |
| tree | 29ca5c04ea47dbb9d9a777294fbfe417182f4cbe /mrblib | |
| parent | fe99819bc996891ea97c10446ca3e495c77d790f (diff) | |
| parent | 3642fe40131220520e961157fa501ee1adf2ebca (diff) | |
| download | mruby-7c62d89348e4fb4258e177bb434582edd18ffdd4.tar.gz mruby-7c62d89348e4fb4258e177bb434582edd18ffdd4.zip | |
Merge pull request #88 from christopheraue/master
Fix for IO#read(n) with n > IO::BUF_SIZE
Diffstat (limited to 'mrblib')
| -rw-r--r-- | mrblib/io.rb | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/mrblib/io.rb b/mrblib/io.rb index 3ea839379..f538af490 100644 --- a/mrblib/io.rb +++ b/mrblib/io.rb @@ -205,10 +205,12 @@ class IO break end - if length && length <= @buf.size - array.push @buf[0, length] - @buf = @buf[length, @buf.size - length] - break + if length + consume = (length <= @buf.size) ? length : @buf.size + array.push @buf[0, consume] + @buf = @buf[consume, @buf.size - consume] + length -= consume + break if length == 0 else array.push @buf @buf = '' |
