mirror of
https://github.com/ntex-rs/ntex.git
synced 2025-04-04 21:37:58 +03:00
wip
This commit is contained in:
parent
aec2908c96
commit
8502e834c7
2 changed files with 17 additions and 13 deletions
|
@ -1,5 +1,5 @@
|
||||||
use std::task::{Context, Poll, Waker};
|
use std::task::{Context, Poll, Waker};
|
||||||
use std::{cell, collections::VecDeque, fmt, future::Future, marker, pin::Pin, rc::Rc};
|
use std::{cell, fmt, future::Future, marker, pin::Pin, rc::Rc};
|
||||||
|
|
||||||
use crate::Service;
|
use crate::Service;
|
||||||
|
|
||||||
|
@ -12,7 +12,7 @@ pub struct ServiceCtx<'a, S: ?Sized> {
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
pub(crate) struct WaitersRef {
|
pub(crate) struct WaitersRef {
|
||||||
cur: cell::Cell<u32>,
|
cur: cell::Cell<u32>,
|
||||||
wakers: cell::UnsafeCell<VecDeque<u32>>,
|
wakers: cell::UnsafeCell<Vec<u32>>,
|
||||||
indexes: cell::UnsafeCell<slab::Slab<Option<Waker>>>,
|
indexes: cell::UnsafeCell<slab::Slab<Option<Waker>>>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -28,7 +28,7 @@ impl WaitersRef {
|
||||||
WaitersRef {
|
WaitersRef {
|
||||||
cur: cell::Cell::new(u32::MAX),
|
cur: cell::Cell::new(u32::MAX),
|
||||||
indexes: cell::UnsafeCell::new(waiters),
|
indexes: cell::UnsafeCell::new(waiters),
|
||||||
wakers: cell::UnsafeCell::new(VecDeque::default()),
|
wakers: cell::UnsafeCell::new(Vec::default()),
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
@ -39,7 +39,7 @@ impl WaitersRef {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[allow(clippy::mut_from_ref)]
|
#[allow(clippy::mut_from_ref)]
|
||||||
pub(crate) fn get_wakers(&self) -> &mut VecDeque<u32> {
|
pub(crate) fn get_wakers(&self) -> &mut Vec<u32> {
|
||||||
unsafe { &mut *self.wakers.get() }
|
unsafe { &mut *self.wakers.get() }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -57,12 +57,12 @@ impl WaitersRef {
|
||||||
|
|
||||||
pub(crate) fn register(&self, idx: u32, cx: &mut Context<'_>) {
|
pub(crate) fn register(&self, idx: u32, cx: &mut Context<'_>) {
|
||||||
self.get()[idx as usize] = Some(cx.waker().clone());
|
self.get()[idx as usize] = Some(cx.waker().clone());
|
||||||
self.get_wakers().push_back(idx);
|
self.get_wakers().push(idx);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) fn register_unready(&self, cx: &mut Context<'_>) {
|
pub(crate) fn register_unready(&self, cx: &mut Context<'_>) {
|
||||||
self.get()[0] = Some(cx.waker().clone());
|
self.get()[0] = Some(cx.waker().clone());
|
||||||
self.get_wakers().push_back(0);
|
self.get_wakers().push(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) fn notify(&self) {
|
pub(crate) fn notify(&self) {
|
||||||
|
|
|
@ -160,7 +160,7 @@ where
|
||||||
{
|
{
|
||||||
pl: Pipeline<S>,
|
pl: Pipeline<S>,
|
||||||
st: cell::UnsafeCell<State<S::Error>>,
|
st: cell::UnsafeCell<State<S::Error>>,
|
||||||
not_ready: cell::UnsafeCell<State<S::Error>>,
|
not_ready: cell::UnsafeCell<StateNotReady<S::Error>>,
|
||||||
}
|
}
|
||||||
|
|
||||||
enum State<E> {
|
enum State<E> {
|
||||||
|
@ -169,6 +169,11 @@ enum State<E> {
|
||||||
Shutdown(Pin<Box<dyn Future<Output = ()> + 'static>>),
|
Shutdown(Pin<Box<dyn Future<Output = ()> + 'static>>),
|
||||||
}
|
}
|
||||||
|
|
||||||
|
enum StateNotReady<E> {
|
||||||
|
New,
|
||||||
|
Readiness(Pin<Box<dyn Future<Output = Result<(), E>> + 'static>>),
|
||||||
|
}
|
||||||
|
|
||||||
impl<S, R> PipelineBinding<S, R>
|
impl<S, R> PipelineBinding<S, R>
|
||||||
where
|
where
|
||||||
S: Service<R> + 'static,
|
S: Service<R> + 'static,
|
||||||
|
@ -178,7 +183,7 @@ where
|
||||||
PipelineBinding {
|
PipelineBinding {
|
||||||
pl,
|
pl,
|
||||||
st: cell::UnsafeCell::new(State::New),
|
st: cell::UnsafeCell::new(State::New),
|
||||||
not_ready: cell::UnsafeCell::new(State::New),
|
not_ready: cell::UnsafeCell::new(StateNotReady::New),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -220,7 +225,7 @@ where
|
||||||
let st = unsafe { &mut *self.not_ready.get() };
|
let st = unsafe { &mut *self.not_ready.get() };
|
||||||
|
|
||||||
match st {
|
match st {
|
||||||
State::New => {
|
StateNotReady::New => {
|
||||||
// SAFETY: `fut` has same lifetime same as lifetime of `self.pl`.
|
// SAFETY: `fut` has same lifetime same as lifetime of `self.pl`.
|
||||||
// Pipeline::svc is heap allocated(Rc<S>), and it is being kept alive until
|
// Pipeline::svc is heap allocated(Rc<S>), and it is being kept alive until
|
||||||
// `self` is alive
|
// `self` is alive
|
||||||
|
@ -230,11 +235,10 @@ where
|
||||||
f: not_ready,
|
f: not_ready,
|
||||||
pl,
|
pl,
|
||||||
});
|
});
|
||||||
*st = State::Readiness(fut);
|
*st = StateNotReady::Readiness(fut);
|
||||||
self.poll_not_ready(cx)
|
self.poll_not_ready(cx)
|
||||||
}
|
}
|
||||||
State::Readiness(ref mut fut) => Pin::new(fut).poll(cx),
|
StateNotReady::Readiness(ref mut fut) => Pin::new(fut).poll(cx),
|
||||||
State::Shutdown(_) => panic!("Pipeline is shutding down"),
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -312,7 +316,7 @@ where
|
||||||
Self {
|
Self {
|
||||||
pl: self.pl.clone(),
|
pl: self.pl.clone(),
|
||||||
st: cell::UnsafeCell::new(State::New),
|
st: cell::UnsafeCell::new(State::New),
|
||||||
not_ready: cell::UnsafeCell::new(State::New),
|
not_ready: cell::UnsafeCell::new(StateNotReady::New),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue