blob: b9b74d18338af0c1fbbcada00b77d90287757987 [file] [log] [blame]
//! 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
}