| Crates.io | task-local |
| lib.rs | task-local |
| version | 0.1.0 |
| created_at | 2025-03-25 05:15:45.447709+00 |
| updated_at | 2025-03-25 05:15:45.447709+00 |
| description | Task-local storage for asynchronous tasks |
| homepage | |
| repository | https://github.com/BugenZhao/task-local |
| max_upload_size | |
| id | 1604783 |
| size | 34,499 |
Task-local storage for asynchronous tasks, extracted from the tokio::task_local module.
This crate provides a way to store task-local values across .await points without requiring the Tokio runtime.
Task-local storage allows you to store and access data that is local to the current asynchronous task. Unlike thread-local storage, task-local values are preserved across .await points within the same task.
Add this to your Cargo.toml:
[dependencies]
task-local = "0.1.0"
use task_local::task_local;
task_local! {
static NUMBER: u32;
}
async fn example() {
NUMBER.scope(1, async {
// The value 1 is accessible within this async block
assert_eq!(NUMBER.get(), 1);
// It's also accessible across .await points
some_async_function().await;
assert_eq!(NUMBER.get(), 1);
// You can nest scopes
NUMBER.scope(2, async {
assert_eq!(NUMBER.get(), 2);
}).await;
// After the nested scope, the original value is restored
assert_eq!(NUMBER.get(), 1);
}).await;
}
async fn some_async_function() {
// The task-local value is still accessible here
assert_eq!(NUMBER.get(), 1);
}
Licensed under either of
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.