Function takeDelimiter [src]
Returns a slice of the next bytes of buffered data from the stream until
delimiter is found, advancing the seek position past the delimiter.
Returned slice excludes the delimiter. End-of-stream is treated equivalent
to a delimiter, unless it would result in a length 0 return value, in which
case null is returned instead.
If the delimiter is not found within a number of bytes matching the
capacity of this Reader, error.StreamTooLong is returned. In
such case, the stream state is unmodified as if this function was never
called.
Invalidates previously returned values from peek.
See also:
takeDelimiterInclusive
takeDelimiterExclusive
Prototype
pub fn takeDelimiter(r: *Reader, delimiter: u8) error{ ReadFailed, StreamTooLong }!?[]u8
Parameters
r: *Reader
delimiter: u8
Possible Errors
Source
pub fn takeDelimiter(r: *Reader, delimiter: u8) error{ ReadFailed, StreamTooLong }!?[]u8 {
const result = r.peekDelimiterInclusive(delimiter) catch |err| switch (err) {
error.EndOfStream => {
const remaining = r.buffer[r.seek..r.end];
if (remaining.len == 0) return null;
r.toss(remaining.len);
return remaining;
},
else => |e| return e,
};
r.toss(result.len + 1);
return result[0 .. result.len - 1];
}