mod abi;
mod agile_reference;
mod array;
mod as_impl;
pub(crate) mod bindings;
mod delay_load;
mod error;
mod event;
mod factory_cache;
mod generic_factory;
mod guid;
mod heap;
mod hresult;
mod inspectable;
mod interface;
mod manually_drop;
mod param;
mod ref_count;
mod runtime_name;
mod runtime_type;
mod scoped_interface;
mod sha1;
mod strings;
mod unknown;
mod vtable;
mod waiter;
mod weak;
mod weak_ref_count;
#[doc(hidden)]
pub use abi::*;
pub use agile_reference::*;
pub use array::*;
#[doc(hidden)]
pub use as_impl::*;
pub use delay_load::*;
pub use error::*;
pub use event::*;
pub use factory_cache::*;
#[doc(hidden)]
pub use generic_factory::*;
pub use guid::*;
pub(crate) use heap::*;
pub use hresult::*;
pub use inspectable::*;
pub use interface::*;
pub use manually_drop::*;
pub use param::*;
#[doc(hidden)]
pub use ref_count::*;
#[doc(hidden)]
pub use runtime_name::*;
#[doc(hidden)]
pub use runtime_type::*;
pub use scoped_interface::*;
#[doc(hidden)]
pub use sha1::*;
pub use strings::*;
pub use unknown::*;
pub use vtable::*;
#[doc(hidden)]
pub use waiter::*;
pub use weak::*;
#[doc(hidden)]
pub use weak_ref_count::*;
pub type Result<T> = std::result::Result<T, Error>;
#[doc(hidden)]
pub use bindings::IAgileObject;
#[doc(hidden)]
#[cfg(feature = "implement")]
pub use windows_implement::implement;
#[doc(hidden)]
#[cfg(feature = "implement")]
pub use windows_interface::interface;
#[doc(hidden)]
pub extern crate alloc;
fn wide_trim_end(mut wide: &[u16]) -> &[u16] {
while let Some(last) = wide.last() {
match last {
32 | 9..=13 => wide = &wide[..wide.len() - 1],
_ => break,
}
}
wide
}
#[doc(hidden)]
#[macro_export]
macro_rules! interface_hierarchy {
($child:ty, $parent:ty) => {
impl ::std::convert::From<$child> for $parent {
fn from(value: $child) -> Self {
unsafe { ::std::mem::transmute(value) }
}
}
impl ::std::convert::From<&$child> for &$parent {
fn from(value: &$child) -> Self {
unsafe { ::std::mem::transmute(value) }
}
}
impl ::std::convert::From<&$child> for $parent {
fn from(value: &$child) -> Self {
unsafe { ::std::mem::transmute(::std::clone::Clone::clone(value)) }
}
}
};
($child:ty, $first:ty, $($rest:ty),+) => {
$crate::core::interface_hierarchy!($child, $first);
$crate::core::interface_hierarchy!($child, $($rest),+);
};
}
#[doc(hidden)]
pub use interface_hierarchy;
#[cfg(all(windows_raw_dylib, target_arch = "x86"))]
#[macro_export]
#[doc(hidden)]
macro_rules! link {
($library:literal $abi:literal fn $name:ident($($arg:ident: $argty:ty),*)->$ret:ty) => (
#[link(name = $library, kind = "raw-dylib", modifiers = "+verbatim", import_name_type = "undecorated")]
extern $abi {
pub fn $name($($arg: $argty),*) -> $ret;
}
)
}
#[cfg(all(windows_raw_dylib, not(target_arch = "x86")))]
#[macro_export]
#[doc(hidden)]
macro_rules! link {
($library:literal $abi:literal fn $name:ident($($arg:ident: $argty:ty),*)->$ret:ty) => (
#[link(name = $library, kind = "raw-dylib", modifiers = "+verbatim")]
extern "system" {
pub fn $name($($arg: $argty),*) -> $ret;
}
)
}
#[cfg(not(windows_raw_dylib))]
#[macro_export]
#[doc(hidden)]
macro_rules! link {
($library:literal $abi:literal fn $name:ident($($arg:ident: $argty:ty),*)->$ret:ty) => (
#[link(name = "windows")]
extern $abi {
pub fn $name($($arg: $argty),*) -> $ret;
}
)
}
pub use crate::link;