mirror of
https://github.com/ntex-rs/ntex.git
synced 2025-04-03 21:07:39 +03:00
Make copy_from_slice universal
This commit is contained in:
parent
1c635a6b55
commit
5866014e75
3 changed files with 46 additions and 4 deletions
|
@ -1937,17 +1937,19 @@ impl BytesVec {
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Creates a new `BytesVec` from slice, by copying it.
|
/// Creates a new `BytesVec` from slice, by copying it.
|
||||||
pub fn copy_from_slice(src: &[u8]) -> Self {
|
pub fn copy_from_slice<T: AsRef<[u8]>>(src: T) -> Self {
|
||||||
Self::copy_from_slice_in(src, PoolId::DEFAULT)
|
Self::copy_from_slice_in(src, PoolId::DEFAULT)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Creates a new `BytesVec` from slice, by copying it.
|
/// Creates a new `BytesVec` from slice, by copying it.
|
||||||
pub fn copy_from_slice_in<T>(src: &[u8], pool: T) -> Self
|
pub fn copy_from_slice_in<T, U>(src: T, pool: U) -> Self
|
||||||
where
|
where
|
||||||
PoolRef: From<T>,
|
T: AsRef<[u8]>,
|
||||||
|
PoolRef: From<U>,
|
||||||
{
|
{
|
||||||
|
let s = src.as_ref();
|
||||||
BytesVec {
|
BytesVec {
|
||||||
inner: InnerVec::from_slice(src.len(), src, pool.into()),
|
inner: InnerVec::from_slice(s.len(), s, pool.into()),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -442,6 +442,15 @@ fn fns_defined_for_bytes() {
|
||||||
let mut bytes = Bytes::from(&b"hello world"[..]);
|
let mut bytes = Bytes::from(&b"hello world"[..]);
|
||||||
bytes.as_ptr();
|
bytes.as_ptr();
|
||||||
|
|
||||||
|
assert!(bytes > "g");
|
||||||
|
assert!(bytes > "g".to_string());
|
||||||
|
assert!(bytes > "g".as_bytes().to_vec());
|
||||||
|
assert!(bytes > Bytes::from(&"g"[..]));
|
||||||
|
assert!("g" > bytes);
|
||||||
|
assert!("g".to_string() > bytes);
|
||||||
|
assert!("g".as_bytes().to_vec() > bytes);
|
||||||
|
assert!(Bytes::from(&"g"[..]) < bytes);
|
||||||
|
|
||||||
assert_eq!(bytes, "hello world");
|
assert_eq!(bytes, "hello world");
|
||||||
assert_eq!(bytes, "hello world".as_bytes().to_vec());
|
assert_eq!(bytes, "hello world".as_bytes().to_vec());
|
||||||
assert_eq!(bytes, "hello world".to_string());
|
assert_eq!(bytes, "hello world".to_string());
|
||||||
|
@ -450,6 +459,9 @@ fn fns_defined_for_bytes() {
|
||||||
assert_eq!(bytes, BytesMut::copy_from_slice(b"hello world"));
|
assert_eq!(bytes, BytesMut::copy_from_slice(b"hello world"));
|
||||||
|
|
||||||
// Iterator
|
// Iterator
|
||||||
|
let v: Vec<u8> = (&bytes).iter().cloned().collect();
|
||||||
|
assert_eq!(&v[..], bytes);
|
||||||
|
|
||||||
let v: Vec<u8> = bytes.as_ref().iter().cloned().collect();
|
let v: Vec<u8> = bytes.as_ref().iter().cloned().collect();
|
||||||
assert_eq!(&v[..], bytes);
|
assert_eq!(&v[..], bytes);
|
||||||
|
|
||||||
|
@ -470,6 +482,15 @@ fn fns_defined_for_bytes_mut() {
|
||||||
bytes.as_ptr();
|
bytes.as_ptr();
|
||||||
bytes.as_mut_ptr();
|
bytes.as_mut_ptr();
|
||||||
|
|
||||||
|
assert!(bytes > "g");
|
||||||
|
assert!(bytes > "g".to_string());
|
||||||
|
assert!(bytes > "g".as_bytes().to_vec());
|
||||||
|
assert!(bytes > BytesMut::from(&"g"[..]));
|
||||||
|
assert!("g" > bytes);
|
||||||
|
assert!("g".to_string() > bytes);
|
||||||
|
assert!("g".as_bytes().to_vec() > bytes);
|
||||||
|
assert!(BytesMut::from(&"g"[..]) < bytes);
|
||||||
|
|
||||||
assert_eq!(bytes, "hello world");
|
assert_eq!(bytes, "hello world");
|
||||||
assert_eq!(bytes, "hello world".as_bytes().to_vec());
|
assert_eq!(bytes, "hello world".as_bytes().to_vec());
|
||||||
assert_eq!(bytes, "hello world".to_string());
|
assert_eq!(bytes, "hello world".to_string());
|
||||||
|
@ -478,6 +499,9 @@ fn fns_defined_for_bytes_mut() {
|
||||||
assert_eq!(bytes, BytesVec::copy_from_slice(b"hello world"));
|
assert_eq!(bytes, BytesVec::copy_from_slice(b"hello world"));
|
||||||
|
|
||||||
// Iterator
|
// Iterator
|
||||||
|
let v: Vec<u8> = (&bytes).iter().cloned().collect();
|
||||||
|
assert_eq!(&v[..], bytes);
|
||||||
|
|
||||||
let v: Vec<u8> = bytes.as_ref().iter().cloned().collect();
|
let v: Vec<u8> = bytes.as_ref().iter().cloned().collect();
|
||||||
assert_eq!(&v[..], bytes);
|
assert_eq!(&v[..], bytes);
|
||||||
|
|
||||||
|
@ -519,6 +543,15 @@ fn fns_defined_for_bytes_vec() {
|
||||||
bytes.as_ptr();
|
bytes.as_ptr();
|
||||||
bytes.as_mut_ptr();
|
bytes.as_mut_ptr();
|
||||||
|
|
||||||
|
assert!(bytes > "g");
|
||||||
|
assert!(bytes > "g".to_string());
|
||||||
|
assert!(bytes > "g".as_bytes().to_vec());
|
||||||
|
assert!(bytes > BytesVec::copy_from_slice("g"));
|
||||||
|
assert!("g" > bytes);
|
||||||
|
assert!("g".to_string() > bytes);
|
||||||
|
assert!("g".as_bytes().to_vec() > bytes);
|
||||||
|
assert!(BytesVec::copy_from_slice(&"g"[..]) < bytes);
|
||||||
|
|
||||||
assert_eq!(bytes, "hello world");
|
assert_eq!(bytes, "hello world");
|
||||||
assert_eq!(bytes, "hello world".as_bytes().to_vec());
|
assert_eq!(bytes, "hello world".as_bytes().to_vec());
|
||||||
assert_eq!(bytes, "hello world".to_string());
|
assert_eq!(bytes, "hello world".to_string());
|
||||||
|
@ -527,6 +560,9 @@ fn fns_defined_for_bytes_vec() {
|
||||||
assert_eq!(bytes, BytesMut::copy_from_slice(b"hello world"));
|
assert_eq!(bytes, BytesMut::copy_from_slice(b"hello world"));
|
||||||
|
|
||||||
// Iterator
|
// Iterator
|
||||||
|
let v: Vec<u8> = (&bytes).iter().cloned().collect();
|
||||||
|
assert_eq!(&v[..], bytes);
|
||||||
|
|
||||||
let v: Vec<u8> = bytes.as_ref().iter().cloned().collect();
|
let v: Vec<u8> = bytes.as_ref().iter().cloned().collect();
|
||||||
assert_eq!(&v[..], bytes);
|
assert_eq!(&v[..], bytes);
|
||||||
|
|
||||||
|
|
|
@ -213,6 +213,10 @@ where
|
||||||
buf.extend_from_slice(b"HTTP/1.1 100 Continue\r\n\r\n")
|
buf.extend_from_slice(b"HTTP/1.1 100 Continue\r\n\r\n")
|
||||||
});
|
});
|
||||||
if result.is_err() {
|
if result.is_err() {
|
||||||
|
log::error!(
|
||||||
|
"Expect handler returned error: {:?}",
|
||||||
|
result.err().unwrap()
|
||||||
|
);
|
||||||
*this.st = State::Stop;
|
*this.st = State::Stop;
|
||||||
this = self.as_mut().project();
|
this = self.as_mut().project();
|
||||||
continue;
|
continue;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue