mirror of
https://github.com/ntex-rs/ntex.git
synced 2025-04-04 13:27:39 +03:00
Add time::Sleep::elapse() method (#480)
This commit is contained in:
parent
b5a4a3cb5b
commit
80d20e4371
4 changed files with 36 additions and 6 deletions
|
@ -1,5 +1,9 @@
|
||||||
# Changes
|
# Changes
|
||||||
|
|
||||||
|
## [2.7.0] - 2024-12-03
|
||||||
|
|
||||||
|
* Add time::Sleep::elapse() method
|
||||||
|
|
||||||
## [2.6.1] - 2024-11-23
|
## [2.6.1] - 2024-11-23
|
||||||
|
|
||||||
* Remove debug print
|
* Remove debug print
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
[package]
|
[package]
|
||||||
name = "ntex-util"
|
name = "ntex-util"
|
||||||
version = "2.6.1"
|
version = "2.7.0"
|
||||||
authors = ["ntex contributors <team@ntex.rs>"]
|
authors = ["ntex contributors <team@ntex.rs>"]
|
||||||
description = "Utilities for ntex framework"
|
description = "Utilities for ntex framework"
|
||||||
keywords = ["network", "framework", "async", "futures"]
|
keywords = ["network", "framework", "async", "futures"]
|
||||||
|
|
|
@ -101,6 +101,12 @@ impl Sleep {
|
||||||
self.hnd.is_elapsed()
|
self.hnd.is_elapsed()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Complete sleep timer.
|
||||||
|
#[inline]
|
||||||
|
pub fn elapse(&self) {
|
||||||
|
self.hnd.elapse()
|
||||||
|
}
|
||||||
|
|
||||||
/// Resets the `Sleep` instance to a new deadline.
|
/// Resets the `Sleep` instance to a new deadline.
|
||||||
///
|
///
|
||||||
/// Calling this function allows changing the instant at which the `Sleep`
|
/// Calling this function allows changing the instant at which the `Sleep`
|
||||||
|
@ -354,7 +360,7 @@ impl crate::Stream for Interval {
|
||||||
#[allow(clippy::let_underscore_future)]
|
#[allow(clippy::let_underscore_future)]
|
||||||
mod tests {
|
mod tests {
|
||||||
use futures_util::StreamExt;
|
use futures_util::StreamExt;
|
||||||
use std::time;
|
use std::{future::poll_fn, rc::Rc, time};
|
||||||
|
|
||||||
use super::*;
|
use super::*;
|
||||||
use crate::future::lazy;
|
use crate::future::lazy;
|
||||||
|
@ -449,6 +455,17 @@ mod tests {
|
||||||
fut.await;
|
fut.await;
|
||||||
let second_time = now();
|
let second_time = now();
|
||||||
assert!(second_time - first_time < time::Duration::from_millis(1));
|
assert!(second_time - first_time < time::Duration::from_millis(1));
|
||||||
|
|
||||||
|
let first_time = now();
|
||||||
|
let fut = Rc::new(sleep(Millis(100000)));
|
||||||
|
let s = fut.clone();
|
||||||
|
ntex::rt::spawn(async move {
|
||||||
|
s.elapse();
|
||||||
|
});
|
||||||
|
poll_fn(|cx| fut.poll_elapsed(cx)).await;
|
||||||
|
assert!(fut.is_elapsed());
|
||||||
|
let second_time = now();
|
||||||
|
assert!(second_time - first_time < time::Duration::from_millis(1));
|
||||||
}
|
}
|
||||||
|
|
||||||
#[ntex_macros::rt_test2]
|
#[ntex_macros::rt_test2]
|
||||||
|
|
|
@ -106,6 +106,11 @@ impl TimerHandle {
|
||||||
TIMER.with(|t| t.update_timer(self.0, millis))
|
TIMER.with(|t| t.update_timer(self.0, millis))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Resets the `TimerHandle` instance to elapsed state.
|
||||||
|
pub fn elapse(&self) {
|
||||||
|
TIMER.with(|t| t.remove_timer(self.0))
|
||||||
|
}
|
||||||
|
|
||||||
pub fn is_elapsed(&self) -> bool {
|
pub fn is_elapsed(&self) -> bool {
|
||||||
TIMER.with(|t| t.with_mod(|m| m.timers[self.0].bucket.is_none()))
|
TIMER.with(|t| t.with_mod(|m| m.timers[self.0].bucket.is_none()))
|
||||||
}
|
}
|
||||||
|
@ -303,6 +308,14 @@ impl Timer {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Remove timer and wake task
|
||||||
|
fn remove_timer(&self, hnd: usize) {
|
||||||
|
self.with_mod(|inner| {
|
||||||
|
inner.remove_timer_bucket(hnd, false);
|
||||||
|
inner.timers[hnd].complete();
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
/// Update existing timer
|
/// Update existing timer
|
||||||
fn update_timer(&self, hnd: usize, millis: u64) {
|
fn update_timer(&self, hnd: usize, millis: u64) {
|
||||||
self.with_mod(|inner| {
|
self.with_mod(|inner| {
|
||||||
|
@ -345,10 +358,6 @@ impl Timer {
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
// fn remove_timer(&self, handle: usize) {
|
|
||||||
// self.0.inner.borrow_mut().remove_timer_bucket(handle, true)
|
|
||||||
// }
|
|
||||||
}
|
}
|
||||||
|
|
||||||
impl TimerMod {
|
impl TimerMod {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue