blob: dacb5d88941982596dd3ee74159b79ca4a3bdfbb [file] [log] [blame]
// 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
// Automatically @generated Rust bindings for C++ target
// //rs_bindings_from_cc/test/golden:private_members_cc
#![rustfmt::skip]
#![feature(const_ptr_offset_from, custom_inner_attributes)]
#![allow(non_camel_case_types)]
#![allow(non_snake_case)]
use ::std as rust_std;
use memoffset_unstable_const::offset_of;
// 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
#[derive(Clone, Copy)]
#[repr(C)]
pub struct SomeClass {
pub public_member_variable_: i32,
private_member_variable_: i32,
}
forward_declare::unsafe_define!(forward_declare::symbol!("SomeClass"), SomeClass);
impl Default for SomeClass {
#[inline(always)]
fn default() -> Self {
let mut tmp = rust_std::mem::MaybeUninit::<Self>::zeroed();
unsafe {
detail::__rust_thunk___ZN9SomeClassC1Ev(&mut tmp);
tmp.assume_init()
}
}
}
impl<'b> From<ctor::RvalueReference<'b, SomeClass>> for SomeClass {
#[inline(always)]
fn from(__param_0: ctor::RvalueReference<'b, SomeClass>) -> Self {
let mut tmp = rust_std::mem::MaybeUninit::<Self>::zeroed();
unsafe {
detail::__rust_thunk___ZN9SomeClassC1EOS_(&mut tmp, __param_0);
tmp.assume_init()
}
}
}
// rs_bindings_from_cc/test/golden/private_members.h;l=10
// Error while generating bindings for item 'SomeClass::operator=':
// Bindings for this kind of operator are not supported
// rs_bindings_from_cc/test/golden/private_members.h;l=10
// Error while generating bindings for item 'SomeClass::operator=':
// Bindings for this kind of operator are not supported
impl SomeClass {
#[inline(always)]
pub fn public_method<'a>(&'a mut self) {
unsafe { detail::__rust_thunk___ZN9SomeClass13public_methodEv(self) }
}
}
impl SomeClass {
#[inline(always)]
pub fn public_static_method() {
unsafe { 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 rust_std::mem::MaybeUninit<SomeClass>,
);
pub(crate) fn __rust_thunk___ZN9SomeClassC1EOS_<'a, 'b>(
__this: &'a mut rust_std::mem::MaybeUninit<SomeClass>,
__param_0: ctor::RvalueReference<'b, 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!(rust_std::mem::size_of::<Option<&i32>>() == rust_std::mem::size_of::<&i32>());
const _: () = assert!(rust_std::mem::size_of::<SomeClass>() == 8usize);
const _: () = assert!(rust_std::mem::align_of::<SomeClass>() == 4usize);
const _: () = {
static_assertions::assert_impl_all!(SomeClass: Clone);
};
const _: () = {
static_assertions::assert_impl_all!(SomeClass: Copy);
};
const _: () = {
static_assertions::assert_not_impl_all!(SomeClass: Drop);
};
const _: () = assert!(offset_of!(SomeClass, public_member_variable_) * 8 == 0usize);
const _: () = assert!(offset_of!(SomeClass, private_member_variable_) * 8 == 32usize);