blob: 558afd6ec96e42738bc59e99ea005357160202df [file] [log] [blame]
#![rustfmt::skip]
// Part of the Crubit project, under the Apache License v2.0 with LLVM
// Exceptions. See /LICENSE for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
#![feature(const_ptr_offset_from, custom_inner_attributes)]
#![allow(non_camel_case_types)]
#![allow(non_snake_case)]
use memoffset_unstable_const::offset_of;
pub type __builtin_ms_va_list = *mut u8;
#[derive(Clone, Copy)]
#[repr(C)]
pub struct SomeClass {
pub public_member_variable_: i32,
private_member_variable_: i32,
}
impl Default for SomeClass {
#[inline(always)]
fn default() -> Self {
let mut tmp = std::mem::MaybeUninit::<Self>::zeroed();
unsafe {
crate::detail::__rust_thunk___ZN9SomeClassC1Ev(&mut tmp);
tmp.assume_init()
}
}
}
// rs_bindings_from_cc/test/golden/private_members.h;l=6
// Error while generating bindings for item 'SomeClass::SomeClass':
// Parameter #0 is not supported: Unsupported type 'class SomeClass &&'
// rs_bindings_from_cc/test/golden/private_members.h;l=6
// Error while generating bindings for item 'SomeClass::operator=':
// Parameter #0 is not supported: Unsupported type 'class SomeClass &&'
impl SomeClass {
#[inline(always)]
pub fn public_method<'a>(&'a mut self) {
unsafe { crate::detail::__rust_thunk___ZN9SomeClass13public_methodEv(self) }
}
}
impl SomeClass {
#[inline(always)]
pub fn public_static_method() {
unsafe { crate::detail::__rust_thunk___ZN9SomeClass20public_static_methodEv() }
}
}
// CRUBIT_RS_BINDINGS_FROM_CC_TEST_GOLDEN_PRIVATE_MEMBERS_H_
mod detail {
#[allow(unused_imports)]
use super::*;
extern "C" {
pub(crate) fn __rust_thunk___ZN9SomeClassC1Ev<'a>(
__this: &'a mut std::mem::MaybeUninit<SomeClass>,
);
#[link_name = "_ZN9SomeClass13public_methodEv"]
pub(crate) fn __rust_thunk___ZN9SomeClass13public_methodEv<'a>(__this: &'a mut SomeClass);
#[link_name = "_ZN9SomeClass20public_static_methodEv"]
pub(crate) fn __rust_thunk___ZN9SomeClass20public_static_methodEv();
}
}
const _: () = assert!(std::mem::size_of::<Option<&i32>>() == std::mem::size_of::<&i32>());
const _: () = assert!(std::mem::size_of::<SomeClass>() == 8usize);
const _: () = assert!(std::mem::align_of::<SomeClass>() == 4usize);
const _: () = assert!(offset_of!(SomeClass, public_member_variable_) * 8 == 0usize);
const _: () = assert!(offset_of!(SomeClass, private_member_variable_) * 8 == 32usize);