blob: 96236454642028a70dff8b8e9911b1fb5207d624 [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 the following C++ target:
// //rs_bindings_from_cc/test/golden:inheritance_cc
// Features: experimental, supported
#![rustfmt::skip]
#![feature(custom_inner_attributes, impl_trait_in_assoc_type, negative_impls, register_tool)]
#![allow(stable_features)]
#![no_std]
#![register_tool(__crubit)]
#![allow(improper_ctypes)]
#![allow(nonstandard_style)]
#![deny(warnings)]
/// Using classes to force these to be non-POD.
/// In the Itanium ABI, the tail padding of POD types cannot be reused by other
/// objects, even if the POD type is potentially-overlapping.
#[derive(Clone, Copy)]
#[repr(C)]
#[__crubit::annotate(cpp_type = "Base0")]
pub struct Base0 {
__non_field_data: [::core::mem::MaybeUninit<u8>; 1],
}
impl !Send for Base0 {}
impl !Sync for Base0 {}
forward_declare::unsafe_define!(forward_declare::symbol!("Base0"), crate::Base0);
impl Default for Base0 {
#[inline(always)]
fn default() -> Self {
let mut tmp = ::core::mem::MaybeUninit::<Self>::zeroed();
unsafe {
crate::detail::__rust_thunk___ZN5Base0C1Ev(&mut tmp);
tmp.assume_init()
}
}
}
impl<'b> From<::ctor::RvalueReference<'b, Self>> for Base0 {
#[inline(always)]
fn from(__param_0: ::ctor::RvalueReference<'b, Self>) -> Self {
let mut tmp = ::core::mem::MaybeUninit::<Self>::zeroed();
unsafe {
crate::detail::__rust_thunk___ZN5Base0C1EOS_(&mut tmp, __param_0);
tmp.assume_init()
}
}
}
impl<'b> ::ctor::UnpinAssign<&'b Self> for Base0 {
#[inline(always)]
fn unpin_assign<'a>(&'a mut self, __param_0: &'b Self) {
unsafe {
crate::detail::__rust_thunk___ZN5Base0aSERKS_(self, __param_0);
}
}
}
impl<'b> ::ctor::UnpinAssign<::ctor::RvalueReference<'b, Self>> for Base0 {
#[inline(always)]
fn unpin_assign<'a>(&'a mut self, __param_0: ::ctor::RvalueReference<'b, Self>) {
unsafe {
crate::detail::__rust_thunk___ZN5Base0aSEOS_(self, __param_0);
}
}
}
#[derive(Clone, Copy)]
#[repr(C, align(8))]
#[__crubit::annotate(cpp_type = "Base1")]
pub struct Base1 {
__non_field_data: [::core::mem::MaybeUninit<u8>; 0],
/// Reason for representing this field as a blob of bytes:
/// Types of non-public C++ fields can be elided away
pub(crate) b1_1_: [::core::mem::MaybeUninit<u8>; 8],
/// Reason for representing this field as a blob of bytes:
/// Types of non-public C++ fields can be elided away
pub(crate) b1_2_: [::core::mem::MaybeUninit<u8>; 8],
}
impl !Send for Base1 {}
impl !Sync for Base1 {}
forward_declare::unsafe_define!(forward_declare::symbol!("Base1"), crate::Base1);
impl Default for Base1 {
#[inline(always)]
fn default() -> Self {
let mut tmp = ::core::mem::MaybeUninit::<Self>::zeroed();
unsafe {
crate::detail::__rust_thunk___ZN5Base1C1Ev(&mut tmp);
tmp.assume_init()
}
}
}
impl<'b> From<::ctor::RvalueReference<'b, Self>> for Base1 {
#[inline(always)]
fn from(__param_0: ::ctor::RvalueReference<'b, Self>) -> Self {
let mut tmp = ::core::mem::MaybeUninit::<Self>::zeroed();
unsafe {
crate::detail::__rust_thunk___ZN5Base1C1EOS_(&mut tmp, __param_0);
tmp.assume_init()
}
}
}
impl<'b> ::ctor::UnpinAssign<&'b Self> for Base1 {
#[inline(always)]
fn unpin_assign<'a>(&'a mut self, __param_0: &'b Self) {
unsafe {
crate::detail::__rust_thunk___ZN5Base1aSERKS_(self, __param_0);
}
}
}
impl<'b> ::ctor::UnpinAssign<::ctor::RvalueReference<'b, Self>> for Base1 {
#[inline(always)]
fn unpin_assign<'a>(&'a mut self, __param_0: ::ctor::RvalueReference<'b, Self>) {
unsafe {
crate::detail::__rust_thunk___ZN5Base1aSEOS_(self, __param_0);
}
}
}
#[derive(Clone, Copy)]
#[repr(C, align(2))]
#[__crubit::annotate(cpp_type = "Base2")]
pub struct Base2 {
__non_field_data: [::core::mem::MaybeUninit<u8>; 0],
/// Reason for representing this field as a blob of bytes:
/// Types of non-public C++ fields can be elided away
pub(crate) b2_1_: [::core::mem::MaybeUninit<u8>; 2],
}
impl !Send for Base2 {}
impl !Sync for Base2 {}
forward_declare::unsafe_define!(forward_declare::symbol!("Base2"), crate::Base2);
impl Default for Base2 {
#[inline(always)]
fn default() -> Self {
let mut tmp = ::core::mem::MaybeUninit::<Self>::zeroed();
unsafe {
crate::detail::__rust_thunk___ZN5Base2C1Ev(&mut tmp);
tmp.assume_init()
}
}
}
impl<'b> From<::ctor::RvalueReference<'b, Self>> for Base2 {
#[inline(always)]
fn from(__param_0: ::ctor::RvalueReference<'b, Self>) -> Self {
let mut tmp = ::core::mem::MaybeUninit::<Self>::zeroed();
unsafe {
crate::detail::__rust_thunk___ZN5Base2C1EOS_(&mut tmp, __param_0);
tmp.assume_init()
}
}
}
impl<'b> ::ctor::UnpinAssign<&'b Self> for Base2 {
#[inline(always)]
fn unpin_assign<'a>(&'a mut self, __param_0: &'b Self) {
unsafe {
crate::detail::__rust_thunk___ZN5Base2aSERKS_(self, __param_0);
}
}
}
impl<'b> ::ctor::UnpinAssign<::ctor::RvalueReference<'b, Self>> for Base2 {
#[inline(always)]
fn unpin_assign<'a>(&'a mut self, __param_0: ::ctor::RvalueReference<'b, Self>) {
unsafe {
crate::detail::__rust_thunk___ZN5Base2aSEOS_(self, __param_0);
}
}
}
#[derive(Clone, Copy)]
#[repr(C, align(8))]
#[__crubit::annotate(cpp_type = "Derived")]
pub struct Derived {
__non_field_data: [::core::mem::MaybeUninit<u8>; 12],
pub derived_1: ::core::ffi::c_char,
}
impl !Send for Derived {}
impl !Sync for Derived {}
forward_declare::unsafe_define!(forward_declare::symbol!("Derived"), crate::Derived);
impl Default for Derived {
#[inline(always)]
fn default() -> Self {
let mut tmp = ::core::mem::MaybeUninit::<Self>::zeroed();
unsafe {
crate::detail::__rust_thunk___ZN7DerivedC1Ev(&mut tmp);
tmp.assume_init()
}
}
}
impl<'b> From<::ctor::RvalueReference<'b, Self>> for Derived {
#[inline(always)]
fn from(__param_0: ::ctor::RvalueReference<'b, Self>) -> Self {
let mut tmp = ::core::mem::MaybeUninit::<Self>::zeroed();
unsafe {
crate::detail::__rust_thunk___ZN7DerivedC1EOS_(&mut tmp, __param_0);
tmp.assume_init()
}
}
}
impl<'b> ::ctor::UnpinAssign<&'b Self> for Derived {
#[inline(always)]
fn unpin_assign<'a>(&'a mut self, __param_0: &'b Self) {
unsafe {
crate::detail::__rust_thunk___ZN7DerivedaSERKS_(self, __param_0);
}
}
}
impl<'b> ::ctor::UnpinAssign<::ctor::RvalueReference<'b, Self>> for Derived {
#[inline(always)]
fn unpin_assign<'a>(&'a mut self, __param_0: ::ctor::RvalueReference<'b, Self>) {
unsafe {
crate::detail::__rust_thunk___ZN7DerivedaSEOS_(self, __param_0);
}
}
}
unsafe impl oops::Inherits<crate::Base0> for crate::Derived {
unsafe fn upcast_ptr(derived: *const Self) -> *const crate::Base0 {
(derived as *const _ as *const u8).offset(0) as *const crate::Base0
}
}
unsafe impl oops::Inherits<crate::Base1> for crate::Derived {
unsafe fn upcast_ptr(derived: *const Self) -> *const crate::Base1 {
(derived as *const _ as *const u8).offset(0) as *const crate::Base1
}
}
unsafe impl oops::Inherits<crate::Base2> for crate::Derived {
unsafe fn upcast_ptr(derived: *const Self) -> *const crate::Base2 {
(derived as *const _ as *const u8).offset(10) as *const crate::Base2
}
}
#[::ctor::recursively_pinned]
#[repr(C, align(8))]
#[__crubit::annotate(cpp_type = "VirtualBase1")]
pub struct VirtualBase1 {
__non_field_data: [::core::mem::MaybeUninit<u8>; 24],
}
impl !Send for VirtualBase1 {}
impl !Sync for VirtualBase1 {}
forward_declare::unsafe_define!(forward_declare::symbol!("VirtualBase1"), crate::VirtualBase1);
impl ::ctor::CtorNew<()> for VirtualBase1 {
type CtorType = impl ::ctor::Ctor<Output = Self>;
#[inline(always)]
fn ctor_new(args: ()) -> Self::CtorType {
let () = args;
unsafe {
::ctor::FnCtor::new(
move |dest: ::core::pin::Pin<&mut ::core::mem::MaybeUninit<Self>>| {
crate::detail::__rust_thunk___ZN12VirtualBase1C1Ev(
::core::pin::Pin::into_inner_unchecked(dest),
);
},
)
}
}
}
impl<'b> ::ctor::CtorNew<&'b Self> for VirtualBase1 {
type CtorType = impl ::ctor::Ctor<Output = Self> + ::ctor::Captures<'b>;
#[inline(always)]
fn ctor_new(args: &'b Self) -> Self::CtorType {
let __param_0 = args;
unsafe {
::ctor::FnCtor::new(
move |dest: ::core::pin::Pin<&mut ::core::mem::MaybeUninit<Self>>| {
crate::detail::__rust_thunk___ZN12VirtualBase1C1ERKS_(
::core::pin::Pin::into_inner_unchecked(dest),
__param_0,
);
},
)
}
}
}
impl<'b> ::ctor::CtorNew<(&'b Self,)> for VirtualBase1 {
type CtorType = impl ::ctor::Ctor<Output = Self> + ::ctor::Captures<'b>;
#[inline(always)]
fn ctor_new(args: (&'b Self,)) -> Self::CtorType {
let (arg,) = args;
<Self as ::ctor::CtorNew<&'b Self>>::ctor_new(arg)
}
}
impl<'b> ::ctor::CtorNew<::ctor::RvalueReference<'b, Self>> for VirtualBase1 {
type CtorType = impl ::ctor::Ctor<Output = Self> + ::ctor::Captures<'b>;
#[inline(always)]
fn ctor_new(args: ::ctor::RvalueReference<'b, Self>) -> Self::CtorType {
let __param_0 = args;
unsafe {
::ctor::FnCtor::new(
move |dest: ::core::pin::Pin<&mut ::core::mem::MaybeUninit<Self>>| {
crate::detail::__rust_thunk___ZN12VirtualBase1C1EOS_(
::core::pin::Pin::into_inner_unchecked(dest),
__param_0,
);
},
)
}
}
}
impl<'b> ::ctor::CtorNew<(::ctor::RvalueReference<'b, Self>,)> for VirtualBase1 {
type CtorType = impl ::ctor::Ctor<Output = Self> + ::ctor::Captures<'b>;
#[inline(always)]
fn ctor_new(args: (::ctor::RvalueReference<'b, Self>,)) -> Self::CtorType {
let (arg,) = args;
<Self as ::ctor::CtorNew<::ctor::RvalueReference<'b, Self>>>::ctor_new(arg)
}
}
impl<'b> ::ctor::Assign<&'b Self> for VirtualBase1 {
#[inline(always)]
fn assign<'a>(self: ::core::pin::Pin<&'a mut Self>, __param_0: &'b Self) {
unsafe {
crate::detail::__rust_thunk___ZN12VirtualBase1aSERKS_(self, __param_0);
}
}
}
impl<'b> ::ctor::Assign<::ctor::RvalueReference<'b, Self>> for VirtualBase1 {
#[inline(always)]
fn assign<'a>(
self: ::core::pin::Pin<&'a mut Self>,
__param_0: ::ctor::RvalueReference<'b, Self>,
) {
unsafe {
crate::detail::__rust_thunk___ZN12VirtualBase1aSEOS_(self, __param_0);
}
}
}
unsafe impl oops::Inherits<crate::Base1> for crate::VirtualBase1 {
unsafe fn upcast_ptr(derived: *const Self) -> *const crate::Base1 {
crate::detail::__crubit_dynamic_upcast__12VirtualBase1__to__5Base1___2f_2fthird_5fparty_2fcrubit_2frs_5fbindings_5ffrom_5fcc_2ftest_2fgolden_3ainheritance_5fcc(derived)
}
}
#[::ctor::recursively_pinned]
#[repr(C, align(8))]
#[__crubit::annotate(cpp_type = "VirtualBase2")]
pub struct VirtualBase2 {
__non_field_data: [::core::mem::MaybeUninit<u8>; 24],
}
impl !Send for VirtualBase2 {}
impl !Sync for VirtualBase2 {}
forward_declare::unsafe_define!(forward_declare::symbol!("VirtualBase2"), crate::VirtualBase2);
impl ::ctor::CtorNew<()> for VirtualBase2 {
type CtorType = impl ::ctor::Ctor<Output = Self>;
#[inline(always)]
fn ctor_new(args: ()) -> Self::CtorType {
let () = args;
unsafe {
::ctor::FnCtor::new(
move |dest: ::core::pin::Pin<&mut ::core::mem::MaybeUninit<Self>>| {
crate::detail::__rust_thunk___ZN12VirtualBase2C1Ev(
::core::pin::Pin::into_inner_unchecked(dest),
);
},
)
}
}
}
impl<'b> ::ctor::CtorNew<&'b Self> for VirtualBase2 {
type CtorType = impl ::ctor::Ctor<Output = Self> + ::ctor::Captures<'b>;
#[inline(always)]
fn ctor_new(args: &'b Self) -> Self::CtorType {
let __param_0 = args;
unsafe {
::ctor::FnCtor::new(
move |dest: ::core::pin::Pin<&mut ::core::mem::MaybeUninit<Self>>| {
crate::detail::__rust_thunk___ZN12VirtualBase2C1ERKS_(
::core::pin::Pin::into_inner_unchecked(dest),
__param_0,
);
},
)
}
}
}
impl<'b> ::ctor::CtorNew<(&'b Self,)> for VirtualBase2 {
type CtorType = impl ::ctor::Ctor<Output = Self> + ::ctor::Captures<'b>;
#[inline(always)]
fn ctor_new(args: (&'b Self,)) -> Self::CtorType {
let (arg,) = args;
<Self as ::ctor::CtorNew<&'b Self>>::ctor_new(arg)
}
}
impl<'b> ::ctor::CtorNew<::ctor::RvalueReference<'b, Self>> for VirtualBase2 {
type CtorType = impl ::ctor::Ctor<Output = Self> + ::ctor::Captures<'b>;
#[inline(always)]
fn ctor_new(args: ::ctor::RvalueReference<'b, Self>) -> Self::CtorType {
let __param_0 = args;
unsafe {
::ctor::FnCtor::new(
move |dest: ::core::pin::Pin<&mut ::core::mem::MaybeUninit<Self>>| {
crate::detail::__rust_thunk___ZN12VirtualBase2C1EOS_(
::core::pin::Pin::into_inner_unchecked(dest),
__param_0,
);
},
)
}
}
}
impl<'b> ::ctor::CtorNew<(::ctor::RvalueReference<'b, Self>,)> for VirtualBase2 {
type CtorType = impl ::ctor::Ctor<Output = Self> + ::ctor::Captures<'b>;
#[inline(always)]
fn ctor_new(args: (::ctor::RvalueReference<'b, Self>,)) -> Self::CtorType {
let (arg,) = args;
<Self as ::ctor::CtorNew<::ctor::RvalueReference<'b, Self>>>::ctor_new(arg)
}
}
impl<'b> ::ctor::Assign<&'b Self> for VirtualBase2 {
#[inline(always)]
fn assign<'a>(self: ::core::pin::Pin<&'a mut Self>, __param_0: &'b Self) {
unsafe {
crate::detail::__rust_thunk___ZN12VirtualBase2aSERKS_(self, __param_0);
}
}
}
impl<'b> ::ctor::Assign<::ctor::RvalueReference<'b, Self>> for VirtualBase2 {
#[inline(always)]
fn assign<'a>(
self: ::core::pin::Pin<&'a mut Self>,
__param_0: ::ctor::RvalueReference<'b, Self>,
) {
unsafe {
crate::detail::__rust_thunk___ZN12VirtualBase2aSEOS_(self, __param_0);
}
}
}
unsafe impl oops::Inherits<crate::Base1> for crate::VirtualBase2 {
unsafe fn upcast_ptr(derived: *const Self) -> *const crate::Base1 {
crate::detail::__crubit_dynamic_upcast__12VirtualBase2__to__5Base1___2f_2fthird_5fparty_2fcrubit_2frs_5fbindings_5ffrom_5fcc_2ftest_2fgolden_3ainheritance_5fcc(derived)
}
}
#[::ctor::recursively_pinned]
#[repr(C, align(8))]
#[__crubit::annotate(cpp_type = "VirtualDerived")]
pub struct VirtualDerived {
__non_field_data: [::core::mem::MaybeUninit<u8>; 32],
}
impl !Send for VirtualDerived {}
impl !Sync for VirtualDerived {}
forward_declare::unsafe_define!(forward_declare::symbol!("VirtualDerived"), crate::VirtualDerived);
impl ::ctor::CtorNew<()> for VirtualDerived {
type CtorType = impl ::ctor::Ctor<Output = Self>;
#[inline(always)]
fn ctor_new(args: ()) -> Self::CtorType {
let () = args;
unsafe {
::ctor::FnCtor::new(
move |dest: ::core::pin::Pin<&mut ::core::mem::MaybeUninit<Self>>| {
crate::detail::__rust_thunk___ZN14VirtualDerivedC1Ev(
::core::pin::Pin::into_inner_unchecked(dest),
);
},
)
}
}
}
impl<'b> ::ctor::CtorNew<&'b Self> for VirtualDerived {
type CtorType = impl ::ctor::Ctor<Output = Self> + ::ctor::Captures<'b>;
#[inline(always)]
fn ctor_new(args: &'b Self) -> Self::CtorType {
let __param_0 = args;
unsafe {
::ctor::FnCtor::new(
move |dest: ::core::pin::Pin<&mut ::core::mem::MaybeUninit<Self>>| {
crate::detail::__rust_thunk___ZN14VirtualDerivedC1ERKS_(
::core::pin::Pin::into_inner_unchecked(dest),
__param_0,
);
},
)
}
}
}
impl<'b> ::ctor::CtorNew<(&'b Self,)> for VirtualDerived {
type CtorType = impl ::ctor::Ctor<Output = Self> + ::ctor::Captures<'b>;
#[inline(always)]
fn ctor_new(args: (&'b Self,)) -> Self::CtorType {
let (arg,) = args;
<Self as ::ctor::CtorNew<&'b Self>>::ctor_new(arg)
}
}
impl<'b> ::ctor::CtorNew<::ctor::RvalueReference<'b, Self>> for VirtualDerived {
type CtorType = impl ::ctor::Ctor<Output = Self> + ::ctor::Captures<'b>;
#[inline(always)]
fn ctor_new(args: ::ctor::RvalueReference<'b, Self>) -> Self::CtorType {
let __param_0 = args;
unsafe {
::ctor::FnCtor::new(
move |dest: ::core::pin::Pin<&mut ::core::mem::MaybeUninit<Self>>| {
crate::detail::__rust_thunk___ZN14VirtualDerivedC1EOS_(
::core::pin::Pin::into_inner_unchecked(dest),
__param_0,
);
},
)
}
}
}
impl<'b> ::ctor::CtorNew<(::ctor::RvalueReference<'b, Self>,)> for VirtualDerived {
type CtorType = impl ::ctor::Ctor<Output = Self> + ::ctor::Captures<'b>;
#[inline(always)]
fn ctor_new(args: (::ctor::RvalueReference<'b, Self>,)) -> Self::CtorType {
let (arg,) = args;
<Self as ::ctor::CtorNew<::ctor::RvalueReference<'b, Self>>>::ctor_new(arg)
}
}
impl<'b> ::ctor::Assign<&'b Self> for VirtualDerived {
#[inline(always)]
fn assign<'a>(self: ::core::pin::Pin<&'a mut Self>, __param_0: &'b Self) {
unsafe {
crate::detail::__rust_thunk___ZN14VirtualDerivedaSERKS_(self, __param_0);
}
}
}
impl<'b> ::ctor::Assign<::ctor::RvalueReference<'b, Self>> for VirtualDerived {
#[inline(always)]
fn assign<'a>(
self: ::core::pin::Pin<&'a mut Self>,
__param_0: ::ctor::RvalueReference<'b, Self>,
) {
unsafe {
crate::detail::__rust_thunk___ZN14VirtualDerivedaSEOS_(self, __param_0);
}
}
}
unsafe impl oops::Inherits<crate::VirtualBase1> for crate::VirtualDerived {
unsafe fn upcast_ptr(derived: *const Self) -> *const crate::VirtualBase1 {
crate::detail::__crubit_dynamic_upcast__14VirtualDerived__to__12VirtualBase1___2f_2fthird_5fparty_2fcrubit_2frs_5fbindings_5ffrom_5fcc_2ftest_2fgolden_3ainheritance_5fcc(derived)
}
}
unsafe impl oops::Inherits<crate::Base1> for crate::VirtualDerived {
unsafe fn upcast_ptr(derived: *const Self) -> *const crate::Base1 {
crate::detail::__crubit_dynamic_upcast__14VirtualDerived__to__5Base1___2f_2fthird_5fparty_2fcrubit_2frs_5fbindings_5ffrom_5fcc_2ftest_2fgolden_3ainheritance_5fcc(derived)
}
}
unsafe impl oops::Inherits<crate::VirtualBase2> for crate::VirtualDerived {
unsafe fn upcast_ptr(derived: *const Self) -> *const crate::VirtualBase2 {
crate::detail::__crubit_dynamic_upcast__14VirtualDerived__to__12VirtualBase2___2f_2fthird_5fparty_2fcrubit_2frs_5fbindings_5ffrom_5fcc_2ftest_2fgolden_3ainheritance_5fcc(derived)
}
}
#[::ctor::recursively_pinned]
#[repr(C, align(8))]
#[__crubit::annotate(cpp_type = "MyAbstractClass")]
pub struct MyAbstractClass {
__non_field_data: [::core::mem::MaybeUninit<u8>; 8],
}
impl !Send for MyAbstractClass {}
impl !Sync for MyAbstractClass {}
forward_declare::unsafe_define!(
forward_declare::symbol!("MyAbstractClass"),
crate::MyAbstractClass
);
// Error while generating bindings for item 'MyAbstractClass::MyAbstractClass':
// Can't directly construct values of type `MyAbstractClass` as it has a non-public or deleted destructor
// Error while generating bindings for item 'MyAbstractClass::MyAbstractClass':
// Can't directly construct values of type `MyAbstractClass` as it has a non-public or deleted destructor
impl<'b> ::ctor::Assign<&'b Self> for MyAbstractClass {
#[inline(always)]
fn assign<'a>(self: ::core::pin::Pin<&'a mut Self>, __param_0: &'b Self) {
unsafe {
crate::detail::__rust_thunk___ZN15MyAbstractClassaSERKS_(self, __param_0);
}
}
}
/// Method inheritance
#[derive(Clone, Copy)]
#[repr(C)]
#[__crubit::annotate(cpp_type = "MethodBase1")]
pub struct MethodBase1 {
__non_field_data: [::core::mem::MaybeUninit<u8>; 1],
}
impl !Send for MethodBase1 {}
impl !Sync for MethodBase1 {}
forward_declare::unsafe_define!(forward_declare::symbol!("MethodBase1"), crate::MethodBase1);
impl Default for MethodBase1 {
#[inline(always)]
fn default() -> Self {
let mut tmp = ::core::mem::MaybeUninit::<Self>::zeroed();
unsafe {
crate::detail::__rust_thunk___ZN11MethodBase1C1Ev(&mut tmp);
tmp.assume_init()
}
}
}
impl<'b> From<::ctor::RvalueReference<'b, Self>> for MethodBase1 {
#[inline(always)]
fn from(__param_0: ::ctor::RvalueReference<'b, Self>) -> Self {
let mut tmp = ::core::mem::MaybeUninit::<Self>::zeroed();
unsafe {
crate::detail::__rust_thunk___ZN11MethodBase1C1EOS_(&mut tmp, __param_0);
tmp.assume_init()
}
}
}
impl<'b> ::ctor::UnpinAssign<&'b Self> for MethodBase1 {
#[inline(always)]
fn unpin_assign<'a>(&'a mut self, __param_0: &'b Self) {
unsafe {
crate::detail::__rust_thunk___ZN11MethodBase1aSERKS_(self, __param_0);
}
}
}
impl<'b> ::ctor::UnpinAssign<::ctor::RvalueReference<'b, Self>> for MethodBase1 {
#[inline(always)]
fn unpin_assign<'a>(&'a mut self, __param_0: ::ctor::RvalueReference<'b, Self>) {
unsafe {
crate::detail::__rust_thunk___ZN11MethodBase1aSEOS_(self, __param_0);
}
}
}
impl MethodBase1 {
#[inline(always)]
pub fn Public<'a>(&'a mut self) {
unsafe { crate::detail::__rust_thunk___ZN11MethodBase16PublicEv(self) }
}
}
impl MethodBase1 {
#[inline(always)]
pub fn Colliding1<'a>(&'a mut self) {
unsafe { crate::detail::__rust_thunk___ZN11MethodBase110Colliding1Ev(self) }
}
}
impl MethodBase1 {
#[inline(always)]
pub fn Colliding2<'a>(&'a mut self) {
unsafe { crate::detail::__rust_thunk___ZN11MethodBase110Colliding2Ev(self) }
}
}
#[derive(Clone, Copy)]
#[repr(C)]
#[__crubit::annotate(cpp_type = "MethodBase2")]
pub struct MethodBase2 {
__non_field_data: [::core::mem::MaybeUninit<u8>; 1],
}
impl !Send for MethodBase2 {}
impl !Sync for MethodBase2 {}
forward_declare::unsafe_define!(forward_declare::symbol!("MethodBase2"), crate::MethodBase2);
impl Default for MethodBase2 {
#[inline(always)]
fn default() -> Self {
let mut tmp = ::core::mem::MaybeUninit::<Self>::zeroed();
unsafe {
crate::detail::__rust_thunk___ZN11MethodBase2C1Ev(&mut tmp);
tmp.assume_init()
}
}
}
impl<'b> From<::ctor::RvalueReference<'b, Self>> for MethodBase2 {
#[inline(always)]
fn from(__param_0: ::ctor::RvalueReference<'b, Self>) -> Self {
let mut tmp = ::core::mem::MaybeUninit::<Self>::zeroed();
unsafe {
crate::detail::__rust_thunk___ZN11MethodBase2C1EOS_(&mut tmp, __param_0);
tmp.assume_init()
}
}
}
impl<'b> ::ctor::UnpinAssign<&'b Self> for MethodBase2 {
#[inline(always)]
fn unpin_assign<'a>(&'a mut self, __param_0: &'b Self) {
unsafe {
crate::detail::__rust_thunk___ZN11MethodBase2aSERKS_(self, __param_0);
}
}
}
impl<'b> ::ctor::UnpinAssign<::ctor::RvalueReference<'b, Self>> for MethodBase2 {
#[inline(always)]
fn unpin_assign<'a>(&'a mut self, __param_0: ::ctor::RvalueReference<'b, Self>) {
unsafe {
crate::detail::__rust_thunk___ZN11MethodBase2aSEOS_(self, __param_0);
}
}
}
impl MethodBase2 {
#[inline(always)]
pub fn Colliding1<'a>(&'a mut self) {
unsafe { crate::detail::__rust_thunk___ZN11MethodBase210Colliding1Ev(self) }
}
}
impl MethodBase2 {
#[inline(always)]
pub fn Colliding2<'a>(&'a mut self) {
unsafe { crate::detail::__rust_thunk___ZN11MethodBase210Colliding2Ev(self) }
}
}
#[derive(Clone, Copy)]
#[repr(C)]
#[__crubit::annotate(cpp_type = "MethodDerived")]
pub struct MethodDerived {
__non_field_data: [::core::mem::MaybeUninit<u8>; 1],
}
impl !Send for MethodDerived {}
impl !Sync for MethodDerived {}
forward_declare::unsafe_define!(forward_declare::symbol!("MethodDerived"), crate::MethodDerived);
impl Default for MethodDerived {
#[inline(always)]
fn default() -> Self {
let mut tmp = ::core::mem::MaybeUninit::<Self>::zeroed();
unsafe {
crate::detail::__rust_thunk___ZN13MethodDerivedC1Ev(&mut tmp);
tmp.assume_init()
}
}
}
impl<'b> From<::ctor::RvalueReference<'b, Self>> for MethodDerived {
#[inline(always)]
fn from(__param_0: ::ctor::RvalueReference<'b, Self>) -> Self {
let mut tmp = ::core::mem::MaybeUninit::<Self>::zeroed();
unsafe {
crate::detail::__rust_thunk___ZN13MethodDerivedC1EOS_(&mut tmp, __param_0);
tmp.assume_init()
}
}
}
impl<'b> ::ctor::UnpinAssign<&'b Self> for MethodDerived {
#[inline(always)]
fn unpin_assign<'a>(&'a mut self, __param_0: &'b Self) {
unsafe {
crate::detail::__rust_thunk___ZN13MethodDerivedaSERKS_(self, __param_0);
}
}
}
impl<'b> ::ctor::UnpinAssign<::ctor::RvalueReference<'b, Self>> for MethodDerived {
#[inline(always)]
fn unpin_assign<'a>(&'a mut self, __param_0: ::ctor::RvalueReference<'b, Self>) {
unsafe {
crate::detail::__rust_thunk___ZN13MethodDerivedaSEOS_(self, __param_0);
}
}
}
unsafe impl oops::Inherits<crate::MethodBase1> for crate::MethodDerived {
unsafe fn upcast_ptr(derived: *const Self) -> *const crate::MethodBase1 {
(derived as *const _ as *const u8).offset(0) as *const crate::MethodBase1
}
}
unsafe impl oops::Inherits<crate::MethodBase2> for crate::MethodDerived {
unsafe fn upcast_ptr(derived: *const Self) -> *const crate::MethodBase2 {
(derived as *const _ as *const u8).offset(0) as *const crate::MethodBase2
}
}
mod detail {
#[allow(unused_imports)]
use super::*;
extern "C" {
pub(crate) fn __rust_thunk___ZN5Base0C1Ev<'a>(
__this: &'a mut ::core::mem::MaybeUninit<crate::Base0>,
);
pub(crate) fn __rust_thunk___ZN5Base0C1EOS_<'a, 'b>(
__this: &'a mut ::core::mem::MaybeUninit<crate::Base0>,
__param_0: ::ctor::RvalueReference<'b, crate::Base0>,
);
pub(crate) fn __rust_thunk___ZN5Base0aSERKS_<'a, 'b>(
__this: &'a mut crate::Base0,
__param_0: &'b crate::Base0,
) -> &'a mut crate::Base0;
pub(crate) fn __rust_thunk___ZN5Base0aSEOS_<'a, 'b>(
__this: &'a mut crate::Base0,
__param_0: ::ctor::RvalueReference<'b, crate::Base0>,
) -> &'a mut crate::Base0;
pub(crate) fn __rust_thunk___ZN5Base1C1Ev<'a>(
__this: &'a mut ::core::mem::MaybeUninit<crate::Base1>,
);
pub(crate) fn __rust_thunk___ZN5Base1C1EOS_<'a, 'b>(
__this: &'a mut ::core::mem::MaybeUninit<crate::Base1>,
__param_0: ::ctor::RvalueReference<'b, crate::Base1>,
);
pub(crate) fn __rust_thunk___ZN5Base1aSERKS_<'a, 'b>(
__this: &'a mut crate::Base1,
__param_0: &'b crate::Base1,
) -> &'a mut crate::Base1;
pub(crate) fn __rust_thunk___ZN5Base1aSEOS_<'a, 'b>(
__this: &'a mut crate::Base1,
__param_0: ::ctor::RvalueReference<'b, crate::Base1>,
) -> &'a mut crate::Base1;
pub(crate) fn __rust_thunk___ZN5Base2C1Ev<'a>(
__this: &'a mut ::core::mem::MaybeUninit<crate::Base2>,
);
pub(crate) fn __rust_thunk___ZN5Base2C1EOS_<'a, 'b>(
__this: &'a mut ::core::mem::MaybeUninit<crate::Base2>,
__param_0: ::ctor::RvalueReference<'b, crate::Base2>,
);
pub(crate) fn __rust_thunk___ZN5Base2aSERKS_<'a, 'b>(
__this: &'a mut crate::Base2,
__param_0: &'b crate::Base2,
) -> &'a mut crate::Base2;
pub(crate) fn __rust_thunk___ZN5Base2aSEOS_<'a, 'b>(
__this: &'a mut crate::Base2,
__param_0: ::ctor::RvalueReference<'b, crate::Base2>,
) -> &'a mut crate::Base2;
pub(crate) fn __rust_thunk___ZN7DerivedC1Ev<'a>(
__this: &'a mut ::core::mem::MaybeUninit<crate::Derived>,
);
pub(crate) fn __rust_thunk___ZN7DerivedC1EOS_<'a, 'b>(
__this: &'a mut ::core::mem::MaybeUninit<crate::Derived>,
__param_0: ::ctor::RvalueReference<'b, crate::Derived>,
);
pub(crate) fn __rust_thunk___ZN7DerivedaSERKS_<'a, 'b>(
__this: &'a mut crate::Derived,
__param_0: &'b crate::Derived,
) -> &'a mut crate::Derived;
pub(crate) fn __rust_thunk___ZN7DerivedaSEOS_<'a, 'b>(
__this: &'a mut crate::Derived,
__param_0: ::ctor::RvalueReference<'b, crate::Derived>,
) -> &'a mut crate::Derived;
pub(crate) fn __rust_thunk___ZN12VirtualBase1C1Ev<'a>(
__this: &'a mut ::core::mem::MaybeUninit<crate::VirtualBase1>,
);
pub(crate) fn __rust_thunk___ZN12VirtualBase1C1ERKS_<'a, 'b>(
__this: &'a mut ::core::mem::MaybeUninit<crate::VirtualBase1>,
__param_0: &'b crate::VirtualBase1,
);
pub(crate) fn __rust_thunk___ZN12VirtualBase1C1EOS_<'a, 'b>(
__this: &'a mut ::core::mem::MaybeUninit<crate::VirtualBase1>,
__param_0: ::ctor::RvalueReference<'b, crate::VirtualBase1>,
);
pub(crate) fn __rust_thunk___ZN12VirtualBase1aSERKS_<'a, 'b>(
__this: ::core::pin::Pin<&'a mut crate::VirtualBase1>,
__param_0: &'b crate::VirtualBase1,
) -> ::core::pin::Pin<&'a mut crate::VirtualBase1>;
pub(crate) fn __rust_thunk___ZN12VirtualBase1aSEOS_<'a, 'b>(
__this: ::core::pin::Pin<&'a mut crate::VirtualBase1>,
__param_0: ::ctor::RvalueReference<'b, crate::VirtualBase1>,
) -> ::core::pin::Pin<&'a mut crate::VirtualBase1>;
pub fn __crubit_dynamic_upcast__12VirtualBase1__to__5Base1___2f_2fthird_5fparty_2fcrubit_2frs_5fbindings_5ffrom_5fcc_2ftest_2fgolden_3ainheritance_5fcc(
from: *const crate::VirtualBase1,
) -> *const crate::Base1;
pub(crate) fn __rust_thunk___ZN12VirtualBase2C1Ev<'a>(
__this: &'a mut ::core::mem::MaybeUninit<crate::VirtualBase2>,
);
pub(crate) fn __rust_thunk___ZN12VirtualBase2C1ERKS_<'a, 'b>(
__this: &'a mut ::core::mem::MaybeUninit<crate::VirtualBase2>,
__param_0: &'b crate::VirtualBase2,
);
pub(crate) fn __rust_thunk___ZN12VirtualBase2C1EOS_<'a, 'b>(
__this: &'a mut ::core::mem::MaybeUninit<crate::VirtualBase2>,
__param_0: ::ctor::RvalueReference<'b, crate::VirtualBase2>,
);
pub(crate) fn __rust_thunk___ZN12VirtualBase2aSERKS_<'a, 'b>(
__this: ::core::pin::Pin<&'a mut crate::VirtualBase2>,
__param_0: &'b crate::VirtualBase2,
) -> ::core::pin::Pin<&'a mut crate::VirtualBase2>;
pub(crate) fn __rust_thunk___ZN12VirtualBase2aSEOS_<'a, 'b>(
__this: ::core::pin::Pin<&'a mut crate::VirtualBase2>,
__param_0: ::ctor::RvalueReference<'b, crate::VirtualBase2>,
) -> ::core::pin::Pin<&'a mut crate::VirtualBase2>;
pub fn __crubit_dynamic_upcast__12VirtualBase2__to__5Base1___2f_2fthird_5fparty_2fcrubit_2frs_5fbindings_5ffrom_5fcc_2ftest_2fgolden_3ainheritance_5fcc(
from: *const crate::VirtualBase2,
) -> *const crate::Base1;
pub(crate) fn __rust_thunk___ZN14VirtualDerivedC1Ev<'a>(
__this: &'a mut ::core::mem::MaybeUninit<crate::VirtualDerived>,
);
pub(crate) fn __rust_thunk___ZN14VirtualDerivedC1ERKS_<'a, 'b>(
__this: &'a mut ::core::mem::MaybeUninit<crate::VirtualDerived>,
__param_0: &'b crate::VirtualDerived,
);
pub(crate) fn __rust_thunk___ZN14VirtualDerivedC1EOS_<'a, 'b>(
__this: &'a mut ::core::mem::MaybeUninit<crate::VirtualDerived>,
__param_0: ::ctor::RvalueReference<'b, crate::VirtualDerived>,
);
pub(crate) fn __rust_thunk___ZN14VirtualDerivedaSERKS_<'a, 'b>(
__this: ::core::pin::Pin<&'a mut crate::VirtualDerived>,
__param_0: &'b crate::VirtualDerived,
) -> ::core::pin::Pin<&'a mut crate::VirtualDerived>;
pub(crate) fn __rust_thunk___ZN14VirtualDerivedaSEOS_<'a, 'b>(
__this: ::core::pin::Pin<&'a mut crate::VirtualDerived>,
__param_0: ::ctor::RvalueReference<'b, crate::VirtualDerived>,
) -> ::core::pin::Pin<&'a mut crate::VirtualDerived>;
pub fn __crubit_dynamic_upcast__14VirtualDerived__to__12VirtualBase1___2f_2fthird_5fparty_2fcrubit_2frs_5fbindings_5ffrom_5fcc_2ftest_2fgolden_3ainheritance_5fcc(
from: *const crate::VirtualDerived,
) -> *const crate::VirtualBase1;
pub fn __crubit_dynamic_upcast__14VirtualDerived__to__5Base1___2f_2fthird_5fparty_2fcrubit_2frs_5fbindings_5ffrom_5fcc_2ftest_2fgolden_3ainheritance_5fcc(
from: *const crate::VirtualDerived,
) -> *const crate::Base1;
pub fn __crubit_dynamic_upcast__14VirtualDerived__to__12VirtualBase2___2f_2fthird_5fparty_2fcrubit_2frs_5fbindings_5ffrom_5fcc_2ftest_2fgolden_3ainheritance_5fcc(
from: *const crate::VirtualDerived,
) -> *const crate::VirtualBase2;
pub(crate) fn __rust_thunk___ZN15MyAbstractClassaSERKS_<'a, 'b>(
__this: ::core::pin::Pin<&'a mut crate::MyAbstractClass>,
__param_0: &'b crate::MyAbstractClass,
) -> ::core::pin::Pin<&'a mut crate::MyAbstractClass>;
pub(crate) fn __rust_thunk___ZN11MethodBase1C1Ev<'a>(
__this: &'a mut ::core::mem::MaybeUninit<crate::MethodBase1>,
);
pub(crate) fn __rust_thunk___ZN11MethodBase1C1EOS_<'a, 'b>(
__this: &'a mut ::core::mem::MaybeUninit<crate::MethodBase1>,
__param_0: ::ctor::RvalueReference<'b, crate::MethodBase1>,
);
pub(crate) fn __rust_thunk___ZN11MethodBase1aSERKS_<'a, 'b>(
__this: &'a mut crate::MethodBase1,
__param_0: &'b crate::MethodBase1,
) -> &'a mut crate::MethodBase1;
pub(crate) fn __rust_thunk___ZN11MethodBase1aSEOS_<'a, 'b>(
__this: &'a mut crate::MethodBase1,
__param_0: ::ctor::RvalueReference<'b, crate::MethodBase1>,
) -> &'a mut crate::MethodBase1;
#[link_name = "_ZN11MethodBase16PublicEv"]
pub(crate) fn __rust_thunk___ZN11MethodBase16PublicEv<'a>(
__this: &'a mut crate::MethodBase1,
);
#[link_name = "_ZN11MethodBase110Colliding1Ev"]
pub(crate) fn __rust_thunk___ZN11MethodBase110Colliding1Ev<'a>(
__this: &'a mut crate::MethodBase1,
);
#[link_name = "_ZN11MethodBase110Colliding2Ev"]
pub(crate) fn __rust_thunk___ZN11MethodBase110Colliding2Ev<'a>(
__this: &'a mut crate::MethodBase1,
);
pub(crate) fn __rust_thunk___ZN11MethodBase2C1Ev<'a>(
__this: &'a mut ::core::mem::MaybeUninit<crate::MethodBase2>,
);
pub(crate) fn __rust_thunk___ZN11MethodBase2C1EOS_<'a, 'b>(
__this: &'a mut ::core::mem::MaybeUninit<crate::MethodBase2>,
__param_0: ::ctor::RvalueReference<'b, crate::MethodBase2>,
);
pub(crate) fn __rust_thunk___ZN11MethodBase2aSERKS_<'a, 'b>(
__this: &'a mut crate::MethodBase2,
__param_0: &'b crate::MethodBase2,
) -> &'a mut crate::MethodBase2;
pub(crate) fn __rust_thunk___ZN11MethodBase2aSEOS_<'a, 'b>(
__this: &'a mut crate::MethodBase2,
__param_0: ::ctor::RvalueReference<'b, crate::MethodBase2>,
) -> &'a mut crate::MethodBase2;
#[link_name = "_ZN11MethodBase210Colliding1Ev"]
pub(crate) fn __rust_thunk___ZN11MethodBase210Colliding1Ev<'a>(
__this: &'a mut crate::MethodBase2,
);
#[link_name = "_ZN11MethodBase210Colliding2Ev"]
pub(crate) fn __rust_thunk___ZN11MethodBase210Colliding2Ev<'a>(
__this: &'a mut crate::MethodBase2,
);
pub(crate) fn __rust_thunk___ZN13MethodDerivedC1Ev<'a>(
__this: &'a mut ::core::mem::MaybeUninit<crate::MethodDerived>,
);
pub(crate) fn __rust_thunk___ZN13MethodDerivedC1EOS_<'a, 'b>(
__this: &'a mut ::core::mem::MaybeUninit<crate::MethodDerived>,
__param_0: ::ctor::RvalueReference<'b, crate::MethodDerived>,
);
pub(crate) fn __rust_thunk___ZN13MethodDerivedaSERKS_<'a, 'b>(
__this: &'a mut crate::MethodDerived,
__param_0: &'b crate::MethodDerived,
) -> &'a mut crate::MethodDerived;
pub(crate) fn __rust_thunk___ZN13MethodDerivedaSEOS_<'a, 'b>(
__this: &'a mut crate::MethodDerived,
__param_0: ::ctor::RvalueReference<'b, crate::MethodDerived>,
) -> &'a mut crate::MethodDerived;
}
}
const _: () = {
assert!(::core::mem::size_of::<crate::Base0>() == 1);
assert!(::core::mem::align_of::<crate::Base0>() == 1);
static_assertions::assert_impl_all!(crate::Base0: Clone);
static_assertions::assert_impl_all!(crate::Base0: Copy);
static_assertions::assert_not_impl_any!(crate::Base0: Drop);
assert!(::core::mem::size_of::<crate::Base1>() == 16);
assert!(::core::mem::align_of::<crate::Base1>() == 8);
static_assertions::assert_impl_all!(crate::Base1: Clone);
static_assertions::assert_impl_all!(crate::Base1: Copy);
static_assertions::assert_not_impl_any!(crate::Base1: Drop);
assert!(::core::mem::offset_of!(crate::Base1, b1_1_) == 0);
assert!(::core::mem::offset_of!(crate::Base1, b1_2_) == 8);
assert!(::core::mem::size_of::<crate::Base2>() == 2);
assert!(::core::mem::align_of::<crate::Base2>() == 2);
static_assertions::assert_impl_all!(crate::Base2: Clone);
static_assertions::assert_impl_all!(crate::Base2: Copy);
static_assertions::assert_not_impl_any!(crate::Base2: Drop);
assert!(::core::mem::offset_of!(crate::Base2, b2_1_) == 0);
assert!(::core::mem::size_of::<crate::Derived>() == 16);
assert!(::core::mem::align_of::<crate::Derived>() == 8);
static_assertions::assert_impl_all!(crate::Derived: Clone);
static_assertions::assert_impl_all!(crate::Derived: Copy);
static_assertions::assert_not_impl_any!(crate::Derived: Drop);
assert!(::core::mem::offset_of!(crate::Derived, derived_1) == 12);
assert!(::core::mem::size_of::<crate::VirtualBase1>() == 24);
assert!(::core::mem::align_of::<crate::VirtualBase1>() == 8);
static_assertions::assert_not_impl_any!(crate::VirtualBase1: Copy);
static_assertions::assert_not_impl_any!(crate::VirtualBase1: Drop);
assert!(::core::mem::size_of::<crate::VirtualBase2>() == 24);
assert!(::core::mem::align_of::<crate::VirtualBase2>() == 8);
static_assertions::assert_not_impl_any!(crate::VirtualBase2: Copy);
static_assertions::assert_not_impl_any!(crate::VirtualBase2: Drop);
assert!(::core::mem::size_of::<crate::VirtualDerived>() == 32);
assert!(::core::mem::align_of::<crate::VirtualDerived>() == 8);
static_assertions::assert_not_impl_any!(crate::VirtualDerived: Copy);
static_assertions::assert_not_impl_any!(crate::VirtualDerived: Drop);
assert!(::core::mem::size_of::<crate::MyAbstractClass>() == 8);
assert!(::core::mem::align_of::<crate::MyAbstractClass>() == 8);
static_assertions::assert_not_impl_any!(crate::MyAbstractClass: Copy);
static_assertions::assert_not_impl_any!(crate::MyAbstractClass: Drop);
assert!(::core::mem::size_of::<crate::MethodBase1>() == 1);
assert!(::core::mem::align_of::<crate::MethodBase1>() == 1);
static_assertions::assert_impl_all!(crate::MethodBase1: Clone);
static_assertions::assert_impl_all!(crate::MethodBase1: Copy);
static_assertions::assert_not_impl_any!(crate::MethodBase1: Drop);
assert!(::core::mem::size_of::<crate::MethodBase2>() == 1);
assert!(::core::mem::align_of::<crate::MethodBase2>() == 1);
static_assertions::assert_impl_all!(crate::MethodBase2: Clone);
static_assertions::assert_impl_all!(crate::MethodBase2: Copy);
static_assertions::assert_not_impl_any!(crate::MethodBase2: Drop);
assert!(::core::mem::size_of::<crate::MethodDerived>() == 1);
assert!(::core::mem::align_of::<crate::MethodDerived>() == 1);
static_assertions::assert_impl_all!(crate::MethodDerived: Clone);
static_assertions::assert_impl_all!(crate::MethodDerived: Copy);
static_assertions::assert_not_impl_any!(crate::MethodDerived: Drop);
};