Skip to content

Commit

Permalink
Merge pull request #1210 from RealKC/bool-error-fmt-variable-expansion
Browse files Browse the repository at this point in the history
glib: Allow variable expansion in format strings passed to bool_error & result_from_gboolean
  • Loading branch information
sdroege authored Oct 21, 2023
2 parents d1fdc2e + d2fc503 commit 90f24bd
Showing 1 changed file with 42 additions and 36 deletions.
78 changes: 42 additions & 36 deletions glib/src/error.rs
Original file line number Diff line number Diff line change
Expand Up @@ -152,49 +152,55 @@ pub trait ErrorDomain: Copy {
/// Generic error used for functions that fail without any further information
#[macro_export]
macro_rules! bool_error(
// Plain strings
($msg:expr) => {{
$crate::BoolError::new(
$msg,
file!(),
$crate::function_name!(),
line!(),
)
}};

// Format strings
($($msg:tt)*) => {{
$crate::BoolError::new(
format!($($msg)*),
file!(),
$crate::function_name!(),
line!(),
)
match ::std::format_args!($($msg)*) {
formatted => {
if let Some(s) = formatted.as_str() {
$crate::BoolError::new(
s,
file!(),
$crate::function_name!(),
line!()
)
} else {
$crate::BoolError::new(
formatted.to_string(),
file!(),
$crate::function_name!(),
line!(),
)
}
}
}
}};
);

#[macro_export]
macro_rules! result_from_gboolean(
// Plain strings
($ffi_bool:expr, $msg:expr) => {{
$crate::BoolError::from_glib(
$ffi_bool,
$msg,
file!(),
$crate::function_name!(),
line!(),
)
}};

// Format strings
($ffi_bool:expr, $($msg:tt)*) => {{
$crate::BoolError::from_glib(
$ffi_bool,
format!($($msg)*),
file!(),
$crate::function_name!(),
line!(),
)
match ::std::format_args!($($msg)*) {
formatted => {
if let Some(s) = formatted.as_str() {
$crate::BoolError::from_glib(
$ffi_bool,
s,
file!(),
$crate::function_name!(),
line!(),
)
} else {
$crate::BoolError::from_glib(
$ffi_bool,
formatted.to_string(),
file!(),
$crate::function_name!(),
line!(),
)
}
}
}


}};
);

Expand Down

0 comments on commit 90f24bd

Please sign in to comment.