libloading 0.8.3

Bindings around the platform's dynamic library loading primitives with greatly improved memory safety.
Documentation
use std::borrow::Cow;
use std::ffi::{CStr, CString};
use std::os::raw;

use crate::Error;

/// Checks for the last byte and avoids allocating if it is zero.
///
/// Non-last null bytes still result in an error.
pub(crate) fn cstr_cow_from_bytes(slice: &[u8]) -> Result<Cow<'_, CStr>, Error> {
    static ZERO: raw::c_char = 0;
    Ok(match slice.last() {
        // Slice out of 0 elements
        None => unsafe { Cow::Borrowed(CStr::from_ptr(&ZERO)) },
        // Slice with trailing 0
        Some(&0) => Cow::Borrowed(
            CStr::from_bytes_with_nul(slice)
                .map_err(|source| Error::CreateCStringWithTrailing { source })?,
        ),
        // Slice with no trailing 0
        Some(_) => {
            Cow::Owned(CString::new(slice).map_err(|source| Error::CreateCString { source })?)
        }
    })
}

#[inline]
pub(crate) fn ensure_compatible_types<T, E>() -> Result<(), Error> {
    if ::std::mem::size_of::<T>() != ::std::mem::size_of::<E>() {
        Err(Error::IncompatibleSize)
    } else {
        Ok(())
    }
}