Crate pin_project
source · [−]Expand description
A crate for safe and ergonomic pin-projection.
Usage
Add this to your Cargo.toml
:
[dependencies]
pin-project = "1"
Compiler support: requires rustc 1.56+
Examples
#[pin_project]
attribute creates projection types
covering all the fields of struct or enum.
use std::pin::Pin;
use pin_project::pin_project;
#[pin_project]
struct Struct<T, U> {
#[pin]
pinned: T,
unpinned: U,
}
impl<T, U> Struct<T, U> {
fn method(self: Pin<&mut Self>) {
let this = self.project();
let _: Pin<&mut T> = this.pinned; // Pinned reference to the field
let _: &mut U = this.unpinned; // Normal reference to the field
}
}
code like this will be generated
To use #[pin_project]
on enums, you need to name the projection type
returned from the method.
use std::pin::Pin;
use pin_project::pin_project;
#[pin_project(project = EnumProj)]
enum Enum<T, U> {
Pinned(#[pin] T),
Unpinned(U),
}
impl<T, U> Enum<T, U> {
fn method(self: Pin<&mut Self>) {
match self.project() {
EnumProj::Pinned(x) => {
let _: Pin<&mut T> = x;
}
EnumProj::Unpinned(y) => {
let _: &mut U = y;
}
}
}
}
code like this will be generated
See #[pin_project]
attribute for more details, and
see examples directory for more examples and generated code.
Related Projects
- pin-project-lite: A lightweight version of pin-project written with declarative macros.
Traits
A trait used for custom implementations of
Unpin
.Attribute Macros
An attribute that creates projection types covering all the fields of
struct or enum.
An attribute used for custom implementations of
Drop
.