entangled is a simple thread pool with minimal dependencies. The main use case is a scoped fork-join, i.e. spawning tasks from a single thread and having that thread await the completion of those tasks. There are also utilities for generating the tasks from a slice of data.
This library makes no attempt to ensure fairness or ordering of spawned tasks.
This is a hard fork of the bevy_tasks crate, to further reduce dependencies and simplify the crate.
Builds on the async-executor crate.
```rust let pool = entangled::TaskPool::default ();
let count = std::sync::atomic::AtomicI32::new(0); let ref_count = & count;
let output = pool.scope( | scope| { for _ in 0..100 { scope.spawn(async { refcount.fetchadd(1, std::sync::atomic::Ordering::Relaxed); 1 }); } });
assert_eq!(output.iter().sum::
Licensed under MIT.