#![allow(dead_code)]
extern crate libc;
#[macro_export]
macro_rules! to_va_list {
($func:expr, $($args:expr),*) => {{
#[inline(always)]
unsafe fn should_be_in_unsafe_block() {}
should_be_in_unsafe_block();
unsafe extern "C" fn call_func(f: *mut libc::c_void, ap: $crate::va_list) {
let f: &Box<Fn($crate::va_list) + 'static> = std::mem::transmute(f);
f(ap);
}
let fu = $func;
let wrap = $crate::Wrap {
f: std::mem::transmute(call_func as usize),
c: $crate::convert_closure(fu),
};
$crate::create_va_list(Box::into_raw(Box::new(wrap)), $($args),*);
}};
($func:expr) => {{
#[inline(always)]
unsafe fn should_be_in_unsafe_block() {}
should_be_in_unsafe_block();
unsafe extern "C" fn call_func(f: *mut libc::c_void, ap: $crate::va_list) {
let f: &Box<Fn($crate::va_list) + 'static> = std::mem::transmute(f);
f(ap);
}
let fu = $func;
let wrap = $crate::Wrap {
f: std::mem::transmute(call_func as usize),
c: $crate::convert_closure(fu),
};
$crate::create_va_list(Box::into_raw(Box::new(wrap)));
}}
}
#[repr(C)]
#[doc(hidden)]
pub struct Wrap {
pub f: extern "C" fn(*mut libc::c_void, va_list),
pub c: *mut libc::c_void,
}
extern "C" {
#[allow(improper_ctypes)]
#[doc(hidden)]
pub fn create_va_list(w: *mut Wrap, ...);
}
#[doc(hidden)]
pub fn convert_closure<F: Fn(va_list) + 'static>(f: F) -> *mut libc::c_void {
let f: Box<Box<Fn(va_list) + 'static>> = Box::new(Box::new(f));
Box::into_raw(f) as *mut _
}
#[doc(hidden)]
#[allow(non_camel_case_types)]
pub enum _va_list {}
#[allow(non_camel_case_types)]
pub type va_list = *mut _va_list;