Struct rustc_target::abi::call::FnAbi
source · pub struct FnAbi<'a, Ty> {
pub args: Box<[ArgAbi<'a, Ty>]>,
pub ret: ArgAbi<'a, Ty>,
pub c_variadic: bool,
pub fixed_count: u32,
pub conv: Conv,
pub can_unwind: bool,
}
Expand description
Metadata describing how the arguments to a native function should be passed in order to respect the native ABI.
I will do my best to describe this structure, but these comments are reverse-engineered and may be inaccurate. -NDM
Fields§
§args: Box<[ArgAbi<'a, Ty>]>
The LLVM types of each argument.
ret: ArgAbi<'a, Ty>
LLVM return type.
c_variadic: bool
§fixed_count: u32
The count of non-variadic arguments.
Should only be different from args.len() when c_variadic is true. This can be used to know whether an argument is variadic or not.
conv: Conv
§can_unwind: bool
Implementations§
source§impl<'a, Ty> FnAbi<'a, Ty>
impl<'a, Ty> FnAbi<'a, Ty>
pub fn adjust_for_foreign_abi<C>(
&mut self,
cx: &C,
abi: Abi
) -> Result<(), AdjustForForeignAbiError>where
Ty: TyAbiInterface<'a, C> + Copy,
C: HasDataLayout + HasTargetSpec,
Trait Implementations§
source§impl<'a, Ty, __CTX> HashStable<__CTX> for FnAbi<'a, Ty>where
__CTX: HashStableContext,
Ty: HashStable<__CTX>,
impl<'a, Ty, __CTX> HashStable<__CTX> for FnAbi<'a, Ty>where
__CTX: HashStableContext,
Ty: HashStable<__CTX>,
fn hash_stable(&self, __hcx: &mut __CTX, __hasher: &mut StableHasher)
source§impl<'a, Ty: PartialEq> PartialEq<FnAbi<'a, Ty>> for FnAbi<'a, Ty>
impl<'a, Ty: PartialEq> PartialEq<FnAbi<'a, Ty>> for FnAbi<'a, Ty>
impl<'a, Ty: Eq> Eq for FnAbi<'a, Ty>
impl<'a, Ty> StructuralEq for FnAbi<'a, Ty>
impl<'a, Ty> StructuralPartialEq for FnAbi<'a, Ty>
Auto Trait Implementations§
impl<'a, Ty> RefUnwindSafe for FnAbi<'a, Ty>where
Ty: RefUnwindSafe,
impl<'a, Ty> Send for FnAbi<'a, Ty>where
Ty: Send,
impl<'a, Ty> Sync for FnAbi<'a, Ty>where
Ty: Sync,
impl<'a, Ty> Unpin for FnAbi<'a, Ty>where
Ty: Unpin,
impl<'a, Ty> UnwindSafe for FnAbi<'a, Ty>where
Ty: UnwindSafe,
Blanket Implementations§
Layout§
Note: Unable to compute type layout, possibly due to this type having generic parameters. Layout can only be computed for concrete, fully-instantiated types.