https://github.com/mitsuhiko/fragile
Utility wrapper to send non send types to other threads safely
https://github.com/mitsuhiko/fragile
Last synced: 3 months ago
JSON representation
Utility wrapper to send non send types to other threads safely
- Host: GitHub
- URL: https://github.com/mitsuhiko/fragile
- Owner: mitsuhiko
- License: apache-2.0
- Created: 2018-06-20T20:21:30.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2025-03-25T20:00:34.000Z (4 months ago)
- Last Synced: 2025-04-11T07:08:26.832Z (3 months ago)
- Language: Rust
- Size: 104 KB
- Stars: 179
- Watchers: 5
- Forks: 12
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# Fragile
[](https://crates.io/crates/fragile)
[](https://github.com/mitsuhiko/fragile/blob/master/LICENSE)
[](https://docs.rs/fragile)This library provides wrapper types that permit sending non Send types to other
threads and use runtime checks to ensure safety.It provides the `Fragile`, `Sticky` and `SemiSticky` types which are
similar in nature but have different behaviors with regards to how destructors
are executed. The `Fragile` will panic if the destructor is called in another
thread, `Sticky` will temporarily leak the object until the thread shuts down.
`SemiSticky` is a compromise of the two. It behaves like `Sticky` but it
avoids the use of thread local storage if the type does not need `Drop`.## Example
```rust
use std::thread;// creating and using a fragile object in the same thread works
let val = Fragile::new(true);
assert_eq!(*val.get(), true);
assert!(val.try_get().is_ok());// once send to another thread it stops working
thread::spawn(move || {
assert!(val.try_get().is_err());
}).join()
.unwrap();
```## License and Links
- [Documentation](https://docs.rs/fragile/)
- [Issue Tracker](https://github.com/mitsuhiko/fragile/issues)
- License: [Apache 2.0](https://github.com/mitsuhiko/fragile/blob/master/LICENSE)