wasmer/lib/runtime-core/src/macros.rs

136 lines
3.0 KiB
Rust
Raw Normal View History

#[macro_export]
#[cfg(feature = "debug")]
macro_rules! debug {
2019-04-06 06:47:59 +00:00
($fmt:expr) => (println!(concat!("[{}] wasmer-runtime(:{}) ", $fmt), {
let time = ::std::time::SystemTime::now().duration_since(::std::time::UNIX_EPOCH).expect("Can't get time");
format!("{}.{:03}", time.as_secs(), time.subsec_millis())
}, line!()));
($fmt:expr, $($arg:tt)*) => (println!(concat!("[{}] wasmer-runtime(:{}) ", $fmt, "\n"), {
let time = ::std::time::SystemTime::now().duration_since(::std::time::UNIX_EPOCH).expect("Can't get time");
format!("{}.{:03}", time.as_secs(), time.subsec_millis())
}, line!(), $($arg)*));
}
#[macro_export]
#[cfg(not(feature = "debug"))]
2019-01-08 17:09:47 +00:00
macro_rules! debug {
($fmt:expr) => {};
($fmt:expr, $($arg:tt)*) => {};
}
#[macro_export]
#[cfg(feature = "trace")]
macro_rules! trace {
($fmt:expr) => {
debug!($fmt)
};
($fmt:expr, $($arg:tt)*) => {
debug!($fmt, $($arg)*);
}
}
#[macro_export]
#[cfg(not(feature = "trace"))]
macro_rules! trace {
($fmt:expr) => {};
($fmt:expr, $($arg:tt)*) => {};
2019-01-08 17:09:47 +00:00
}
#[macro_export]
macro_rules! func {
($func:path) => {{
$crate::Func::new($func)
}};
}
2019-01-21 23:10:07 +00:00
/// Generate an [`ImportObject`] safely.
///
/// [`ImportObject`]: struct.ImportObject.html
///
/// # Note:
/// The `import` macro currently only supports
/// importing functions.
///
///
/// # Usage:
/// ```
2019-01-28 18:59:05 +00:00
/// # use wasmer_runtime_core::{imports, func};
/// # use wasmer_runtime_core::vm::Ctx;
/// let import_object = imports! {
/// "env" => {
/// "foo" => func!(foo),
/// },
/// };
///
2019-03-28 18:41:14 +00:00
/// let imports_with_state = imports! {
/// || (0 as _, |_a| {}),
/// "env" => {
/// "foo" => func!(foo),
/// },
/// };
///
/// fn foo(_: &mut Ctx, n: i32) -> i32 {
/// n
/// }
/// ```
2019-01-22 00:24:49 +00:00
#[macro_export]
macro_rules! imports {
( $( $ns_name:expr => $ns:tt, )* ) => {{
use $crate::{
2019-01-22 00:24:49 +00:00
import::{ImportObject, Namespace},
};
let mut import_object = ImportObject::new();
$({
let ns = $crate::__imports_internal!($ns);
import_object.register($ns_name, ns);
})*
2019-03-28 18:41:14 +00:00
import_object
}};
($state_gen:expr, $( $ns_name:expr => $ns:tt, )* ) => {{
use $crate::{
import::{ImportObject, Namespace},
};
let mut import_object = ImportObject::new_with_data($state_gen);
$({
let ns = $crate::__imports_internal!($ns);
import_object.register($ns_name, ns);
})*
2019-01-22 00:24:49 +00:00
import_object
}};
}
#[macro_export]
#[doc(hidden)]
macro_rules! __imports_internal {
( { $( $imp_name:expr => $import_item:expr, )* } ) => {{
2019-01-22 00:24:49 +00:00
let mut ns = Namespace::new();
$(
ns.insert($imp_name, $import_item);
2019-01-22 00:24:49 +00:00
)*
ns
}};
($ns:ident) => {
$ns
};
}
#[macro_export]
#[doc(hidden)]
2019-03-27 03:07:00 +00:00
macro_rules! namespace {
( $( $imp_name:expr => $import_item:expr, )* ) => {{
let mut ns = $crate::import::Namespace::new();
$(
ns.insert($imp_name, $import_item);
)*
ns
}};
}