aboutsummaryrefslogtreecommitdiff
path: root/src/net/bytes_buf.rs
diff options
context:
space:
mode:
authorAlex Auvolat <alex@adnab.me>2024-02-23 11:46:57 +0100
committerAlex Auvolat <alex@adnab.me>2024-02-23 11:46:57 +0100
commit9b41f4ff2016b099ee706747828f5828f8c96b1c (patch)
tree3c9e06d8d0ca7162e97e765bbe8091a5eaf676fd /src/net/bytes_buf.rs
parent93552b9275a6a83653353e27c0ee0c64c7a23d59 (diff)
downloadgarage-9b41f4ff2016b099ee706747828f5828f8c96b1c.tar.gz
garage-9b41f4ff2016b099ee706747828f5828f8c96b1c.zip
[refactor-block] move read_stream_to_end to garage_net
Diffstat (limited to 'src/net/bytes_buf.rs')
-rw-r--r--src/net/bytes_buf.rs13
1 files changed, 13 insertions, 0 deletions
diff --git a/src/net/bytes_buf.rs b/src/net/bytes_buf.rs
index 3929a860..1d928ffb 100644
--- a/src/net/bytes_buf.rs
+++ b/src/net/bytes_buf.rs
@@ -3,6 +3,8 @@ use std::collections::VecDeque;
use bytes::BytesMut;
+use crate::stream::ByteStream;
+
pub use bytes::Bytes;
/// A circular buffer of bytes, internally represented as a list of Bytes
@@ -119,6 +121,17 @@ impl BytesBuf {
pub fn into_slices(self) -> VecDeque<Bytes> {
self.buf
}
+
+ /// Return the entire buffer concatenated into a single big Bytes
+ pub fn into_bytes(mut self) -> Bytes {
+ self.take_all()
+ }
+
+ /// Return the content as a stream of individual chunks
+ pub fn into_stream(self) -> ByteStream {
+ use futures::stream::StreamExt;
+ Box::pin(futures::stream::iter(self.buf).map(|x| Ok(x)))
+ }
}
impl Default for BytesBuf {