From 2e862fce5e7fed36b39aeeb35b621156db1683e5 Mon Sep 17 00:00:00 2001 From: Gbillou <7978569+Gbillou@users.noreply.github.com> Date: Mon, 5 Jul 2021 16:46:17 +0200 Subject: [PATCH] Keep capacity when unsplit on empty other buf (#502) --- src/bytes_mut.rs | 2 +- tests/test_bytes.rs | 25 +++++++++++++++++++++++++ 2 files changed, 26 insertions(+), 1 deletion(-) diff --git a/src/bytes_mut.rs b/src/bytes_mut.rs index 2af58e300..8e42079e6 100644 --- a/src/bytes_mut.rs +++ b/src/bytes_mut.rs @@ -819,7 +819,7 @@ impl BytesMut { } fn try_unsplit(&mut self, other: BytesMut) -> Result<(), BytesMut> { - if other.is_empty() { + if other.capacity() == 0 { return Ok(()); } diff --git a/tests/test_bytes.rs b/tests/test_bytes.rs index 84f4e7914..f2ae42e31 100644 --- a/tests/test_bytes.rs +++ b/tests/test_bytes.rs @@ -785,6 +785,31 @@ fn bytes_mut_unsplit_empty_self() { assert_eq!(b"aaabbbcccddd", &buf[..]); } +#[test] +fn bytes_mut_unsplit_other_keeps_capacity() { + let mut buf = BytesMut::with_capacity(64); + buf.extend_from_slice(b"aabb"); + + // non empty other created "from" buf + let mut other = buf.split_off(buf.len()); + other.extend_from_slice(b"ccddee"); + buf.unsplit(other); + + assert_eq!(buf.capacity(), 64); +} + +#[test] +fn bytes_mut_unsplit_empty_other_keeps_capacity() { + let mut buf = BytesMut::with_capacity(64); + buf.extend_from_slice(b"aabbccddee"); + + // empty other created "from" buf + let other = buf.split_off(buf.len()); + buf.unsplit(other); + + assert_eq!(buf.capacity(), 64); +} + #[test] fn bytes_mut_unsplit_arc_different() { let mut buf = BytesMut::with_capacity(64);