An experimental crate that defines the ToBoundedStatic
and IntoBoundedStatic
traits,
the ToStatic
macro and provides impls
for common types. This crate has zero-dependencies, is no_std
friendly and
forbids unsafe
code.
As described in the Common Rust Lifetime Misconceptions:
T: 'static
should be read as "T
is bounded by a'static
lifetime" not "T
has a'static
lifetime".
The traits ToBoundedStatic
and IntoBoundedStatic
can be used to convert any suitable T
and &T
to an
owned T
such that T: 'static
. Both traits define an associated type which is bounded by 'static
and provide a
method to convert to that bounded type.
The macros ToStatic
can be used to automatically derive ToBoundedStatic
and IntoBoundedStatic
for any struct
or enum
that can be converted to a form that is bounded by 'static
.
Experimental
This is useful for data structures which directly or indirectly contain Cow<T>
types that must be supplied to
a function which requires the 'static
bound (i.e. std::thread::spawn
):
```rust
struct Foo<'a> {
foo: Cow<'a, str>,
bar: Vec
enum Bar<'a> { First, Second(Cow<'a, str>), }
fn main() { let value = String::from("data"); let foo = Foo { foo: Cow::from(&value), bar: vec![Bar::First, Bar::Second(Cow::from(&value))] }; let foostatic = foo.intostatic(); std::thread::spawn(move || { asserteq!(foostatic.foo, "data"); asserteq!(foostatic.bar, vec![Bar::First, Bar::Second("data".into())]) }).join().unwrap(); } ```
ToOwned
trait?The ToOwned
trait defines an associated type Owned
which
is not bound by 'static
and therefore the follow will not compile:
```rust use std::borrow::Cow;
fn main() { #[derive(Clone)] struct Foo<'a> { foo: Cow<'a, str>, }
fn ensure_static<T: 'static>(_: T) {}
let s = String::from("data");
let foo = Foo { foo: Cow::from(&s) };
ensure_static(foo.to_owned())
} ```
Results in the following error:
error[E0597]: `s` does not live long enough
--> src/lib.rs:12:36
|
12 | let foo = Foo { foo: Cow::from(&s) };
| ----------^^-
| | |
| | borrowed value does not live long enough
| argument requires that `s` is borrowed for `'static`
13 | ensure_static(foo.to_owned())
14 | }
| - `s` dropped here while still borrowed
Replacing Clone
with ToStatic
and using into_static()
(or to_static()
as needed) allows the example to compile:
```rust use std::borrow::Cow;
fn main() {
#[derive(ToStatic)]
struct Foo<'a> {
foo: Cow<'a, str>,
}
fn ensure_static<T: 'static>(_: T) {}
let s = String::from("data");
let foo = Foo { foo: Cow::from(&s) };
ensure_static(foo.into_static())
} ```
bounded-static
is distributed under the terms of the Apache License (Version 2.0).
See LICENSE for details.
Copyright 2022