1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92
macro_rules! prefixed_extern {
// Functions.
{
$(
$( #[$meta:meta] )*
$vis:vis fn $name:ident ( $( $arg_pat:ident : $arg_ty:ty ),* $(,)? )
$( -> $ret_ty:ty )?;
)+
} => {
extern "C" {
$(
prefixed_item! {
link_name
$name
{
$( #[$meta] )*
$vis fn $name ( $( $arg_pat : $arg_ty ),* ) $( -> $ret_ty )?;
}
}
)+
}
};
// A global variable.
{
$( #[$meta:meta] )*
$vis:vis static mut $name:ident: $typ:ty;
} => {
extern "C" {
prefixed_item! {
link_name
$name
{
$( #[$meta] )*
$vis static mut $name: $typ;
}
}
}
};
}
#[deprecated = "`#[export_name]` creates problems and we will stop doing it."]
#[cfg(not(any(
target_arch = "aarch64",
target_arch = "arm",
target_arch = "x86",
target_arch = "x86_64"
)))]
macro_rules! prefixed_export {
// A function.
{
$( #[$meta:meta] )*
$vis:vis unsafe fn $name:ident ( $( $arg_pat:ident : $arg_ty:ty ),* $(,)? ) $body:block
} => {
prefixed_item! {
export_name
$name
{
$( #[$meta] )*
$vis unsafe fn $name ( $( $arg_pat : $arg_ty ),* ) $body
}
}
};
}
macro_rules! prefixed_item {
// Calculate the prefixed name in a separate layer of macro expansion
// because rustc won't currently accept a non-literal expression as
// the value for `#[link_name = value]`.
{
$attr:ident
$name:ident
{ $( $item:tt )+ }
} => {
prefixed_item! {
$attr
{ concat!(env!("RING_CORE_PREFIX"), stringify!($name)) }
{ $( $item )+ }
}
};
// Output the item.
{
$attr:ident
{ $prefixed_name:expr }
{ $( $item:tt )+ }
} => {
#[$attr = $prefixed_name]
$( $item )+
};
}