mirror of
https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs.git
synced 2025-02-01 05:32:23 +00:00
Only format strings, etc in debug log handler if the configured threshold is higher than the level
This commit is contained in:
parent
fb21d62868
commit
c9aad84898
1 changed files with 14 additions and 10 deletions
|
@ -101,15 +101,11 @@ impl Drain for GstDebugDrain {
|
|||
line: u32,
|
||||
object: *const c_void,
|
||||
message: *const c_char);
|
||||
fn gst_debug_category_get_threshold(category: *const c_void) -> u32;
|
||||
fn g_weak_ref_get(weak_ref: &*const c_void) -> *const c_void;
|
||||
fn gst_object_unref(obj: *const c_void);
|
||||
}
|
||||
|
||||
let file_cstr = CString::new(record.file().as_bytes()).unwrap();
|
||||
|
||||
// TODO: Probably want to include module?
|
||||
let function_cstr = CString::new(record.function().as_bytes()).unwrap();
|
||||
|
||||
let message_cstr = CString::new(fmt::format(record.msg()).as_bytes()).unwrap();
|
||||
|
||||
let level = match record.level() {
|
||||
Level::Critical | Level::Error => 1,
|
||||
Level::Warning => 2,
|
||||
|
@ -118,11 +114,19 @@ impl Drain for GstDebugDrain {
|
|||
Level::Trace => 7,
|
||||
};
|
||||
|
||||
extern "C" {
|
||||
fn g_weak_ref_get(weak_ref: &*const c_void) -> *const c_void;
|
||||
fn gst_object_unref(obj: *const c_void);
|
||||
let threshold = unsafe { gst_debug_category_get_threshold(self.category) };
|
||||
|
||||
if level > threshold {
|
||||
return Ok(());
|
||||
}
|
||||
|
||||
let file_cstr = CString::new(record.file().as_bytes()).unwrap();
|
||||
|
||||
// TODO: Probably want to include module?
|
||||
let function_cstr = CString::new(record.function().as_bytes()).unwrap();
|
||||
|
||||
let message_cstr = CString::new(fmt::format(record.msg()).as_bytes()).unwrap();
|
||||
|
||||
unsafe {
|
||||
let element = if self.element.is_null() {
|
||||
ptr::null()
|
||||
|
|
Loading…
Reference in a new issue