1use std::cmp::Ordering;
2use std::fmt;
3use std::hash::{Hash, Hasher};
4
5#[cfg(feature = "nightly")]
6use rustc_data_structures::stable_hasher::{HashStable, StableHasher, StableOrd};
7#[cfg(feature = "nightly")]
8use rustc_macros::{Decodable, Encodable};
9#[cfg(feature = "nightly")]
10use rustc_span::Symbol;
11
12use crate::AbiFromStrErr;
13
14#[cfg(test)]
15mod tests;
16
17#[derive(#[automatically_derived]
impl ::core::clone::Clone for ExternAbi {
#[inline]
fn clone(&self) -> ExternAbi {
let _: ::core::clone::AssertParamIsClone<bool>;
*self
}
}Clone, #[automatically_derived]
impl ::core::marker::Copy for ExternAbi { }Copy, #[automatically_derived]
impl ::core::fmt::Debug for ExternAbi {
#[inline]
fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
match self {
ExternAbi::C { unwind: __self_0 } =>
::core::fmt::Formatter::debug_struct_field1_finish(f, "C",
"unwind", &__self_0),
ExternAbi::System { unwind: __self_0 } =>
::core::fmt::Formatter::debug_struct_field1_finish(f,
"System", "unwind", &__self_0),
ExternAbi::Rust => ::core::fmt::Formatter::write_str(f, "Rust"),
ExternAbi::RustCall =>
::core::fmt::Formatter::write_str(f, "RustCall"),
ExternAbi::RustCold =>
::core::fmt::Formatter::write_str(f, "RustCold"),
ExternAbi::RustInvalid =>
::core::fmt::Formatter::write_str(f, "RustInvalid"),
ExternAbi::RustPreserveNone =>
::core::fmt::Formatter::write_str(f, "RustPreserveNone"),
ExternAbi::Unadjusted =>
::core::fmt::Formatter::write_str(f, "Unadjusted"),
ExternAbi::Custom =>
::core::fmt::Formatter::write_str(f, "Custom"),
ExternAbi::EfiApi =>
::core::fmt::Formatter::write_str(f, "EfiApi"),
ExternAbi::Aapcs { unwind: __self_0 } =>
::core::fmt::Formatter::debug_struct_field1_finish(f, "Aapcs",
"unwind", &__self_0),
ExternAbi::CmseNonSecureCall =>
::core::fmt::Formatter::write_str(f, "CmseNonSecureCall"),
ExternAbi::CmseNonSecureEntry =>
::core::fmt::Formatter::write_str(f, "CmseNonSecureEntry"),
ExternAbi::GpuKernel =>
::core::fmt::Formatter::write_str(f, "GpuKernel"),
ExternAbi::PtxKernel =>
::core::fmt::Formatter::write_str(f, "PtxKernel"),
ExternAbi::AvrInterrupt =>
::core::fmt::Formatter::write_str(f, "AvrInterrupt"),
ExternAbi::AvrNonBlockingInterrupt =>
::core::fmt::Formatter::write_str(f,
"AvrNonBlockingInterrupt"),
ExternAbi::Msp430Interrupt =>
::core::fmt::Formatter::write_str(f, "Msp430Interrupt"),
ExternAbi::RiscvInterruptM =>
::core::fmt::Formatter::write_str(f, "RiscvInterruptM"),
ExternAbi::RiscvInterruptS =>
::core::fmt::Formatter::write_str(f, "RiscvInterruptS"),
ExternAbi::X86Interrupt =>
::core::fmt::Formatter::write_str(f, "X86Interrupt"),
ExternAbi::Cdecl { unwind: __self_0 } =>
::core::fmt::Formatter::debug_struct_field1_finish(f, "Cdecl",
"unwind", &__self_0),
ExternAbi::Stdcall { unwind: __self_0 } =>
::core::fmt::Formatter::debug_struct_field1_finish(f,
"Stdcall", "unwind", &__self_0),
ExternAbi::Fastcall { unwind: __self_0 } =>
::core::fmt::Formatter::debug_struct_field1_finish(f,
"Fastcall", "unwind", &__self_0),
ExternAbi::Thiscall { unwind: __self_0 } =>
::core::fmt::Formatter::debug_struct_field1_finish(f,
"Thiscall", "unwind", &__self_0),
ExternAbi::Vectorcall { unwind: __self_0 } =>
::core::fmt::Formatter::debug_struct_field1_finish(f,
"Vectorcall", "unwind", &__self_0),
ExternAbi::SysV64 { unwind: __self_0 } =>
::core::fmt::Formatter::debug_struct_field1_finish(f,
"SysV64", "unwind", &__self_0),
ExternAbi::Win64 { unwind: __self_0 } =>
::core::fmt::Formatter::debug_struct_field1_finish(f, "Win64",
"unwind", &__self_0),
}
}
}Debug)]
19#[cfg_attr(feature = "nightly", derive(const _: () =
{
impl<__E: ::rustc_span::SpanEncoder> ::rustc_serialize::Encodable<__E>
for ExternAbi {
fn encode(&self, __encoder: &mut __E) {
let disc =
match *self {
ExternAbi::C { unwind: ref __binding_0 } => { 0usize }
ExternAbi::System { unwind: ref __binding_0 } => { 1usize }
ExternAbi::Rust => { 2usize }
ExternAbi::RustCall => { 3usize }
ExternAbi::RustCold => { 4usize }
ExternAbi::RustInvalid => { 5usize }
ExternAbi::RustPreserveNone => { 6usize }
ExternAbi::Unadjusted => { 7usize }
ExternAbi::Custom => { 8usize }
ExternAbi::EfiApi => { 9usize }
ExternAbi::Aapcs { unwind: ref __binding_0 } => { 10usize }
ExternAbi::CmseNonSecureCall => { 11usize }
ExternAbi::CmseNonSecureEntry => { 12usize }
ExternAbi::GpuKernel => { 13usize }
ExternAbi::PtxKernel => { 14usize }
ExternAbi::AvrInterrupt => { 15usize }
ExternAbi::AvrNonBlockingInterrupt => { 16usize }
ExternAbi::Msp430Interrupt => { 17usize }
ExternAbi::RiscvInterruptM => { 18usize }
ExternAbi::RiscvInterruptS => { 19usize }
ExternAbi::X86Interrupt => { 20usize }
ExternAbi::Cdecl { unwind: ref __binding_0 } => { 21usize }
ExternAbi::Stdcall { unwind: ref __binding_0 } => {
22usize
}
ExternAbi::Fastcall { unwind: ref __binding_0 } => {
23usize
}
ExternAbi::Thiscall { unwind: ref __binding_0 } => {
24usize
}
ExternAbi::Vectorcall { unwind: ref __binding_0 } => {
25usize
}
ExternAbi::SysV64 { unwind: ref __binding_0 } => { 26usize }
ExternAbi::Win64 { unwind: ref __binding_0 } => { 27usize }
};
::rustc_serialize::Encoder::emit_u8(__encoder, disc as u8);
match *self {
ExternAbi::C { unwind: ref __binding_0 } => {
::rustc_serialize::Encodable::<__E>::encode(__binding_0,
__encoder);
}
ExternAbi::System { unwind: ref __binding_0 } => {
::rustc_serialize::Encodable::<__E>::encode(__binding_0,
__encoder);
}
ExternAbi::Rust => {}
ExternAbi::RustCall => {}
ExternAbi::RustCold => {}
ExternAbi::RustInvalid => {}
ExternAbi::RustPreserveNone => {}
ExternAbi::Unadjusted => {}
ExternAbi::Custom => {}
ExternAbi::EfiApi => {}
ExternAbi::Aapcs { unwind: ref __binding_0 } => {
::rustc_serialize::Encodable::<__E>::encode(__binding_0,
__encoder);
}
ExternAbi::CmseNonSecureCall => {}
ExternAbi::CmseNonSecureEntry => {}
ExternAbi::GpuKernel => {}
ExternAbi::PtxKernel => {}
ExternAbi::AvrInterrupt => {}
ExternAbi::AvrNonBlockingInterrupt => {}
ExternAbi::Msp430Interrupt => {}
ExternAbi::RiscvInterruptM => {}
ExternAbi::RiscvInterruptS => {}
ExternAbi::X86Interrupt => {}
ExternAbi::Cdecl { unwind: ref __binding_0 } => {
::rustc_serialize::Encodable::<__E>::encode(__binding_0,
__encoder);
}
ExternAbi::Stdcall { unwind: ref __binding_0 } => {
::rustc_serialize::Encodable::<__E>::encode(__binding_0,
__encoder);
}
ExternAbi::Fastcall { unwind: ref __binding_0 } => {
::rustc_serialize::Encodable::<__E>::encode(__binding_0,
__encoder);
}
ExternAbi::Thiscall { unwind: ref __binding_0 } => {
::rustc_serialize::Encodable::<__E>::encode(__binding_0,
__encoder);
}
ExternAbi::Vectorcall { unwind: ref __binding_0 } => {
::rustc_serialize::Encodable::<__E>::encode(__binding_0,
__encoder);
}
ExternAbi::SysV64 { unwind: ref __binding_0 } => {
::rustc_serialize::Encodable::<__E>::encode(__binding_0,
__encoder);
}
ExternAbi::Win64 { unwind: ref __binding_0 } => {
::rustc_serialize::Encodable::<__E>::encode(__binding_0,
__encoder);
}
}
}
}
};Encodable, const _: () =
{
impl<__D: ::rustc_span::SpanDecoder> ::rustc_serialize::Decodable<__D>
for ExternAbi {
fn decode(__decoder: &mut __D) -> Self {
match ::rustc_serialize::Decoder::read_u8(__decoder) as usize
{
0usize => {
ExternAbi::C {
unwind: ::rustc_serialize::Decodable::decode(__decoder),
}
}
1usize => {
ExternAbi::System {
unwind: ::rustc_serialize::Decodable::decode(__decoder),
}
}
2usize => { ExternAbi::Rust }
3usize => { ExternAbi::RustCall }
4usize => { ExternAbi::RustCold }
5usize => { ExternAbi::RustInvalid }
6usize => { ExternAbi::RustPreserveNone }
7usize => { ExternAbi::Unadjusted }
8usize => { ExternAbi::Custom }
9usize => { ExternAbi::EfiApi }
10usize => {
ExternAbi::Aapcs {
unwind: ::rustc_serialize::Decodable::decode(__decoder),
}
}
11usize => { ExternAbi::CmseNonSecureCall }
12usize => { ExternAbi::CmseNonSecureEntry }
13usize => { ExternAbi::GpuKernel }
14usize => { ExternAbi::PtxKernel }
15usize => { ExternAbi::AvrInterrupt }
16usize => { ExternAbi::AvrNonBlockingInterrupt }
17usize => { ExternAbi::Msp430Interrupt }
18usize => { ExternAbi::RiscvInterruptM }
19usize => { ExternAbi::RiscvInterruptS }
20usize => { ExternAbi::X86Interrupt }
21usize => {
ExternAbi::Cdecl {
unwind: ::rustc_serialize::Decodable::decode(__decoder),
}
}
22usize => {
ExternAbi::Stdcall {
unwind: ::rustc_serialize::Decodable::decode(__decoder),
}
}
23usize => {
ExternAbi::Fastcall {
unwind: ::rustc_serialize::Decodable::decode(__decoder),
}
}
24usize => {
ExternAbi::Thiscall {
unwind: ::rustc_serialize::Decodable::decode(__decoder),
}
}
25usize => {
ExternAbi::Vectorcall {
unwind: ::rustc_serialize::Decodable::decode(__decoder),
}
}
26usize => {
ExternAbi::SysV64 {
unwind: ::rustc_serialize::Decodable::decode(__decoder),
}
}
27usize => {
ExternAbi::Win64 {
unwind: ::rustc_serialize::Decodable::decode(__decoder),
}
}
n => {
::core::panicking::panic_fmt(format_args!("invalid enum variant tag while decoding `ExternAbi`, expected 0..28, actual {0}",
n));
}
}
}
}
};Decodable))]
20pub enum ExternAbi {
21 C {
24 unwind: bool,
25 },
26 System {
28 unwind: bool,
29 },
30
31 Rust,
33 RustCall,
36 RustCold,
40
41 RustInvalid,
44
45 RustPreserveNone,
51
52 Unadjusted,
55
56 Custom,
60
61 EfiApi,
64
65 Aapcs {
68 unwind: bool,
69 },
70 CmseNonSecureCall,
72 CmseNonSecureEntry,
74
75 GpuKernel,
78 PtxKernel,
81
82 AvrInterrupt,
84 AvrNonBlockingInterrupt,
85 Msp430Interrupt,
86 RiscvInterruptM,
87 RiscvInterruptS,
88 X86Interrupt,
89
90 Cdecl {
93 unwind: bool,
94 },
95 Stdcall {
97 unwind: bool,
98 },
99 Fastcall {
101 unwind: bool,
102 },
103 Thiscall {
105 unwind: bool,
106 },
107 Vectorcall {
109 unwind: bool,
110 },
111
112 SysV64 {
114 unwind: bool,
115 },
116 Win64 {
117 unwind: bool,
118 },
119}
120
121macro_rules! abi_impls {
122 ($e_name:ident = {
123 $($variant:ident $({ unwind: $uw:literal })? =><= $tok:literal,)*
124 }) => {
125 impl $e_name {
126 pub const ALL_VARIANTS: &[Self] = &[
127 $($e_name::$variant $({ unwind: $uw })*,)*
128 ];
129 pub const fn as_str(&self) -> &'static str {
130 match self {
131 $($e_name::$variant $( { unwind: $uw } )* => $tok,)*
132 }
133 }
134 const fn internal_const_eq(&self, other: &Self) -> bool {
136 match (self, other) {
137 $( ( $e_name::$variant $( { unwind: $uw } )* , $e_name::$variant $( { unwind: $uw } )* ) => true,)*
138 _ => false,
139 }
140 }
141 pub const fn as_packed(&self) -> u8 {
143 let mut index = 0;
144 while index < $e_name::ALL_VARIANTS.len() {
145 if self.internal_const_eq(&$e_name::ALL_VARIANTS[index]) {
146 return index as u8;
147 }
148 index += 1;
149 }
150 panic!("unreachable: invalid ExternAbi variant");
151 }
152 pub const fn from_packed(index: u8) -> Self {
153 let index = index as usize;
154 assert!(index < $e_name::ALL_VARIANTS.len(), "invalid ExternAbi index");
155 $e_name::ALL_VARIANTS[index]
156 }
157 }
158
159 impl ::core::str::FromStr for $e_name {
160 type Err = AbiFromStrErr;
161 fn from_str(s: &str) -> Result<$e_name, Self::Err> {
162 match s {
163 $($tok => Ok($e_name::$variant $({ unwind: $uw })*),)*
164 _ => Err(AbiFromStrErr::Unknown),
165 }
166 }
167 }
168 }
169}
170
171impl ExternAbi {
pub const ALL_VARIANTS: &[Self] =
&[ExternAbi::C { unwind: false }, ExternAbi::C { unwind: true },
ExternAbi::Rust, ExternAbi::Aapcs { unwind: false },
ExternAbi::Aapcs { unwind: true }, ExternAbi::AvrInterrupt,
ExternAbi::AvrNonBlockingInterrupt,
ExternAbi::Cdecl { unwind: false },
ExternAbi::Cdecl { unwind: true },
ExternAbi::CmseNonSecureCall, ExternAbi::CmseNonSecureEntry,
ExternAbi::Custom, ExternAbi::EfiApi,
ExternAbi::Fastcall { unwind: false },
ExternAbi::Fastcall { unwind: true }, ExternAbi::GpuKernel,
ExternAbi::Msp430Interrupt, ExternAbi::PtxKernel,
ExternAbi::RiscvInterruptM, ExternAbi::RiscvInterruptS,
ExternAbi::RustCall, ExternAbi::RustCold,
ExternAbi::RustInvalid, ExternAbi::RustPreserveNone,
ExternAbi::Stdcall { unwind: false },
ExternAbi::Stdcall { unwind: true },
ExternAbi::System { unwind: false },
ExternAbi::System { unwind: true },
ExternAbi::SysV64 { unwind: false },
ExternAbi::SysV64 { unwind: true },
ExternAbi::Thiscall { unwind: false },
ExternAbi::Thiscall { unwind: true }, ExternAbi::Unadjusted,
ExternAbi::Vectorcall { unwind: false },
ExternAbi::Vectorcall { unwind: true },
ExternAbi::Win64 { unwind: false },
ExternAbi::Win64 { unwind: true }, ExternAbi::X86Interrupt];
pub const fn as_str(&self) -> &'static str {
match self {
ExternAbi::C { unwind: false } => "C",
ExternAbi::C { unwind: true } => "C-unwind",
ExternAbi::Rust => "Rust",
ExternAbi::Aapcs { unwind: false } => "aapcs",
ExternAbi::Aapcs { unwind: true } => "aapcs-unwind",
ExternAbi::AvrInterrupt => "avr-interrupt",
ExternAbi::AvrNonBlockingInterrupt =>
"avr-non-blocking-interrupt",
ExternAbi::Cdecl { unwind: false } => "cdecl",
ExternAbi::Cdecl { unwind: true } => "cdecl-unwind",
ExternAbi::CmseNonSecureCall => "cmse-nonsecure-call",
ExternAbi::CmseNonSecureEntry => "cmse-nonsecure-entry",
ExternAbi::Custom => "custom",
ExternAbi::EfiApi => "efiapi",
ExternAbi::Fastcall { unwind: false } => "fastcall",
ExternAbi::Fastcall { unwind: true } => "fastcall-unwind",
ExternAbi::GpuKernel => "gpu-kernel",
ExternAbi::Msp430Interrupt => "msp430-interrupt",
ExternAbi::PtxKernel => "ptx-kernel",
ExternAbi::RiscvInterruptM => "riscv-interrupt-m",
ExternAbi::RiscvInterruptS => "riscv-interrupt-s",
ExternAbi::RustCall => "rust-call",
ExternAbi::RustCold => "rust-cold",
ExternAbi::RustInvalid => "rust-invalid",
ExternAbi::RustPreserveNone => "rust-preserve-none",
ExternAbi::Stdcall { unwind: false } => "stdcall",
ExternAbi::Stdcall { unwind: true } => "stdcall-unwind",
ExternAbi::System { unwind: false } => "system",
ExternAbi::System { unwind: true } => "system-unwind",
ExternAbi::SysV64 { unwind: false } => "sysv64",
ExternAbi::SysV64 { unwind: true } => "sysv64-unwind",
ExternAbi::Thiscall { unwind: false } => "thiscall",
ExternAbi::Thiscall { unwind: true } => "thiscall-unwind",
ExternAbi::Unadjusted => "unadjusted",
ExternAbi::Vectorcall { unwind: false } => "vectorcall",
ExternAbi::Vectorcall { unwind: true } => "vectorcall-unwind",
ExternAbi::Win64 { unwind: false } => "win64",
ExternAbi::Win64 { unwind: true } => "win64-unwind",
ExternAbi::X86Interrupt => "x86-interrupt",
}
}
const fn internal_const_eq(&self, other: &Self) -> bool {
match (self, other) {
(ExternAbi::C { unwind: false }, ExternAbi::C { unwind: false })
=> true,
(ExternAbi::C { unwind: true }, ExternAbi::C { unwind: true }) =>
true,
(ExternAbi::Rust, ExternAbi::Rust) => true,
(ExternAbi::Aapcs { unwind: false }, ExternAbi::Aapcs {
unwind: false }) => true,
(ExternAbi::Aapcs { unwind: true }, ExternAbi::Aapcs {
unwind: true }) => true,
(ExternAbi::AvrInterrupt, ExternAbi::AvrInterrupt) => true,
(ExternAbi::AvrNonBlockingInterrupt,
ExternAbi::AvrNonBlockingInterrupt) => true,
(ExternAbi::Cdecl { unwind: false }, ExternAbi::Cdecl {
unwind: false }) => true,
(ExternAbi::Cdecl { unwind: true }, ExternAbi::Cdecl {
unwind: true }) => true,
(ExternAbi::CmseNonSecureCall, ExternAbi::CmseNonSecureCall) =>
true,
(ExternAbi::CmseNonSecureEntry, ExternAbi::CmseNonSecureEntry) =>
true,
(ExternAbi::Custom, ExternAbi::Custom) => true,
(ExternAbi::EfiApi, ExternAbi::EfiApi) => true,
(ExternAbi::Fastcall { unwind: false }, ExternAbi::Fastcall {
unwind: false }) => true,
(ExternAbi::Fastcall { unwind: true }, ExternAbi::Fastcall {
unwind: true }) => true,
(ExternAbi::GpuKernel, ExternAbi::GpuKernel) => true,
(ExternAbi::Msp430Interrupt, ExternAbi::Msp430Interrupt) => true,
(ExternAbi::PtxKernel, ExternAbi::PtxKernel) => true,
(ExternAbi::RiscvInterruptM, ExternAbi::RiscvInterruptM) => true,
(ExternAbi::RiscvInterruptS, ExternAbi::RiscvInterruptS) => true,
(ExternAbi::RustCall, ExternAbi::RustCall) => true,
(ExternAbi::RustCold, ExternAbi::RustCold) => true,
(ExternAbi::RustInvalid, ExternAbi::RustInvalid) => true,
(ExternAbi::RustPreserveNone, ExternAbi::RustPreserveNone) =>
true,
(ExternAbi::Stdcall { unwind: false }, ExternAbi::Stdcall {
unwind: false }) => true,
(ExternAbi::Stdcall { unwind: true }, ExternAbi::Stdcall {
unwind: true }) => true,
(ExternAbi::System { unwind: false }, ExternAbi::System {
unwind: false }) => true,
(ExternAbi::System { unwind: true }, ExternAbi::System {
unwind: true }) => true,
(ExternAbi::SysV64 { unwind: false }, ExternAbi::SysV64 {
unwind: false }) => true,
(ExternAbi::SysV64 { unwind: true }, ExternAbi::SysV64 {
unwind: true }) => true,
(ExternAbi::Thiscall { unwind: false }, ExternAbi::Thiscall {
unwind: false }) => true,
(ExternAbi::Thiscall { unwind: true }, ExternAbi::Thiscall {
unwind: true }) => true,
(ExternAbi::Unadjusted, ExternAbi::Unadjusted) => true,
(ExternAbi::Vectorcall { unwind: false }, ExternAbi::Vectorcall {
unwind: false }) => true,
(ExternAbi::Vectorcall { unwind: true }, ExternAbi::Vectorcall {
unwind: true }) => true,
(ExternAbi::Win64 { unwind: false }, ExternAbi::Win64 {
unwind: false }) => true,
(ExternAbi::Win64 { unwind: true }, ExternAbi::Win64 {
unwind: true }) => true,
(ExternAbi::X86Interrupt, ExternAbi::X86Interrupt) => true,
_ => false,
}
}
pub const fn as_packed(&self) -> u8 {
let mut index = 0;
while index < ExternAbi::ALL_VARIANTS.len() {
if self.internal_const_eq(&ExternAbi::ALL_VARIANTS[index]) {
return index as u8;
}
index += 1;
}
{
::core::panicking::panic_fmt(format_args!("unreachable: invalid ExternAbi variant"));
};
}
pub const fn from_packed(index: u8) -> Self {
let index = index as usize;
if !(index < ExternAbi::ALL_VARIANTS.len()) {
{
::core::panicking::panic_fmt(format_args!("invalid ExternAbi index"));
}
};
ExternAbi::ALL_VARIANTS[index]
}
}
impl ::core::str::FromStr for ExternAbi {
type Err = AbiFromStrErr;
fn from_str(s: &str) -> Result<ExternAbi, Self::Err> {
match s {
"C" => Ok(ExternAbi::C { unwind: false }),
"C-unwind" => Ok(ExternAbi::C { unwind: true }),
"Rust" => Ok(ExternAbi::Rust),
"aapcs" => Ok(ExternAbi::Aapcs { unwind: false }),
"aapcs-unwind" => Ok(ExternAbi::Aapcs { unwind: true }),
"avr-interrupt" => Ok(ExternAbi::AvrInterrupt),
"avr-non-blocking-interrupt" =>
Ok(ExternAbi::AvrNonBlockingInterrupt),
"cdecl" => Ok(ExternAbi::Cdecl { unwind: false }),
"cdecl-unwind" => Ok(ExternAbi::Cdecl { unwind: true }),
"cmse-nonsecure-call" => Ok(ExternAbi::CmseNonSecureCall),
"cmse-nonsecure-entry" => Ok(ExternAbi::CmseNonSecureEntry),
"custom" => Ok(ExternAbi::Custom),
"efiapi" => Ok(ExternAbi::EfiApi),
"fastcall" => Ok(ExternAbi::Fastcall { unwind: false }),
"fastcall-unwind" => Ok(ExternAbi::Fastcall { unwind: true }),
"gpu-kernel" => Ok(ExternAbi::GpuKernel),
"msp430-interrupt" => Ok(ExternAbi::Msp430Interrupt),
"ptx-kernel" => Ok(ExternAbi::PtxKernel),
"riscv-interrupt-m" => Ok(ExternAbi::RiscvInterruptM),
"riscv-interrupt-s" => Ok(ExternAbi::RiscvInterruptS),
"rust-call" => Ok(ExternAbi::RustCall),
"rust-cold" => Ok(ExternAbi::RustCold),
"rust-invalid" => Ok(ExternAbi::RustInvalid),
"rust-preserve-none" => Ok(ExternAbi::RustPreserveNone),
"stdcall" => Ok(ExternAbi::Stdcall { unwind: false }),
"stdcall-unwind" => Ok(ExternAbi::Stdcall { unwind: true }),
"system" => Ok(ExternAbi::System { unwind: false }),
"system-unwind" => Ok(ExternAbi::System { unwind: true }),
"sysv64" => Ok(ExternAbi::SysV64 { unwind: false }),
"sysv64-unwind" => Ok(ExternAbi::SysV64 { unwind: true }),
"thiscall" => Ok(ExternAbi::Thiscall { unwind: false }),
"thiscall-unwind" => Ok(ExternAbi::Thiscall { unwind: true }),
"unadjusted" => Ok(ExternAbi::Unadjusted),
"vectorcall" => Ok(ExternAbi::Vectorcall { unwind: false }),
"vectorcall-unwind" => Ok(ExternAbi::Vectorcall { unwind: true }),
"win64" => Ok(ExternAbi::Win64 { unwind: false }),
"win64-unwind" => Ok(ExternAbi::Win64 { unwind: true }),
"x86-interrupt" => Ok(ExternAbi::X86Interrupt),
_ => Err(AbiFromStrErr::Unknown),
}
}
}abi_impls! {
172 ExternAbi = {
173 C { unwind: false } =><= "C",
174 C { unwind: true } =><= "C-unwind",
175 Rust =><= "Rust",
176 Aapcs { unwind: false } =><= "aapcs",
177 Aapcs { unwind: true } =><= "aapcs-unwind",
178 AvrInterrupt =><= "avr-interrupt",
179 AvrNonBlockingInterrupt =><= "avr-non-blocking-interrupt",
180 Cdecl { unwind: false } =><= "cdecl",
181 Cdecl { unwind: true } =><= "cdecl-unwind",
182 CmseNonSecureCall =><= "cmse-nonsecure-call",
183 CmseNonSecureEntry =><= "cmse-nonsecure-entry",
184 Custom =><= "custom",
185 EfiApi =><= "efiapi",
186 Fastcall { unwind: false } =><= "fastcall",
187 Fastcall { unwind: true } =><= "fastcall-unwind",
188 GpuKernel =><= "gpu-kernel",
189 Msp430Interrupt =><= "msp430-interrupt",
190 PtxKernel =><= "ptx-kernel",
191 RiscvInterruptM =><= "riscv-interrupt-m",
192 RiscvInterruptS =><= "riscv-interrupt-s",
193 RustCall =><= "rust-call",
194 RustCold =><= "rust-cold",
195 RustInvalid =><= "rust-invalid",
196 RustPreserveNone =><= "rust-preserve-none",
197 Stdcall { unwind: false } =><= "stdcall",
198 Stdcall { unwind: true } =><= "stdcall-unwind",
199 System { unwind: false } =><= "system",
200 System { unwind: true } =><= "system-unwind",
201 SysV64 { unwind: false } =><= "sysv64",
202 SysV64 { unwind: true } =><= "sysv64-unwind",
203 Thiscall { unwind: false } =><= "thiscall",
204 Thiscall { unwind: true } =><= "thiscall-unwind",
205 Unadjusted =><= "unadjusted",
206 Vectorcall { unwind: false } =><= "vectorcall",
207 Vectorcall { unwind: true } =><= "vectorcall-unwind",
208 Win64 { unwind: false } =><= "win64",
209 Win64 { unwind: true } =><= "win64-unwind",
210 X86Interrupt =><= "x86-interrupt",
211 }
212}
213
214impl Ord for ExternAbi {
215 fn cmp(&self, rhs: &Self) -> Ordering {
216 self.as_str().cmp(rhs.as_str())
217 }
218}
219
220impl PartialOrd for ExternAbi {
221 fn partial_cmp(&self, rhs: &Self) -> Option<Ordering> {
222 Some(self.cmp(rhs))
223 }
224}
225
226impl PartialEq for ExternAbi {
227 fn eq(&self, rhs: &Self) -> bool {
228 self.cmp(rhs) == Ordering::Equal
229 }
230}
231
232impl Eq for ExternAbi {}
233
234impl Hash for ExternAbi {
235 fn hash<H: Hasher>(&self, state: &mut H) {
236 self.as_str().hash(state);
237 u32::from_be_bytes(*b"ABI\0").hash(state);
239 }
240}
241
242#[cfg(feature = "nightly")]
243impl<C> HashStable<C> for ExternAbi {
244 #[inline]
245 fn hash_stable(&self, _: &mut C, hasher: &mut StableHasher) {
246 Hash::hash(self, hasher);
247 }
248}
249
250#[cfg(feature = "nightly")]
251impl StableOrd for ExternAbi {
252 const CAN_USE_UNSTABLE_SORT: bool = true;
253
254 const THIS_IMPLEMENTATION_HAS_BEEN_TRIPLE_CHECKED: () = ();
256}
257
258#[cfg(feature = "nightly")]
259impl ::rustc_error_messages::IntoDiagArg for ExternAbi {
fn into_diag_arg(self, path: &mut Option<std::path::PathBuf>)
-> ::rustc_error_messages::DiagArgValue {
self.to_string().into_diag_arg(path)
}
}rustc_error_messages::into_diag_arg_using_display!(ExternAbi);
260
261#[cfg(feature = "nightly")]
262pub enum CVariadicStatus {
263 NotSupported,
264 Stable,
265 Unstable { feature: Symbol },
266}
267
268impl ExternAbi {
269 pub fn is_rustic_abi(self) -> bool {
276 use ExternAbi::*;
277 #[allow(non_exhaustive_omitted_patterns)] match self {
Rust | RustCall | RustCold | RustPreserveNone => true,
_ => false,
}matches!(self, Rust | RustCall | RustCold | RustPreserveNone)
278 }
279
280 #[cfg(feature = "nightly")]
284 pub fn supports_c_variadic(self) -> CVariadicStatus {
285 match self {
297 Self::C { .. }
298 | Self::Cdecl { .. }
299 | Self::Aapcs { .. }
300 | Self::Win64 { .. }
301 | Self::SysV64 { .. }
302 | Self::EfiApi
303 | Self::System { .. } => CVariadicStatus::Stable,
304 _ => CVariadicStatus::NotSupported,
305 }
306 }
307
308 #[cfg(feature = "nightly")]
310 pub fn supports_guaranteed_tail_call(self) -> bool {
311 match self {
312 Self::CmseNonSecureCall | Self::CmseNonSecureEntry => {
313 false
316 }
317 Self::AvrInterrupt
318 | Self::AvrNonBlockingInterrupt
319 | Self::Msp430Interrupt
320 | Self::RiscvInterruptM
321 | Self::RiscvInterruptS
322 | Self::X86Interrupt => {
323 false
325 }
326 Self::GpuKernel | Self::PtxKernel => {
327 false
329 }
330 Self::Custom => {
331 false
333 }
334 Self::C { .. }
335 | Self::System { .. }
336 | Self::Rust
337 | Self::RustCall
338 | Self::RustCold
339 | Self::RustInvalid
340 | Self::Unadjusted
341 | Self::EfiApi
342 | Self::Aapcs { .. }
343 | Self::Cdecl { .. }
344 | Self::Stdcall { .. }
345 | Self::Fastcall { .. }
346 | Self::Thiscall { .. }
347 | Self::Vectorcall { .. }
348 | Self::SysV64 { .. }
349 | Self::Win64 { .. }
350 | Self::RustPreserveNone => true,
351 }
352 }
353}
354
355pub fn all_names() -> Vec<&'static str> {
356 ExternAbi::ALL_VARIANTS.iter().map(|abi| abi.as_str()).collect()
357}
358
359impl ExternAbi {
360 pub const FALLBACK: ExternAbi = ExternAbi::C { unwind: false };
362
363 pub fn name(self) -> &'static str {
364 self.as_str()
365 }
366}
367
368impl fmt::Display for ExternAbi {
369 fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
370 f.write_fmt(format_args!("\"{0}\"", self.as_str()))write!(f, "\"{}\"", self.as_str())
371 }
372}