1 unstable release
0.1.0 | Nov 30, 2024 |
---|
#1013 in Data structures
38KB
767 lines
weak-lists
This crate provides list types that hold weak references to their elements. These lists allow concurrent iteration over and modification of the lists with reasonable outcomes.
Example
Consider a service that allows clients to register callbacks:
use std::sync::Arc;
use {
weak_lists::{SyncWeakList, SyncWeakListElement},
std::{
array,
},
};
pub struct Service {
callbacks: SyncWeakList<dyn Callback>,
}
pub trait Callback {
fn run(&self);
}
impl Service {
pub fn register_callback(&self, callback: &SyncWeakListElement<dyn Callback>) {
callback.attach(&self.callbacks);
}
pub fn run_callbacks(&self) {
for callback in &self.callbacks {
callback.run();
}
}
}
struct Client {
id: usize,
entry: SyncWeakListElement<dyn Callback>,
}
impl Callback for Client {
fn run(&self) {
eprintln!("Callback {} invoked", self.id);
if self.id == 1 {
self.entry.detach();
}
}
}
fn main() {
let service = Service {
callbacks: Default::default(),
};
let clients = array::from_fn::<_, 3, _>(|id| {
Arc::<Client>::new_cyclic(|slf| Client {
id,
entry: SyncWeakListElement::new(slf.clone()),
})
});
for client in &clients {
service.register_callback(&client.entry);
}
service.run_callbacks();
// Callback 0 invoked
// Callback 1 invoked
// Callback 2 invoked
service.run_callbacks();
// Callback 0 invoked
// Callback 2 invoked
}
License
This project is licensed under either of
- Apache License, Version 2.0
- MIT License
at your option.
Dependencies
~0.8–5.5MB
~16K SLoC