abi_stable/type_layout/shared_vars.rs
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 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131
use super::*;
use crate::abi_stability::ConstGeneric;
use std::{
fmt::{self, Debug},
slice,
};
////////////////////////////////////////////////////////////////////////////////
/// A few static slices that many types in the `type_layout` module contain ranges into,
/// requiring this type to be passed as a parameter.
#[repr(C)]
#[derive(StableAbi)]
pub struct SharedVars {
mono: &'static MonoSharedVars,
type_layouts: *const extern "C" fn() -> &'static TypeLayout,
constants: *const ConstGeneric,
type_layouts_len: u16,
constants_len: u16,
}
unsafe impl Sync for SharedVars {}
unsafe impl Send for SharedVars {}
impl SharedVars {
/// Constructs a `SharedVars`.
pub const fn new(
mono: &'static MonoSharedVars,
type_layouts: RSlice<'static, extern "C" fn() -> &'static TypeLayout>,
constants: RSlice<'static, ConstGeneric>,
) -> Self {
Self {
mono,
type_layouts: type_layouts.as_ptr(),
type_layouts_len: type_layouts.len() as u16,
constants: constants.as_ptr(),
constants_len: constants.len() as u16,
}
}
/// A string containing many strings that types in the `type_layout`
/// module store substrings inside of.
#[inline]
pub fn strings(&self) -> &'static str {
self.mono.strings()
}
/// Many lifetimes that types in the `type_layout` module reference.
#[inline]
pub fn lifetime_indices(&self) -> &'static [LifetimeIndexPair] {
self.mono.lifetime_indices()
}
/// Many type layouts that types in the `type_layout`
/// module reference.
///
/// The `StableAbi` derive macro deduplicates identical looking types
/// when constructing SharedVars.
#[inline]
pub fn type_layouts(&self) -> &'static [extern "C" fn() -> &'static TypeLayout] {
unsafe { slice::from_raw_parts(self.type_layouts, self.type_layouts_len as usize) }
}
/// Many constants that types in the `type_layout` module contain ranges into.
#[inline]
pub fn constants(&self) -> &'static [ConstGeneric] {
unsafe { slice::from_raw_parts(self.constants, self.constants_len as usize) }
}
}
impl Debug for SharedVars {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
f.debug_struct("SharedVars").finish()
}
}
/// A few static slices that many types in the `type_layout` module contain ranges into,
/// requiring this type to be passed as a parameter.
#[repr(C)]
#[derive(StableAbi, Copy, Clone)]
pub struct MonoSharedVars {
/// Many strings,separated with ";".
strings: *const u8,
/// Stores the lifetime indices for lifetimes referenced in a type.
///
/// Note that this only stores those indices if the type references more than 3 lifetimes,
/// otherwise it is stored in the range itself.
///
/// Lifetimes indices are stored for these in order:
///
/// - For fields
///
/// - For parameters and return types in function pointers in fields.
///
lifetime_indices: *const LifetimeIndexPair,
strings_len: u16,
lifetime_indices_len: u16,
}
impl MonoSharedVars {
/// Constructs a `MonoSharedVars`.
pub const fn new(
strings: RStr<'static>,
lifetime_indices: RSlice<'static, LifetimeIndexPairRepr>,
) -> Self {
Self {
strings: strings.as_ptr(),
strings_len: strings.len() as u16,
lifetime_indices: lifetime_indices.as_ptr() as *const LifetimeIndexPairRepr
as *const LifetimeIndexPair,
lifetime_indices_len: lifetime_indices.len() as u16,
}
}
/// A string that types in the `type_layout` module store substrings inside of.
#[inline]
pub fn strings(&self) -> &'static str {
unsafe {
let slice = slice::from_raw_parts(self.strings, self.strings_len as usize);
std::str::from_utf8_unchecked(slice)
}
}
/// Many lifetimes that types in the `type_layout` module reference.
#[inline]
pub fn lifetime_indices(&self) -> &'static [LifetimeIndexPair] {
unsafe { slice::from_raw_parts(self.lifetime_indices, self.lifetime_indices_len as usize) }
}
}