Compare commits
5 Commits
master
...
pipelined-
Author | SHA1 | Date |
---|---|---|
Avril | 1bfa6bbd4e | 3 years ago |
Avril | c658e8a702 | 3 years ago |
Avril | fbf96276ca | 3 years ago |
Avril | 444f3f38dc | 3 years ago |
Avril | 30522ec96f | 3 years ago |
@ -0,0 +1 @@
|
||||
<mxfile host="app.diagrams.net" modified="2021-08-19T19:47:34.219Z" agent="5.0 (X11)" etag="m3W9Xk7ZdncWV_dDKnck" version="14.9.8" type="device"><diagram id="yzWLK1SvWkPlnieqc2aE" name="Page-1">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</diagram></mxfile>
|
@ -0,0 +1,74 @@
|
||||
//! Syncronisation helpers
|
||||
use super::*;
|
||||
use futures::{
|
||||
Future,
|
||||
};
|
||||
use tokio::time::Duration;
|
||||
|
||||
/// Force a future to take *at least* a specific amount of time to complete.
|
||||
///
|
||||
/// If the future takes longer than `time` to complete, no additional delay is added.
|
||||
/// If `time` is zero, no delay is added.
|
||||
///
|
||||
/// # Panics
|
||||
/// The returned future will panic if
|
||||
/// * The future itself panics
|
||||
/// * We are unable to convert the future's duration from `chrono`'s duration span to std's duration span
|
||||
pub fn timesync<'a, T, F>(future: F, time: Duration) -> impl Future<Output = T> + 'a
|
||||
where F: Future<Output=T> + 'a
|
||||
{
|
||||
use chrono::prelude::*;
|
||||
|
||||
#[cold]
|
||||
#[inline(never)]
|
||||
fn _panic_failed_tmconv(orig: chrono::Duration, error: impl Into<eyre::Report>)
|
||||
{
|
||||
panic!("Failed to convert chrono duration span {:?} to std duration span: {}", orig, error.into());
|
||||
}
|
||||
|
||||
async move {
|
||||
let now = Utc::now();
|
||||
let r = future.await;
|
||||
if time.is_zero() {
|
||||
return r;
|
||||
}
|
||||
let after = Utc::now();
|
||||
let duration = after - now;
|
||||
match duration.to_std() {
|
||||
Ok(taken)
|
||||
if taken < time => {
|
||||
// Delay for the remaining time
|
||||
tokio::time::delay_for(time - taken).await;
|
||||
},
|
||||
Err(error) => _panic_failed_tmconv(duration, error),
|
||||
// At least `time` has passed
|
||||
_ => (),
|
||||
}
|
||||
r
|
||||
}
|
||||
}
|
||||
|
||||
pub trait TimeSyncExt<'a>: Future + Sized + 'a
|
||||
{
|
||||
type OutputFuture: Future<Output = Self::Output> + 'a;
|
||||
fn pad_time(self, time: Duration) -> Self::OutputFuture;
|
||||
}
|
||||
|
||||
#[cfg(nightly)]
|
||||
impl<'a, F> TimeSyncExt<'a> for F
|
||||
where F: Future + 'a
|
||||
{
|
||||
//#[cfg(nightly)]
|
||||
type OutputFuture = impl Future<Output = Self::Output> + 'a;
|
||||
//#[cfg(not(nightly))]
|
||||
//type OutputFuture = futures::future::BoxFuture<'a, Self::Output>; //TODO: Requires `Send` bound for some reason.
|
||||
fn pad_time(self, time: Duration) -> Self::OutputFuture {
|
||||
/*#[cfg(not(nightly))] {
|
||||
use futures::prelude::*;
|
||||
return timesync(self, time).boxed();
|
||||
}
|
||||
#[cfg(nightly)] {
|
||||
return*/ timesync(self, time)
|
||||
//}
|
||||
}
|
||||
}
|
Loading…
Reference in new issue