aboutsummaryrefslogtreecommitdiff
path: root/src/message.rs
diff options
context:
space:
mode:
authorAlex Auvolat <alex@adnab.me>2022-07-22 14:38:03 +0200
committerAlex Auvolat <alex@adnab.me>2022-07-22 14:38:03 +0200
commit482566929385fab18300d205a89d0e23d977855b (patch)
treec59f6c62e04d1be8a4268ba36b7a6d5581e54c44 /src/message.rs
parent50358b944ae7ee4b4aa292ede8bc5d185c86df65 (diff)
downloadnetapp-482566929385fab18300d205a89d0e23d977855b.tar.gz
netapp-482566929385fab18300d205a89d0e23d977855b.zip
Remove copy of serialized thing in encode
Diffstat (limited to 'src/message.rs')
-rw-r--r--src/message.rs11
1 files changed, 4 insertions, 7 deletions
diff --git a/src/message.rs b/src/message.rs
index 56e6e8e..629992d 100644
--- a/src/message.rs
+++ b/src/message.rs
@@ -313,14 +313,13 @@ impl ReqEnc {
buf.put(&self.telemetry_id[..]);
buf.put_u32(self.msg.len() as u32);
- buf.put(&self.msg[..]);
let header = buf.freeze();
if let Some(stream) = self.stream {
- Box::pin(futures::stream::once(async move { Ok(header) }).chain(stream))
+ Box::pin(futures::stream::iter([Ok(header), Ok(self.msg)]).chain(stream))
} else {
- Box::pin(futures::stream::once(async move { Ok(header) }))
+ Box::pin(futures::stream::iter([Ok(header), Ok(self.msg)]))
}
}
@@ -387,16 +386,14 @@ impl RespEnc {
let mut buf = BytesMut::with_capacity(msg.len() + 8);
buf.put_u8(0);
-
buf.put_u32(msg.len() as u32);
- buf.put(&msg[..]);
let header = buf.freeze();
if let Some(stream) = stream {
- Box::pin(futures::stream::once(async move { Ok(header) }).chain(stream))
+ Box::pin(futures::stream::iter([Ok(header), Ok(msg)]).chain(stream))
} else {
- Box::pin(futures::stream::once(async move { Ok(header) }))
+ Box::pin(futures::stream::iter([Ok(header), Ok(msg)]))
}
}
RespEnc::Error { code, message } => {