#[macro_export]
macro_rules! polo_log (
($($arg:tt)+) => {
if $crate::db::SHOULD_LOG.load(std::sync::atomic::Ordering::SeqCst) {
eprintln!($($arg)*);
}
}
);
#[macro_export]
macro_rules! try_unwrap_document {
($op_name:tt, $doc:expr) => {
match $doc {
Bson::Document(doc) => doc,
t => {
let name = format!("{}", t);
let err = $crate::errors::FieldTypeUnexpectedStruct {
field_name: $op_name.into(),
expected_ty: "Document".into(),
actual_ty: name,
}.into();
return Err(err);
},
}
};
}
#[macro_export]
macro_rules! try_unwrap_array {
($op_name:tt, $arr:expr) => {
match $arr {
Bson::Array(arr) => arr,
t => {
let name = format!("{}", t);
let err = $crate::errors::FieldTypeUnexpectedStruct {
field_name: $op_name.into(),
expected_ty: "Array".into(),
actual_ty: name,
}.into();
return Err(err);
},
}
};
}
#[macro_export]
macro_rules! path_hint {
($self:tt, $key: expr, $content:block) => {
$self.paths.push($key);
$content;
$self.paths.pop();
};
}
#[macro_export]
macro_rules! path_hint_2 {
($paths: expr, $key: expr, $content:block) => {
$paths.push($key);
$content;
$paths.pop();
};
}
#[macro_export]
macro_rules! path_hint_3 {
($paths: expr, $key: expr, $content:block) => {
{
$paths.push($key);
let result = $content;
$paths.pop();
result
}
};
}