abi_stable/for_examples.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
//! Types used in documentation examples.
use crate::{
library::RootModule,
sabi_types::VersionStrings,
std_types::{ROption, RStr, RString},
StableAbi,
};
/// This type is used in prefix type examples.
#[repr(C)]
#[derive(StableAbi)]
#[sabi(kind(Prefix(prefix_ref = Module_Ref, prefix_fields = Module_Prefix)))]
pub struct Module {
///
pub first: ROption<usize>,
// The `#[sabi(last_prefix_field)]` attribute here means that this is
// the last field in this struct that was defined in the
// first compatible version of the library,
// requiring new fields to always be added after it.
// Moving this attribute is a breaking change, it can only be done in a
// major version bump..
///
#[sabi(last_prefix_field)]
pub second: RStr<'static>,
///
pub third: usize,
}
impl RootModule for Module_Ref {
crate::declare_root_module_statics! {Module_Ref}
const BASE_NAME: &'static str = "example_root_module";
const NAME: &'static str = "example_root_module";
const VERSION_STRINGS: VersionStrings = crate::package_version_strings!();
}
/// This type is used in prefix type examples.
#[repr(C)]
#[derive(StableAbi)]
#[sabi(kind(Prefix(prefix_ref = PhantModule_Ref, prefix_fields = PhantModule_Prefix)))]
pub struct PhantModule<T: Copy> {
///
pub first: ROption<usize>,
///
// The `#[sabi(last_prefix_field)]` attribute here means that this is
// the last field in this struct that was defined in the
// first compatible version of the library,
// requiring new fields to always be added after it.
// Moving this attribute is a breaking change, it can only be done in a
// major version bump..
#[sabi(last_prefix_field)]
pub second: RStr<'static>,
///
pub third: usize,
///
pub phantom: std::marker::PhantomData<T>,
}
/// For demonstrating ffi-safe non-exhaustive enums.
#[repr(u8)]
// #[derive(Debug,Clone,PartialEq)]
// #[sabi(debug_print)]
#[derive(StableAbi, Debug, Clone, PartialEq, Eq)]
#[sabi(kind(WithNonExhaustive(size = [usize;10], traits(Debug, Clone, PartialEq),)))]
#[sabi(with_constructor)]
#[non_exhaustive]
pub enum ValidTag {
#[allow(missing_docs)]
Foo,
#[allow(missing_docs)]
Bar,
#[allow(missing_docs)]
Tag { name: RString, tag: RString },
}