use crate::sys;
use std::ptr::null_mut;
use std::ffi::{CStr, CString};
#[derive(Debug, Copy, Clone, PartialEq, Eq, Hash)]
pub enum Category {
Application,
Error,
Assert,
System,
Audio,
Video,
Render,
Input,
Test,
Custom,
Unknown,
}
impl Category {
#[allow(dead_code)]
fn from_ll(value: u32) -> Category {
if value == sys::SDL_LOG_CATEGORY_APPLICATION as u32 {
Category::Application
} else if value == sys::SDL_LOG_CATEGORY_ERROR as u32 {
Category::Error
} else if value == sys::SDL_LOG_CATEGORY_ASSERT as u32 {
Category::Assert
} else if value == sys::SDL_LOG_CATEGORY_SYSTEM as u32 {
Category::System
} else if value == sys::SDL_LOG_CATEGORY_AUDIO as u32 {
Category::Audio
} else if value == sys::SDL_LOG_CATEGORY_VIDEO as u32 {
Category::Video
} else if value == sys::SDL_LOG_CATEGORY_RENDER as u32 {
Category::Render
} else if value == sys::SDL_LOG_CATEGORY_INPUT as u32 {
Category::Input
} else if value == sys::SDL_LOG_CATEGORY_TEST as u32 {
Category::Test
} else {
Category::Custom
}
}
}
#[derive(Debug, Copy, Clone, PartialEq, Eq, Hash)]
pub enum Priority {
Verbose,
Debug,
Info,
Warn,
Error,
Critical,
}
impl Priority {
fn from_ll(value: sys::SDL_LogPriority) -> Priority {
use crate::sys::SDL_LogPriority::*;
match value {
SDL_LOG_PRIORITY_VERBOSE => Priority::Verbose,
SDL_LOG_PRIORITY_DEBUG => Priority::Debug,
SDL_LOG_PRIORITY_INFO => Priority::Info,
SDL_LOG_PRIORITY_WARN => Priority::Warn,
SDL_LOG_PRIORITY_ERROR => Priority::Error,
SDL_LOG_PRIORITY_CRITICAL | _ => Priority::Critical,
}
}
}
fn dummy(_priority: Priority, _category: Category, _message: &str) {
}
#[allow(non_upper_case_globals)]
static mut custom_log_fn : fn(Priority, Category, &str) = dummy;
unsafe extern "C" fn rust_sdl2_log_fn(_userdata: *mut libc::c_void,
category: libc::c_int,
priority: sys::SDL_LogPriority,
message: *const libc::c_char) {
let category = Category::from_ll(category as u32);
let priority = Priority::from_ll(priority);
let message = CStr::from_ptr(message).to_string_lossy();
custom_log_fn(priority, category, &*message);
}
pub fn set_output_function(callback : fn(Priority, Category, &str)) {
unsafe {
custom_log_fn = callback;
sys::SDL_LogSetOutputFunction(Some(rust_sdl2_log_fn), null_mut());
};
}
pub fn log(message: &str) {
let message = message.replace('%', "%%");
let message = CString::new(message).unwrap();
unsafe {
crate::sys::SDL_Log(message.into_raw());
}
}