Crates.io | streamcatcher |
lib.rs | streamcatcher |
version | 1.0.1 |
source | src |
created_at | 2020-08-17 11:34:54.699132 |
updated_at | 2021-12-27 14:52:02.717144 |
description | A thread-safe, shared (asynchronous), almost-lockless stream buffer. |
homepage | https://github.com/FelixMcFelix/streamcatcher |
repository | https://github.com/FelixMcFelix/streamcatcher.git |
max_upload_size | |
id | 277474 |
size | 55,065 |
A Rust thread-safe, shared (asynchronous) stream buffer designed to lock only on accessing and storing new data.
Streamcatcher is designed to allow seeking on otherwise one-way streams (e.g., command output) whose output needs to be accessed by many threads without constant reallocations, contention over safe read-only data, or unnecessary stalling. Only threads who read in new data ever need to lock the data structure, and do not prevent earlier reads from occurring.
"async"
feature, and runtimes via ["async-std-compat"
, "smol-compat"
, "tokio-compat"
].The main algorithm is outlined in this blog post, with rope reference tracking moved to occur only in the core.
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.
Detailed guidelines are given in the CONTRIBUTING file.