//@ run-pass //@ ignore-backends: gcc #![feature(c_variadic)] #[repr(transparent)] struct Struct(i32); impl Struct { unsafe extern "C" fn associated_function(mut ap: ...) -> i32 { unsafe { ap.arg() } } unsafe extern "C" fn method(&self, mut ap: ...) -> i32 { self.0 + unsafe { ap.arg::() } } } trait Trait: Sized { fn get(&self) -> i32; unsafe extern "C" fn trait_associated_function(mut ap: ...) -> i32 { unsafe { ap.arg() } } unsafe extern "C" fn trait_method_owned(self, mut ap: ...) -> i32 { self.get() + unsafe { ap.arg::() } } unsafe extern "C" fn trait_method_ref(&self, mut ap: ...) -> i32 { self.get() + unsafe { ap.arg::() } } unsafe extern "C" fn trait_method_mut(&mut self, mut ap: ...) -> i32 { self.get() + unsafe { ap.arg::() } } unsafe extern "C" fn trait_fat_pointer(self: Box, mut ap: ...) -> i32 { self.get() + unsafe { ap.arg::() } } } impl Trait for Struct { fn get(&self) -> i32 { self.0 } } fn main() { unsafe { assert_eq!(Struct::associated_function(32), 32); assert_eq!(Struct(100).method(32), 132); assert_eq!(Struct::trait_associated_function(32), 32); assert_eq!(Struct(100).trait_method_owned(32), 132); assert_eq!(Struct(100).trait_method_ref(32), 132); assert_eq!(Struct(100).trait_method_mut(32), 132); assert_eq!(Struct::trait_fat_pointer(Box::new(Struct(100)), 32), 132); assert_eq!(::trait_associated_function(32), 32); assert_eq!(Trait::trait_method_owned(Struct(100), 32), 132); assert_eq!(Trait::trait_method_ref(&Struct(100), 32), 132); assert_eq!(Trait::trait_method_mut(&mut Struct(100), 32), 132); assert_eq!(Trait::trait_fat_pointer(Box::new(Struct(100)), 32), 132); type Associated = unsafe extern "C" fn(...) -> i32; type Method = unsafe extern "C" fn(T, ...) -> i32; assert_eq!((Struct::trait_associated_function as Associated)(32), 32); assert_eq!((Struct::trait_method_owned as Method<_>)(Struct(100), 32), 132); assert_eq!((Struct::trait_method_ref as Method<_>)(&Struct(100), 32), 132); assert_eq!((Struct::trait_method_mut as Method<_>)(&mut Struct(100), 32), 132); assert_eq!((Struct::trait_fat_pointer as Method<_>)(Box::new(Struct(100)), 32), 132); } }