54 lines
1.5 KiB
C++
54 lines
1.5 KiB
C++
|
/*
|
||
|
* Mr. 4th Dimention - Allen Webster
|
||
|
*
|
||
|
* 14.08.2019
|
||
|
*
|
||
|
* Logging helpers.
|
||
|
*
|
||
|
*/
|
||
|
|
||
|
// TOP
|
||
|
|
||
|
#if !defined(FCODER_LOG_CPP)
|
||
|
#define FCODER_LOG_CPP
|
||
|
|
||
|
internal String_Const_u8
|
||
|
log_event(Arena *arena, String_Const_u8 event_name, String_Const_u8 src_name, i32 line_number, i32 buffer, i32 view, i32 thread_id){
|
||
|
List_String_Const_u8 list = {};
|
||
|
string_list_pushf(arena, &list, "%.*s:%d: %.*s",
|
||
|
string_expand(src_name), line_number, string_expand(event_name));
|
||
|
if (thread_id != 0){
|
||
|
string_list_pushf(arena, &list, " [thread=%d]", thread_id);
|
||
|
}
|
||
|
if (buffer != 0){
|
||
|
string_list_pushf(arena, &list, " [buffer=%d]", buffer);
|
||
|
}
|
||
|
if (view != 0){
|
||
|
string_list_pushf(arena, &list, " [view=%d]", view);
|
||
|
}
|
||
|
string_list_push(arena, &list, string_u8_litexpr("\n"));
|
||
|
return(string_list_flatten(arena, list));
|
||
|
}
|
||
|
|
||
|
#define LogEventStr(log_call, arena, B, V, T, E) \
|
||
|
Stmnt(Temp_Memory temp_LOG = begin_temp(arena); \
|
||
|
String_Const_u8 M = log_event(arena, E, \
|
||
|
string_u8_litexpr(__FILE__), \
|
||
|
__LINE__, (B), (V), (T)); \
|
||
|
log_call; \
|
||
|
end_temp(temp_LOG); )
|
||
|
|
||
|
#define LogEventLit(log_call, arena, B, V, T, Elit) \
|
||
|
LogEventStr(log_call, arena, (B), (V), (T), string_u8_litexpr(Elit))
|
||
|
|
||
|
#define LogEventF(log_call, arena, B, V, T, Ef, ...) \
|
||
|
Stmnt(Temp_Memory temp_LOG_F = begin_temp(arena); \
|
||
|
String_Const_u8 E = push_u8_stringf(arena, Ef, __VA_ARGS__); \
|
||
|
LogEventStr(log_call, arena, B, V, T, E); \
|
||
|
end_temp(temp_LOG_F); )
|
||
|
|
||
|
#endif
|
||
|
|
||
|
// BOTTOM
|
||
|
|