An open API service indexing awesome lists of open source software.

https://github.com/truelayer/task-local-extensions

Task-local container for arbitrary data
https://github.com/truelayer/task-local-extensions

Last synced: 6 months ago
JSON representation

Task-local container for arbitrary data

Awesome Lists containing this project

README

          

# task-local-extensions

Provides a type-safe task-local container for arbitrary data keyed by types.

[![Crates.io](https://img.shields.io/crates/v/task-local-extensions.svg)](https://crates.io/crates/task-local-extensions)
[![Docs.rs](https://docs.rs/task-local-extensions/badge.svg)](https://docs.rs/task-local-extensions)
[![CI](https://github.com/TrueLayer/task-local-extensions/workflows/CI/badge.svg)](https://github.com/TrueLayer/task-local-extensions/actions)
[![Coverage Status](https://coveralls.io/repos/github/TrueLayer/task-local-extensions/badge.svg?branch=main&t=DdH5KB)](https://coveralls.io/github/TrueLayer/task-local-extensions?branch=main)

## How to install

Add `task-local-extensions` to your dependencies

```toml
[dependencies]
# ...
task-local-extensions = "0.1.0"
```

## Usage

[`Extensions`](https://docs.rs/task-local-extensions/latest/task_local_extensions/struct.Extensions.html)
is a container that can store up to one value of each type, so you can insert and retrive values by
their type:

```rust
use task_local_extensions::Extensions;

let a: i64 = 3;
let mut ext = Extensions::new();
ext.insert(a);
assert_eq!(ext.get::(), Some(&3));
```

The crate also provides [`with_extensions`](https://docs.rs/task-local-extensions/latest/task_local_extensions/fn.with_extensions.html)
so you set an `Extensions` instance while running a given task:

```rust
use task_local_extensions::{get_local_item, set_local_item, with_extensions, Extensions};

async fn my_task() {
let a: i64 = get_local_item().await.unwrap(0);
let msg = format!("The value of a is: {}", a);
set_local_item(msg).await;
}

let a: i64 = 3;
let (out_ext, _) = with_extensions(Extensions::new().with(a), my_task()).await;
let msg = out_ext.get::().unwrap();
assert_eq!(msg.as_str(), "The value of a is: 3");
```

#### License


Licensed under either of Apache License, Version
2.0
or MIT license 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.