summaryrefslogtreecommitdiffstats
path: root/src/test/ui/transmutability/visibility/assume/should_accept_if_dst_has_unreachable_ty.rs
blob: b9b74d18338af0c1fbbcada00b77d90287757987 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
//! If visibility is assumed, a transmutation should be accepted even if the
//! destination type contains an unreachable field (e.g., a public field with a
//! private type). (This rule is distinct from type privacy, which still may
//! forbid naming such types.)

#![crate_type = "lib"]
#![feature(transmutability)]
#![allow(dead_code)]

mod assert {
    use std::mem::{Assume, BikeshedIntrinsicFrom};

    pub fn is_transmutable<Src, Dst, Context>()
    where
        Dst: BikeshedIntrinsicFrom<Src, Context, { Assume::SAFETY }>
        // safety IS assumed --------------------^^^^^^^^^^^^^^^^^^
    {}
}

mod src {
    #[repr(C)] pub(self) struct Zst;

    #[repr(C)] pub(in super) struct Src {
        pub(self) field: Zst,
    }
}

mod dst {
    #[repr(C)] pub(in super) struct Zst;

    // unreachable type
    #[repr(C)] pub(self) struct Dst {
        pub(in super) field: Zst,
    }
}

fn test() {
    struct Context;
    assert::is_transmutable::<src::Src, dst::Dst, Context>(); //~ ERROR `Dst` is private
}