mirror of
https://github.com/ntex-rs/ntex.git
synced 2025-04-04 21:37:58 +03:00
add Bytes::trimdown() method
This commit is contained in:
parent
0f796c7642
commit
60885478bd
4 changed files with 38 additions and 1 deletions
|
@ -1,5 +1,9 @@
|
||||||
# 0.1.0 (2021-07-xx)
|
# 0.1.0 (2021-07-xx)
|
||||||
|
|
||||||
|
* Add `Bytes::trimdown()` method
|
||||||
|
|
||||||
|
* Remove unused code
|
||||||
|
|
||||||
* Project fork
|
* Project fork
|
||||||
|
|
||||||
# 0.4.12 (March 6, 2019)
|
# 0.4.12 (March 6, 2019)
|
||||||
|
|
|
@ -5,7 +5,7 @@ A utility library for working with bytes. This is fork of bytes crate (https://g
|
||||||
[![Crates.io][crates-badge]][crates-url]
|
[![Crates.io][crates-badge]][crates-url]
|
||||||
[![Build Status][azure-badge]][azure-url]
|
[![Build Status][azure-badge]][azure-url]
|
||||||
|
|
||||||
[crates-badge]: https://img.shields.io/crates/v/bytes.svg
|
[crates-badge]: https://img.shields.io/crates/v/ntex-bytes.svg
|
||||||
[crates-url]: https://crates.io/crates/ntex-bytes
|
[crates-url]: https://crates.io/crates/ntex-bytes
|
||||||
|
|
||||||
[Documentation](https://docs.rs/ntex-bytes)
|
[Documentation](https://docs.rs/ntex-bytes)
|
||||||
|
|
|
@ -706,6 +706,33 @@ impl Bytes {
|
||||||
self.inner.truncate(len);
|
self.inner.truncate(len);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Shortens the buffer to `len` bytes and dropping the rest.
|
||||||
|
///
|
||||||
|
/// This is useful if underlying buffer is larger than cuurrent bytes object.
|
||||||
|
///
|
||||||
|
/// # Examples
|
||||||
|
///
|
||||||
|
/// ```
|
||||||
|
/// use ntex_bytes::Bytes;
|
||||||
|
///
|
||||||
|
/// let mut buf = Bytes::from(&b"hello world"[..]);
|
||||||
|
/// buf.trimdown();
|
||||||
|
/// assert_eq!(buf, b"hello world"[..]);
|
||||||
|
/// ```
|
||||||
|
#[inline]
|
||||||
|
pub fn trimdown(&mut self) {
|
||||||
|
let kind = self.inner.kind();
|
||||||
|
|
||||||
|
// trim down only if buffer is not inline or static and
|
||||||
|
// buffer cap is greater than 64 bytes
|
||||||
|
if !(kind == KIND_INLINE || kind == KIND_STATIC)
|
||||||
|
&& (self.inner.capacity() - self.inner.len() >= 64)
|
||||||
|
{
|
||||||
|
let bytes = Bytes::copy_from_slice(self);
|
||||||
|
let _ = mem::replace(self, bytes);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// Clears the buffer, removing all data.
|
/// Clears the buffer, removing all data.
|
||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
|
|
|
@ -32,6 +32,12 @@ impl ByteString {
|
||||||
Self(Bytes::from_static(src.as_bytes()))
|
Self(Bytes::from_static(src.as_bytes()))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Shortens the buffer to `len` bytes and dropping the rest.
|
||||||
|
#[inline]
|
||||||
|
pub fn trimdown(&mut self) {
|
||||||
|
self.0.trimdown()
|
||||||
|
}
|
||||||
|
|
||||||
/// Creates a new `ByteString` from a Bytes.
|
/// Creates a new `ByteString` from a Bytes.
|
||||||
///
|
///
|
||||||
/// # Safety
|
/// # Safety
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue