blob: 1a11f1beb00709a80964007baef5264bab754c72 [file] [log] [blame]
#![allow(
dead_code,
non_snake_case,
non_camel_case_types,
non_upper_case_globals
)]
pub mod foo {
pub type Type = ::std::os::raw::c_uint;
pub const THIS: Type = 0;
pub const SHOULD_BE: Type = 1;
pub const A_CONSTANT: Type = 2;
pub const ALSO_THIS: Type = 42;
pub const AND_ALSO_THIS: Type = 42;
}
pub mod anon_enum {
pub type Type = ::std::os::raw::c_uint;
pub const Variant1: Type = 0;
pub const Variant2: Type = 1;
pub const Variant3: Type = 2;
}
pub mod ns1_foo {
pub type Type = ::std::os::raw::c_uint;
pub const THIS: Type = 0;
pub const SHOULD_BE: Type = 1;
pub const A_CONSTANT: Type = 2;
pub const ALSO_THIS: Type = 42;
}
pub mod ns2_Foo {
pub type Type = ::std::os::raw::c_int;
pub const Variant1: Type = 0;
pub const Variant2: Type = 1;
}
pub use self::anon_enum::Type as anon_enum_alias1;
pub use self::anon_enum_alias1 as anon_enum_alias2;
pub use self::anon_enum_alias2 as anon_enum_alias3;
pub use self::foo::Type as foo_alias1;
pub use self::foo_alias1 as foo_alias2;
pub use self::foo_alias2 as foo_alias3;
#[repr(C)]
#[derive(Debug, Copy, Clone)]
pub struct bar {
pub member1: foo::Type,
pub member2: foo_alias1,
pub member3: foo_alias2,
pub member4: foo_alias3,
pub member5: ns1_foo::Type,
pub member6: *mut ns2_Foo::Type,
pub member7: anon_enum::Type,
pub member8: anon_enum_alias1,
pub member9: anon_enum_alias2,
pub member10: anon_enum_alias3,
}
#[test]
fn bindgen_test_layout_bar() {
assert_eq!(
::std::mem::size_of::<bar>(),
48usize,
concat!("Size of: ", stringify!(bar))
);
assert_eq!(
::std::mem::align_of::<bar>(),
8usize,
concat!("Alignment of ", stringify!(bar))
);
assert_eq!(
{
let struct_instance = unsafe { std::mem::zeroed::<bar>() };
let struct_ptr = &struct_instance as *const bar;
let field_ptr = std::ptr::addr_of!(struct_instance.member1);
let struct_address = struct_ptr as usize;
let field_address = field_ptr as usize;
std::mem::forget(struct_instance);
field_address.checked_sub(struct_address).unwrap()
},
0usize,
concat!(
"Offset of field: ",
stringify!(bar),
"::",
stringify!(member1)
)
);
assert_eq!(
{
let struct_instance = unsafe { std::mem::zeroed::<bar>() };
let struct_ptr = &struct_instance as *const bar;
let field_ptr = std::ptr::addr_of!(struct_instance.member2);
let struct_address = struct_ptr as usize;
let field_address = field_ptr as usize;
std::mem::forget(struct_instance);
field_address.checked_sub(struct_address).unwrap()
},
4usize,
concat!(
"Offset of field: ",
stringify!(bar),
"::",
stringify!(member2)
)
);
assert_eq!(
{
let struct_instance = unsafe { std::mem::zeroed::<bar>() };
let struct_ptr = &struct_instance as *const bar;
let field_ptr = std::ptr::addr_of!(struct_instance.member3);
let struct_address = struct_ptr as usize;
let field_address = field_ptr as usize;
std::mem::forget(struct_instance);
field_address.checked_sub(struct_address).unwrap()
},
8usize,
concat!(
"Offset of field: ",
stringify!(bar),
"::",
stringify!(member3)
)
);
assert_eq!(
{
let struct_instance = unsafe { std::mem::zeroed::<bar>() };
let struct_ptr = &struct_instance as *const bar;
let field_ptr = std::ptr::addr_of!(struct_instance.member4);
let struct_address = struct_ptr as usize;
let field_address = field_ptr as usize;
std::mem::forget(struct_instance);
field_address.checked_sub(struct_address).unwrap()
},
12usize,
concat!(
"Offset of field: ",
stringify!(bar),
"::",
stringify!(member4)
)
);
assert_eq!(
{
let struct_instance = unsafe { std::mem::zeroed::<bar>() };
let struct_ptr = &struct_instance as *const bar;
let field_ptr = std::ptr::addr_of!(struct_instance.member5);
let struct_address = struct_ptr as usize;
let field_address = field_ptr as usize;
std::mem::forget(struct_instance);
field_address.checked_sub(struct_address).unwrap()
},
16usize,
concat!(
"Offset of field: ",
stringify!(bar),
"::",
stringify!(member5)
)
);
assert_eq!(
{
let struct_instance = unsafe { std::mem::zeroed::<bar>() };
let struct_ptr = &struct_instance as *const bar;
let field_ptr = std::ptr::addr_of!(struct_instance.member6);
let struct_address = struct_ptr as usize;
let field_address = field_ptr as usize;
std::mem::forget(struct_instance);
field_address.checked_sub(struct_address).unwrap()
},
24usize,
concat!(
"Offset of field: ",
stringify!(bar),
"::",
stringify!(member6)
)
);
assert_eq!(
{
let struct_instance = unsafe { std::mem::zeroed::<bar>() };
let struct_ptr = &struct_instance as *const bar;
let field_ptr = std::ptr::addr_of!(struct_instance.member7);
let struct_address = struct_ptr as usize;
let field_address = field_ptr as usize;
std::mem::forget(struct_instance);
field_address.checked_sub(struct_address).unwrap()
},
32usize,
concat!(
"Offset of field: ",
stringify!(bar),
"::",
stringify!(member7)
)
);
assert_eq!(
{
let struct_instance = unsafe { std::mem::zeroed::<bar>() };
let struct_ptr = &struct_instance as *const bar;
let field_ptr = std::ptr::addr_of!(struct_instance.member8);
let struct_address = struct_ptr as usize;
let field_address = field_ptr as usize;
std::mem::forget(struct_instance);
field_address.checked_sub(struct_address).unwrap()
},
36usize,
concat!(
"Offset of field: ",
stringify!(bar),
"::",
stringify!(member8)
)
);
assert_eq!(
{
let struct_instance = unsafe { std::mem::zeroed::<bar>() };
let struct_ptr = &struct_instance as *const bar;
let field_ptr = std::ptr::addr_of!(struct_instance.member9);
let struct_address = struct_ptr as usize;
let field_address = field_ptr as usize;
std::mem::forget(struct_instance);
field_address.checked_sub(struct_address).unwrap()
},
40usize,
concat!(
"Offset of field: ",
stringify!(bar),
"::",
stringify!(member9)
)
);
assert_eq!(
{
let struct_instance = unsafe { std::mem::zeroed::<bar>() };
let struct_ptr = &struct_instance as *const bar;
let field_ptr = std::ptr::addr_of!(struct_instance.member10);
let struct_address = struct_ptr as usize;
let field_address = field_ptr as usize;
std::mem::forget(struct_instance);
field_address.checked_sub(struct_address).unwrap()
},
44usize,
concat!(
"Offset of field: ",
stringify!(bar),
"::",
stringify!(member10)
)
);
}
impl Default for bar {
fn default() -> Self {
let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
unsafe {
::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
s.assume_init()
}
}
}
#[repr(C)]
#[derive(Debug, Copy, Clone)]
pub struct Baz {
pub member1: ns2_Foo::Type,
}
#[test]
fn bindgen_test_layout_Baz() {
assert_eq!(
::std::mem::size_of::<Baz>(),
4usize,
concat!("Size of: ", stringify!(Baz))
);
assert_eq!(
::std::mem::align_of::<Baz>(),
4usize,
concat!("Alignment of ", stringify!(Baz))
);
assert_eq!(
{
let struct_instance = unsafe { std::mem::zeroed::<Baz>() };
let struct_ptr = &struct_instance as *const Baz;
let field_ptr = std::ptr::addr_of!(struct_instance.member1);
let struct_address = struct_ptr as usize;
let field_address = field_ptr as usize;
std::mem::forget(struct_instance);
field_address.checked_sub(struct_address).unwrap()
},
0usize,
concat!(
"Offset of field: ",
stringify!(Baz),
"::",
stringify!(member1)
)
);
}
impl Default for Baz {
fn default() -> Self {
let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
unsafe {
::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
s.assume_init()
}
}
}
pub mod one_Foo {
pub type Type = ::std::os::raw::c_int;
pub const Variant1: Type = 0;
pub const Variant2: Type = 1;
}
#[repr(C)]
#[derive(Debug, Copy, Clone)]
pub struct Bar {
pub baz: *mut one_Foo::Type,
}
#[test]
fn bindgen_test_layout_Bar() {
assert_eq!(
::std::mem::size_of::<Bar>(),
8usize,
concat!("Size of: ", stringify!(Bar))
);
assert_eq!(
::std::mem::align_of::<Bar>(),
8usize,
concat!("Alignment of ", stringify!(Bar))
);
assert_eq!(
{
let struct_instance = unsafe { std::mem::zeroed::<Bar>() };
let struct_ptr = &struct_instance as *const Bar;
let field_ptr = std::ptr::addr_of!(struct_instance.baz);
let struct_address = struct_ptr as usize;
let field_address = field_ptr as usize;
std::mem::forget(struct_instance);
field_address.checked_sub(struct_address).unwrap()
},
0usize,
concat!("Offset of field: ", stringify!(Bar), "::", stringify!(baz))
);
}
impl Default for Bar {
fn default() -> Self {
let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
unsafe {
::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
s.assume_init()
}
}
}
extern "C" {
#[link_name = "\u{1}_Z5func13fooPS_PS0_"]
pub fn func1(
arg1: foo::Type,
arg2: *mut foo::Type,
arg3: *mut *mut foo::Type,
) -> *mut foo::Type;
}
extern "C" {
#[link_name = "\u{1}_Z5func23fooPS_PS0_"]
pub fn func2(
arg1: foo_alias1,
arg2: *mut foo_alias1,
arg3: *mut *mut foo_alias1,
) -> *mut foo_alias1;
}
#[repr(C)]
#[derive(Debug, Copy, Clone)]
pub struct Thing<T> {
pub thing: T,
pub _phantom_0: ::std::marker::PhantomData<::std::cell::UnsafeCell<T>>,
}
impl<T> Default for Thing<T> {
fn default() -> Self {
let mut s = ::std::mem::MaybeUninit::<Self>::uninit();
unsafe {
::std::ptr::write_bytes(s.as_mut_ptr(), 0, 1);
s.assume_init()
}
}
}
extern "C" {
#[link_name = "\u{1}_Z5func35ThingI3fooE"]
pub fn func3(arg1: Thing<foo::Type>) -> foo::Type;
}
extern "C" {
#[link_name = "\u{1}_Z5func45ThingIS_I3fooEE"]
pub fn func4(arg1: Thing<Thing<foo::Type>>) -> foo::Type;
}