|
@@ -37,30 +37,30 @@ File_Console_Logger_Data :: struct {
|
|
ident: string,
|
|
ident: string,
|
|
}
|
|
}
|
|
|
|
|
|
-create_file_logger :: proc(h: os.Handle, lowest := Level.Debug, opt := Default_File_Logger_Opts, ident := "") -> Logger {
|
|
|
|
- data := new(File_Console_Logger_Data)
|
|
|
|
|
|
+create_file_logger :: proc(h: os.Handle, lowest := Level.Debug, opt := Default_File_Logger_Opts, ident := "", allocator := context.allocator) -> Logger {
|
|
|
|
+ data := new(File_Console_Logger_Data, allocator)
|
|
data.file_handle = h
|
|
data.file_handle = h
|
|
data.ident = ident
|
|
data.ident = ident
|
|
return Logger{file_console_logger_proc, data, lowest, opt}
|
|
return Logger{file_console_logger_proc, data, lowest, opt}
|
|
}
|
|
}
|
|
|
|
|
|
-destroy_file_logger :: proc(log: Logger) {
|
|
|
|
|
|
+destroy_file_logger :: proc(log: Logger, allocator := context.allocator) {
|
|
data := cast(^File_Console_Logger_Data)log.data
|
|
data := cast(^File_Console_Logger_Data)log.data
|
|
if data.file_handle != os.INVALID_HANDLE {
|
|
if data.file_handle != os.INVALID_HANDLE {
|
|
os.close(data.file_handle)
|
|
os.close(data.file_handle)
|
|
}
|
|
}
|
|
- free(data)
|
|
|
|
|
|
+ free(data, allocator)
|
|
}
|
|
}
|
|
|
|
|
|
-create_console_logger :: proc(lowest := Level.Debug, opt := Default_Console_Logger_Opts, ident := "") -> Logger {
|
|
|
|
- data := new(File_Console_Logger_Data)
|
|
|
|
|
|
+create_console_logger :: proc(lowest := Level.Debug, opt := Default_Console_Logger_Opts, ident := "", allocator := context.allocator) -> Logger {
|
|
|
|
+ data := new(File_Console_Logger_Data, allocator)
|
|
data.file_handle = os.INVALID_HANDLE
|
|
data.file_handle = os.INVALID_HANDLE
|
|
data.ident = ident
|
|
data.ident = ident
|
|
return Logger{file_console_logger_proc, data, lowest, opt}
|
|
return Logger{file_console_logger_proc, data, lowest, opt}
|
|
}
|
|
}
|
|
|
|
|
|
-destroy_console_logger :: proc(log: Logger) {
|
|
|
|
- free(log.data)
|
|
|
|
|
|
+destroy_console_logger :: proc(log: Logger, allocator := context.allocator) {
|
|
|
|
+ free(log.data, allocator)
|
|
}
|
|
}
|
|
|
|
|
|
file_console_logger_proc :: proc(logger_data: rawptr, level: Level, text: string, options: Options, location := #caller_location) {
|
|
file_console_logger_proc :: proc(logger_data: rawptr, level: Level, text: string, options: Options, location := #caller_location) {
|