mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer-rs.git
synced 2025-01-11 01:35:26 +00:00
gstreamer: Require using a NUL-terminated UTF-8 string or a string literal for the logging ID
Otherwise each log will involve a new allocation just for the ID. Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer-rs/-/merge_requests/1160>
This commit is contained in:
parent
2be477b753
commit
0e7f5a19df
1 changed files with 44 additions and 6 deletions
|
@ -293,7 +293,7 @@ impl DebugCategory {
|
||||||
#[doc(alias = "gst_debug_log_id")]
|
#[doc(alias = "gst_debug_log_id")]
|
||||||
pub fn log_id(
|
pub fn log_id(
|
||||||
self,
|
self,
|
||||||
id: Option<&str>,
|
id: Option<impl AsRef<glib::GStr>>,
|
||||||
level: crate::DebugLevel,
|
level: crate::DebugLevel,
|
||||||
file: &glib::GStr,
|
file: &glib::GStr,
|
||||||
function: &glib::GStr,
|
function: &glib::GStr,
|
||||||
|
@ -327,7 +327,7 @@ impl DebugCategory {
|
||||||
#[doc(alias = "gst_debug_log_id_literal")]
|
#[doc(alias = "gst_debug_log_id_literal")]
|
||||||
pub fn log_id_literal(
|
pub fn log_id_literal(
|
||||||
self,
|
self,
|
||||||
id: Option<&str>,
|
id: Option<impl AsRef<glib::GStr>>,
|
||||||
level: crate::DebugLevel,
|
level: crate::DebugLevel,
|
||||||
file: &glib::GStr,
|
file: &glib::GStr,
|
||||||
function: &glib::GStr,
|
function: &glib::GStr,
|
||||||
|
@ -356,7 +356,7 @@ impl DebugCategory {
|
||||||
#[doc(alias = "gst_debug_log_id")]
|
#[doc(alias = "gst_debug_log_id")]
|
||||||
pub fn log_id_unfiltered(
|
pub fn log_id_unfiltered(
|
||||||
self,
|
self,
|
||||||
id: Option<&str>,
|
id: Option<impl AsRef<glib::GStr>>,
|
||||||
level: crate::DebugLevel,
|
level: crate::DebugLevel,
|
||||||
file: &glib::GStr,
|
file: &glib::GStr,
|
||||||
function: &glib::GStr,
|
function: &glib::GStr,
|
||||||
|
@ -381,7 +381,7 @@ impl DebugCategory {
|
||||||
#[doc(alias = "gst_debug_log_id_literal")]
|
#[doc(alias = "gst_debug_log_id_literal")]
|
||||||
pub fn log_id_literal_unfiltered(
|
pub fn log_id_literal_unfiltered(
|
||||||
self,
|
self,
|
||||||
id: Option<&str>,
|
id: Option<impl AsRef<glib::GStr>>,
|
||||||
level: crate::DebugLevel,
|
level: crate::DebugLevel,
|
||||||
file: &glib::GStr,
|
file: &glib::GStr,
|
||||||
function: &glib::GStr,
|
function: &glib::GStr,
|
||||||
|
@ -393,6 +393,11 @@ impl DebugCategory {
|
||||||
None => return,
|
None => return,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
let id = match id {
|
||||||
|
None => ptr::null(),
|
||||||
|
Some(id) => id.as_ref().as_ptr(),
|
||||||
|
};
|
||||||
|
|
||||||
unsafe {
|
unsafe {
|
||||||
ffi::gst_debug_log_id_literal(
|
ffi::gst_debug_log_id_literal(
|
||||||
cat.as_ptr(),
|
cat.as_ptr(),
|
||||||
|
@ -400,7 +405,7 @@ impl DebugCategory {
|
||||||
file.as_ptr(),
|
file.as_ptr(),
|
||||||
function.as_ptr(),
|
function.as_ptr(),
|
||||||
line as i32,
|
line as i32,
|
||||||
id.to_glib_none().0,
|
id,
|
||||||
msg.as_ptr(),
|
msg.as_ptr(),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -727,6 +732,38 @@ macro_rules! log_with_level(
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
}};
|
}};
|
||||||
|
($cat:expr, level: $level:expr, id: $id:literal, $msg:literal) => { {
|
||||||
|
// Check the log level before using `format_args!` otherwise
|
||||||
|
// formatted arguments are evaluated even if we end up not logging.
|
||||||
|
#[allow(unused_unsafe)]
|
||||||
|
if $level <= $cat.threshold() {
|
||||||
|
$crate::DebugCategory::log_id_literal_unfiltered(
|
||||||
|
$cat.clone(),
|
||||||
|
Some($crate::glib::gstr!($id)),
|
||||||
|
$level,
|
||||||
|
unsafe { $crate::glib::GStr::from_bytes_with_nul_unchecked(concat!(file!(), "\0").as_bytes()) },
|
||||||
|
unsafe { $crate::glib::GStr::from_bytes_with_nul_unchecked(concat!(module_path!(), "\0").as_bytes()) },
|
||||||
|
line!(),
|
||||||
|
$crate::glib::gstr!($msg),
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}};
|
||||||
|
($cat:expr, level: $level:expr, id: $id:literal, $($args:tt)*) => { {
|
||||||
|
// Check the log level before using `format_args!` otherwise
|
||||||
|
// formatted arguments are evaluated even if we end up not logging.
|
||||||
|
#[allow(unused_unsafe)]
|
||||||
|
if $level <= $cat.threshold() {
|
||||||
|
$crate::DebugCategory::log_id_unfiltered(
|
||||||
|
$cat.clone(),
|
||||||
|
Some($crate::glib::gstr!($id)),
|
||||||
|
$level,
|
||||||
|
unsafe { $crate::glib::GStr::from_bytes_with_nul_unchecked(concat!(file!(), "\0").as_bytes()) },
|
||||||
|
unsafe { $crate::glib::GStr::from_bytes_with_nul_unchecked(concat!(module_path!(), "\0").as_bytes()) },
|
||||||
|
line!(),
|
||||||
|
format_args!($($args)*),
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}};
|
||||||
($cat:expr, level: $level:expr, id: $id:expr, $msg:literal) => { {
|
($cat:expr, level: $level:expr, id: $id:expr, $msg:literal) => { {
|
||||||
// Check the log level before using `format_args!` otherwise
|
// Check the log level before using `format_args!` otherwise
|
||||||
// formatted arguments are evaluated even if we end up not logging.
|
// formatted arguments are evaluated even if we end up not logging.
|
||||||
|
@ -1099,6 +1136,7 @@ mod tests {
|
||||||
);
|
);
|
||||||
|
|
||||||
trace!(cat, id: "123", "test");
|
trace!(cat, id: "123", "test");
|
||||||
trace!(cat, id: &String::from("123"), "test");
|
trace!(cat, id: glib::GString::from("123"), "test");
|
||||||
|
trace!(cat, id: &glib::GString::from("123"), "test");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue