2022-10-12 04:07:30 -05:00
|
|
|
#![allow(dead_code, unused_variables)]
|
|
|
|
|
|
|
|
use std::sync::Arc;
|
|
|
|
|
|
|
|
#[derive(Debug)]
|
|
|
|
struct A;
|
|
|
|
#[derive(Debug)]
|
|
|
|
struct B;
|
|
|
|
|
|
|
|
fn process_without_annot(arc: &Arc<(A, B)>) {
|
|
|
|
let (a, b) = **arc; // suggests putting `&**arc` here; with that, fixed!
|
2024-02-01 16:45:00 -06:00
|
|
|
//~^ ERROR: cannot move out of an `Arc`
|
2022-10-12 04:07:30 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
fn process_with_annot(arc: &Arc<(A, B)>) {
|
|
|
|
let (a, b): (A, B) = &**arc; // suggests putting `&**arc` here too
|
|
|
|
//~^ ERROR mismatched types
|
|
|
|
}
|
|
|
|
|
|
|
|
fn process_with_tuple_annot(mutation: &mut (A, B), arc: &Arc<(A, B)>) {
|
|
|
|
let (a, b): ((A, B), A) = (&mut *mutation, &(**arc).0); // suggests putting `&**arc` here too
|
|
|
|
//~^ ERROR mismatched types
|
|
|
|
//~| ERROR mismatched types
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {}
|