mirror of
https://github.com/ntex-rs/ntex.git
synced 2025-04-04 13:27:39 +03:00
better api usability
This commit is contained in:
parent
79afb61b03
commit
d89f1c29c6
5 changed files with 91 additions and 27 deletions
|
@ -1,5 +1,9 @@
|
||||||
# Changes
|
# Changes
|
||||||
|
|
||||||
|
## 0.1.6 (2021-12-03)
|
||||||
|
|
||||||
|
* Better api usability
|
||||||
|
|
||||||
## 0.1.5 (2021-12-02)
|
## 0.1.5 (2021-12-02)
|
||||||
|
|
||||||
* Split,freeze,truncate operations produce inline Bytes object if possible
|
* Split,freeze,truncate operations produce inline Bytes object if possible
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
[package]
|
[package]
|
||||||
name = "ntex-bytes"
|
name = "ntex-bytes"
|
||||||
version = "0.1.5"
|
version = "0.1.6"
|
||||||
license = "MIT"
|
license = "MIT"
|
||||||
authors = ["Nikolay Kim <fafhrd91@gmail.com>", "Carl Lerche <me@carllerche.com>"]
|
authors = ["Nikolay Kim <fafhrd91@gmail.com>", "Carl Lerche <me@carllerche.com>"]
|
||||||
description = "Types and traits for working with bytes (bytes crate fork)"
|
description = "Types and traits for working with bytes (bytes crate fork)"
|
||||||
|
|
|
@ -5,7 +5,7 @@ use std::sync::atomic::Ordering::{Acquire, Relaxed, Release};
|
||||||
use std::sync::atomic::{self, AtomicUsize};
|
use std::sync::atomic::{self, AtomicUsize};
|
||||||
use std::{cmp, fmt, hash, mem, ptr, ptr::NonNull, slice, usize};
|
use std::{cmp, fmt, hash, mem, ptr, ptr::NonNull, slice, usize};
|
||||||
|
|
||||||
use crate::pool::{AsPoolRef, PoolId, PoolRef};
|
use crate::pool::{PoolId, PoolRef};
|
||||||
use crate::{buf::IntoIter, buf::UninitSlice, debug, Buf, BufMut};
|
use crate::{buf::IntoIter, buf::UninitSlice, debug, Buf, BufMut};
|
||||||
|
|
||||||
/// A reference counted contiguous slice of memory.
|
/// A reference counted contiguous slice of memory.
|
||||||
|
@ -473,14 +473,17 @@ impl Bytes {
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Creates `Bytes` instance from slice, by copying it.
|
/// Creates `Bytes` instance from slice, by copying it.
|
||||||
pub fn copy_from_slice_in<T: AsPoolRef>(data: &[u8], pool: T) -> Self {
|
pub fn copy_from_slice_in<T>(data: &[u8], pool: T) -> Self
|
||||||
|
where
|
||||||
|
PoolRef: From<T>,
|
||||||
|
{
|
||||||
if data.len() <= INLINE_CAP {
|
if data.len() <= INLINE_CAP {
|
||||||
Bytes {
|
Bytes {
|
||||||
inner: Inner::from_slice_inline(data),
|
inner: Inner::from_slice_inline(data),
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
Bytes {
|
Bytes {
|
||||||
inner: BytesMut::copy_from_slice_in(data, pool.pool_ref()).inner,
|
inner: BytesMut::copy_from_slice_in(data, pool.into()).inner,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1072,9 +1075,12 @@ impl BytesMut {
|
||||||
/// assert!(PoolId::P1.pool_ref().allocated() > 0);
|
/// assert!(PoolId::P1.pool_ref().allocated() > 0);
|
||||||
/// ```
|
/// ```
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn with_capacity_in<T: AsPoolRef>(capacity: usize, pool: T) -> BytesMut {
|
pub fn with_capacity_in<T>(capacity: usize, pool: T) -> BytesMut
|
||||||
|
where
|
||||||
|
PoolRef: From<T>,
|
||||||
|
{
|
||||||
BytesMut {
|
BytesMut {
|
||||||
inner: Inner::with_capacity(capacity, pool.pool_ref()),
|
inner: Inner::with_capacity(capacity, pool.into()),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1086,8 +1092,11 @@ impl BytesMut {
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Creates a new `BytesMut` from slice, by copying it.
|
/// Creates a new `BytesMut` from slice, by copying it.
|
||||||
pub fn copy_from_slice_in<T: AsPoolRef>(src: &[u8], pool: T) -> Self {
|
pub fn copy_from_slice_in<T>(src: &[u8], pool: T) -> Self
|
||||||
let mut bytes = BytesMut::with_capacity_in(src.len(), pool.pool_ref());
|
where
|
||||||
|
PoolRef: From<T>,
|
||||||
|
{
|
||||||
|
let mut bytes = BytesMut::with_capacity_in(src.len(), pool.into());
|
||||||
bytes.extend_from_slice(src);
|
bytes.extend_from_slice(src);
|
||||||
bytes
|
bytes
|
||||||
}
|
}
|
||||||
|
@ -1100,9 +1109,12 @@ impl BytesMut {
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
/// Convert a `Vec` into a `BytesMut`
|
/// Convert a `Vec` into a `BytesMut`
|
||||||
pub fn from_vec<T: AsPoolRef>(src: Vec<u8>, pool: T) -> BytesMut {
|
pub fn from_vec<T>(src: Vec<u8>, pool: T) -> BytesMut
|
||||||
|
where
|
||||||
|
PoolRef: From<T>,
|
||||||
|
{
|
||||||
BytesMut {
|
BytesMut {
|
||||||
inner: Inner::from_vec(src, pool.pool_ref()),
|
inner: Inner::from_vec(src, pool.into()),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -19,10 +19,6 @@ pub struct PoolRef(&'static MemoryPool);
|
||||||
#[derive(Copy, Clone, Debug)]
|
#[derive(Copy, Clone, Debug)]
|
||||||
pub struct PoolId(u8);
|
pub struct PoolId(u8);
|
||||||
|
|
||||||
pub trait AsPoolRef {
|
|
||||||
fn pool_ref(&self) -> PoolRef;
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Copy, Clone)]
|
#[derive(Copy, Clone)]
|
||||||
pub struct BufParams {
|
pub struct BufParams {
|
||||||
pub high: u16,
|
pub high: u16,
|
||||||
|
@ -94,8 +90,44 @@ impl PoolId {
|
||||||
POOLS.with(|pools| PoolRef(pools[self.0 as usize]))
|
POOLS.with(|pools| PoolRef(pools[self.0 as usize]))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[inline]
|
||||||
|
/// Set max pool size
|
||||||
|
pub fn set_pool_size(self, size: usize) -> Self {
|
||||||
|
self.pool_ref().set_pool_size(size);
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
#[doc(hidden)]
|
||||||
|
#[inline]
|
||||||
|
pub fn set_read_params(self, h: u16, l: u16) -> Self {
|
||||||
|
self.pool_ref().set_read_params(h, l);
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
#[doc(hidden)]
|
||||||
|
#[inline]
|
||||||
|
pub fn set_write_params(self, h: u16, l: u16) -> Self {
|
||||||
|
self.pool_ref().set_write_params(h, l);
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
/// Set future spawn fn
|
/// Set future spawn fn
|
||||||
pub fn set_spawn_fn<T>(f: T)
|
pub fn set_spawn_fn<T>(self, f: T) -> Self
|
||||||
|
where
|
||||||
|
T: Fn(Pin<Box<dyn Future<Output = ()>>>) + 'static,
|
||||||
|
{
|
||||||
|
let spawn: Rc<dyn Fn(Pin<Box<dyn Future<Output = ()>>>)> =
|
||||||
|
Rc::new(move |fut| f(fut));
|
||||||
|
|
||||||
|
POOLS.with(move |pools| {
|
||||||
|
*pools[self.0 as usize].spawn.borrow_mut() = Some(spawn.clone());
|
||||||
|
});
|
||||||
|
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Set future spawn fn to all pools
|
||||||
|
pub fn set_spawn_fn_all<T>(f: T)
|
||||||
where
|
where
|
||||||
T: Fn(Pin<Box<dyn Future<Output = ()>>>) + 'static,
|
T: Fn(Pin<Box<dyn Future<Output = ()>>>) + 'static,
|
||||||
{
|
{
|
||||||
|
@ -110,13 +142,6 @@ impl PoolId {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl AsPoolRef for PoolId {
|
|
||||||
#[inline]
|
|
||||||
fn pool_ref(&self) -> PoolRef {
|
|
||||||
POOLS.with(|pools| PoolRef(pools[self.0 as usize]))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
thread_local! {
|
thread_local! {
|
||||||
static POOLS: [&'static MemoryPool; 16] = [
|
static POOLS: [&'static MemoryPool; 16] = [
|
||||||
MemoryPool::create(PoolId::P0),
|
MemoryPool::create(PoolId::P0),
|
||||||
|
@ -171,6 +196,7 @@ impl PoolRef {
|
||||||
BytesMut::with_capacity_in_priv(cap, self)
|
BytesMut::with_capacity_in_priv(cap, self)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[doc(hidden)]
|
||||||
#[inline]
|
#[inline]
|
||||||
/// Set max pool size
|
/// Set max pool size
|
||||||
pub fn set_pool_size(self, size: usize) -> Self {
|
pub fn set_pool_size(self, size: usize) -> Self {
|
||||||
|
@ -329,10 +355,17 @@ impl Default for PoolRef {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl AsPoolRef for PoolRef {
|
impl From<PoolId> for PoolRef {
|
||||||
#[inline]
|
#[inline]
|
||||||
fn pool_ref(&self) -> PoolRef {
|
fn from(pid: PoolId) -> Self {
|
||||||
*self
|
pid.pool_ref()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'a> From<&'a Pool> for PoolRef {
|
||||||
|
#[inline]
|
||||||
|
fn from(pool: &'a Pool) -> Self {
|
||||||
|
PoolRef(pool.inner)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -386,6 +419,7 @@ impl BufParams {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Clone for Pool {
|
impl Clone for Pool {
|
||||||
|
#[inline]
|
||||||
fn clone(&self) -> Pool {
|
fn clone(&self) -> Pool {
|
||||||
Pool {
|
Pool {
|
||||||
idx: Cell::new(0),
|
idx: Cell::new(0),
|
||||||
|
@ -394,6 +428,20 @@ impl Clone for Pool {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl From<PoolId> for Pool {
|
||||||
|
#[inline]
|
||||||
|
fn from(pid: PoolId) -> Self {
|
||||||
|
pid.pool()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl From<PoolRef> for Pool {
|
||||||
|
#[inline]
|
||||||
|
fn from(pref: PoolRef) -> Self {
|
||||||
|
pref.pool()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl Drop for Pool {
|
impl Drop for Pool {
|
||||||
fn drop(&mut self) {
|
fn drop(&mut self) {
|
||||||
let idx = self.idx.get();
|
let idx = self.idx.get();
|
||||||
|
|
|
@ -655,11 +655,11 @@ fn pool() {
|
||||||
async fn pool_usage() {
|
async fn pool_usage() {
|
||||||
use ntex::{time, util};
|
use ntex::{time, util};
|
||||||
|
|
||||||
PoolId::set_spawn_fn(|f| {
|
PoolId::set_spawn_fn_all(|f| {
|
||||||
let _ = ntex::rt::spawn(f);
|
let _ = ntex::rt::spawn(f);
|
||||||
});
|
});
|
||||||
|
|
||||||
let p_ref = PoolId::P1.pool_ref().set_pool_size(10 * 1024);
|
let p_ref = PoolId::P1.set_pool_size(10 * 1024);
|
||||||
let p1 = p_ref.pool();
|
let p1 = p_ref.pool();
|
||||||
let p2 = p_ref.pool();
|
let p2 = p_ref.pool();
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue