47 lines
1.2 KiB
Rust
47 lines
1.2 KiB
Rust
//! The `blob_fetch_stage` pulls blobs from UDP sockets and sends it to a channel.
|
|
|
|
use crate::service::Service;
|
|
use crate::streamer::{self, BlobSender};
|
|
use std::net::UdpSocket;
|
|
use std::sync::atomic::{AtomicBool, Ordering};
|
|
use std::sync::Arc;
|
|
use std::thread::{self, JoinHandle};
|
|
|
|
pub struct BlobFetchStage {
|
|
exit: Arc<AtomicBool>,
|
|
thread_hdls: Vec<JoinHandle<()>>,
|
|
}
|
|
|
|
impl BlobFetchStage {
|
|
pub fn new(socket: Arc<UdpSocket>, sender: &BlobSender, exit: Arc<AtomicBool>) -> Self {
|
|
Self::new_multi_socket(vec![socket], sender, exit)
|
|
}
|
|
pub fn new_multi_socket(
|
|
sockets: Vec<Arc<UdpSocket>>,
|
|
sender: &BlobSender,
|
|
exit: Arc<AtomicBool>,
|
|
) -> Self {
|
|
let thread_hdls: Vec<_> = sockets
|
|
.into_iter()
|
|
.map(|socket| streamer::blob_receiver(socket, exit.clone(), sender.clone()))
|
|
.collect();
|
|
|
|
Self { exit, thread_hdls }
|
|
}
|
|
|
|
pub fn close(&self) {
|
|
self.exit.store(true, Ordering::Relaxed);
|
|
}
|
|
}
|
|
|
|
impl Service for BlobFetchStage {
|
|
type JoinReturnType = ();
|
|
|
|
fn join(self) -> thread::Result<()> {
|
|
for thread_hdl in self.thread_hdls {
|
|
thread_hdl.join()?;
|
|
}
|
|
Ok(())
|
|
}
|
|
}
|