Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/mitsuhiko/fragile

Utility wrapper to send non send types to other threads safely
https://github.com/mitsuhiko/fragile

Last synced: 4 days ago
JSON representation

Utility wrapper to send non send types to other threads safely

Awesome Lists containing this project

README

        

# Fragile

[![Build Status](https://github.com/mitsuhiko/fragile/workflows/Tests/badge.svg?branch=master)](https://github.com/mitsuhiko/fragile/actions?query=workflow%3ATests)
[![Crates.io](https://img.shields.io/crates/d/fragile.svg)](https://crates.io/crates/fragile)
[![License](https://img.shields.io/github/license/mitsuhiko/fragile)](https://github.com/mitsuhiko/fragile/blob/master/LICENSE)
[![rustc 1.42.0](https://img.shields.io/badge/rust-1.42%2B-orange.svg)](https://img.shields.io/badge/rust-1.42%2B-orange.svg)
[![Documentation](https://docs.rs/fragile/badge.svg)](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)