pub trait AsyncFnMut<Args>: AsyncFnOnce<Args> {
// Required method
async fn call_mut(&mut self, args: Args) -> Self::Output;
}Expand description
The type implemented with this trait can be used multiple times with its states obtained by exclusive references.
§Examples
Normally, a HRTB to express any referenced value passed in as an argument.
A function caller returning generics...
#![feature(async_fn_in_trait)]
#![allow(incomplete_features)]
use async_closure::{capture_no_lifetimes::AsyncFnMut, async_owned_closure_mut};
// Here a caller requires a generic output.
async fn caller<T, F>(mut f: F) -> (T, F)
where F: for<'any> AsyncFnMut<(&'any str,), Output = T>
{
let s = String::from("Hi ");
f.call_mut((&s[..],)).await;
(f.call_mut(("there!",)).await, f)
}
#[pollster::main]
async fn main() {
let context = String::new();
let cb = async_owned_closure_mut!({
buf: String = context
}; async |s: &str| -> usize {
buf.push_str(s);
s.len()
});
let (last_len, cb) = caller(cb).await;
assert_eq!(last_len, 6);
let buf = cb.buf;
assert_eq!(buf, "Hi there!"); // have access to the closure's states
let cb = async_owned_closure_mut!({
buf: String = buf
}; async |s: &str| -> std::fmt::Result {
use std::fmt::Write;
write!(buf, " {s}")?;
Ok(())
});
let (res, cb) = caller(cb).await;
assert!(res.is_ok());
assert_eq!(cb.buf, "Hi there! Hi there!");
{
// Subtrait relation
use async_closure::capture_no_lifetimes::AsyncFnOnce;
assert!(cb.call_once((":)",)).await.is_ok());
}
}A struct caller implemented with specific types...
#![feature(async_fn_in_trait)]
#![allow(incomplete_features)]
use async_closure::{capture_no_lifetimes::AsyncFnMut, async_owned_closure_mut};
use std::marker::PhantomData;
struct Caller<T, F> {
async_closure: F,
_ph: PhantomData<*mut T>,
}
// Generic impls like the caller function above are similar.
// But here we present a specific scenario where its arguments and output are defined clearly.
impl<F> Caller<(), F>
where F: for<'any> AsyncFnMut<(&'any str,), Output = ()>
{
async fn run(mut self, s: &str) -> F {
self.async_closure.call_mut((s,)).await;
self.async_closure.call_mut((" world!",)).await;
self.async_closure
}
}
#[pollster::main]
async fn main() {
let context = String::new();
let cb = async_owned_closure_mut!({
buf: String = context
}; async |s: &str| -> () {
buf.push_str(s);
});
let caller = Caller { async_closure: cb, _ph: PhantomData };
let cb = caller.run("Hello").await;
assert_eq!(cb.buf, "Hello world!");
}Required Methods§
Dyn Compatibility§
This trait is not dyn compatible.
In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.