mirror of
https://github.com/logos-co/nomos-simulations.git
synced 2025-01-11 11:14:51 +00:00
Implement Epoch and Slot streams.
This commit is contained in:
parent
29f78e026e
commit
85a5b48c1f
56
network-runner/src/node/mix/consensus_streams.rs
Normal file
56
network-runner/src/node/mix/consensus_streams.rs
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
use crate::node::mix::scheduler::Interval;
|
||||||
|
use crossbeam::channel;
|
||||||
|
use futures::stream::iter;
|
||||||
|
use futures::{Stream, StreamExt};
|
||||||
|
use std::pin::Pin;
|
||||||
|
use std::task::{Context, Poll};
|
||||||
|
use std::time::Duration;
|
||||||
|
|
||||||
|
pub struct CounterInterval {
|
||||||
|
interval: Box<dyn Stream<Item = usize> + Unpin>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl CounterInterval {
|
||||||
|
pub fn new(duration: Duration, update_receiver: channel::Receiver<Duration>) -> Self {
|
||||||
|
let interval = Interval::new(duration, update_receiver)
|
||||||
|
.zip(iter(0usize..))
|
||||||
|
.map(|(_, i)| i);
|
||||||
|
let interval = Box::new(interval);
|
||||||
|
Self { interval }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Stream for CounterInterval {
|
||||||
|
type Item = usize;
|
||||||
|
|
||||||
|
fn poll_next(mut self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Option<Self::Item>> {
|
||||||
|
self.interval.poll_next_unpin(cx)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub type Epoch = CounterInterval;
|
||||||
|
|
||||||
|
pub struct Slot {
|
||||||
|
interval: Box<dyn Stream<Item = usize> + Unpin>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Slot {
|
||||||
|
pub fn new(
|
||||||
|
slots_per_epoch: usize,
|
||||||
|
slot_duration: Duration,
|
||||||
|
update_receiver: channel::Receiver<Duration>,
|
||||||
|
) -> Self {
|
||||||
|
let interval = CounterInterval::new(slot_duration, update_receiver)
|
||||||
|
.map(move |slot| slot % slots_per_epoch);
|
||||||
|
let interval = Box::new(interval);
|
||||||
|
Self { interval }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Stream for Slot {
|
||||||
|
type Item = usize;
|
||||||
|
|
||||||
|
fn poll_next(mut self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Option<Self::Item>> {
|
||||||
|
self.interval.poll_next_unpin(cx)
|
||||||
|
}
|
||||||
|
}
|
@ -1,3 +1,4 @@
|
|||||||
|
mod consensus_streams;
|
||||||
mod scheduler;
|
mod scheduler;
|
||||||
pub mod state;
|
pub mod state;
|
||||||
mod stream_wrapper;
|
mod stream_wrapper;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user