30c0e4e72b
* ensuring that offset_of!(Self, ...) works iff inside an impl block * ensuring that the output type is usize and doesn't coerce. this can be changed in the future, but if it is done, it should be a conscious descision * improving the privacy checking test * ensuring that generics don't let you escape the unsized check
58 lines
1.3 KiB
Rust
58 lines
1.3 KiB
Rust
#![feature(offset_of)]
|
|
|
|
use std::mem::offset_of;
|
|
|
|
struct C<T> {
|
|
v: T,
|
|
w: T,
|
|
}
|
|
|
|
struct S {
|
|
v: u8,
|
|
w: u16,
|
|
}
|
|
|
|
impl S {
|
|
fn v_offs() -> usize {
|
|
offset_of!(Self, v)
|
|
}
|
|
fn v_offs_wrong_syntax() {
|
|
offset_of!(Self, Self::v); //~ ERROR no rules expected the token `::`
|
|
offset_of!(S, Self); //~ ERROR expected identifier, found keyword `Self`
|
|
//~| no field `Self` on type `S`
|
|
}
|
|
fn offs_in_c() -> usize {
|
|
offset_of!(C<Self>, w)
|
|
}
|
|
fn offs_in_c_colon() -> usize {
|
|
offset_of!(C::<Self>, w)
|
|
}
|
|
}
|
|
|
|
mod m {
|
|
use std::mem::offset_of;
|
|
fn off() {
|
|
offset_of!(self::S, v); //~ ERROR cannot find type `S` in module
|
|
offset_of!(super::S, v);
|
|
offset_of!(crate::S, v);
|
|
}
|
|
impl super::n::T {
|
|
fn v_offs_self() -> usize {
|
|
offset_of!(Self, v) //~ ERROR field `v` of struct `T` is private
|
|
}
|
|
}
|
|
}
|
|
|
|
mod n {
|
|
pub struct T { v: u8, }
|
|
}
|
|
|
|
fn main() {
|
|
offset_of!(self::S, v);
|
|
offset_of!(Self, v); //~ ERROR cannot find type `Self` in this scope
|
|
|
|
offset_of!(S, self); //~ ERROR expected identifier, found keyword `self`
|
|
//~| no field `self` on type `S`
|
|
offset_of!(S, v.self); //~ ERROR expected identifier, found keyword `self`
|
|
//~| no field `self` on type `u8`
|
|
}
|