# HG changeset patch # User Matthew Wild # Date 1593431488 -3600 # Node ID eaee72c7afbdf9f120ef0c9374813c7abeabaefe # Parent 5671d51df26cff5cf18b9e1acf1401945fefcb92 util.dbuffer: If no bytes parameter passed to read, return remainder of frontmost chunk diff -r 5671d51df26c -r eaee72c7afbd spec/util_dbuffer_spec.lua --- a/spec/util_dbuffer_spec.lua Sun Jun 28 15:58:47 2020 +0200 +++ b/spec/util_dbuffer_spec.lua Mon Jun 29 12:51:28 2020 +0100 @@ -21,6 +21,21 @@ end); end); + describe(":read", function () + it("supports optional bytes parameter", function () + -- should return the frontmost chunk + local b = dbuffer.new(); + assert.truthy(b:write("hello")); + assert.truthy(b:write(" ")); + assert.truthy(b:write("world")); + assert.equal("h", b:read(1)); + + assert.equal("ello", b:read()); + assert.equal(" ", b:read()); + assert.equal("world", b:read()); + end); + end); + describe(":discard", function () local b = dbuffer.new(); it("works", function () diff -r 5671d51df26c -r eaee72c7afbd util/dbuffer.lua --- a/util/dbuffer.lua Sun Jun 28 15:58:47 2020 +0200 +++ b/util/dbuffer.lua Mon Jun 29 12:51:28 2020 +0100 @@ -24,6 +24,9 @@ if not chunk then return; end local chunk_length = #chunk; local remaining_chunk_length = chunk_length - consumed; + if not requested_bytes then + requested_bytes = remaining_chunk_length; + end if remaining_chunk_length <= requested_bytes then self.front_consumed = 0; self._length = self._length - remaining_chunk_length; @@ -41,12 +44,14 @@ function dbuffer_methods:read(requested_bytes) local chunks; - if requested_bytes > self._length then + if requested_bytes and requested_bytes > self._length then return nil; end local chunk, read_bytes = self:read_chunk(requested_bytes); - if chunk then + if not requested_bytes then + return chunk; + elseif chunk then requested_bytes = requested_bytes - read_bytes; if requested_bytes == 0 then -- Already read everything we need return chunk;