1
0
Fork 0
forked from AbleOS/ableos
ableos/sysdata/libraries/stn/src/log.hb

42 lines
1.3 KiB
Plaintext
Raw Normal View History

2024-12-19 11:19:57 -06:00
.{string, fmt, memory} := @use("stn")
2024-07-07 08:35:07 -05:00
2024-12-19 11:19:57 -06:00
LogMsg := packed struct {level: LogLevel, string: ^u8, strlen: uint}
2024-09-17 12:08:19 -05:00
2024-12-19 11:19:57 -06:00
LogLevel := enum {
Error,
Warn,
Info,
Debug,
Trace,
}
2024-12-22 13:48:12 -06:00
$log := fn(level: LogLevel, message: []u8): void {
return @eca(3, 1, LogMsg.(level, message.ptr, message.len), @sizeof(LogMsg))
2024-07-07 08:35:07 -05:00
}
2024-12-22 13:48:12 -06:00
$error := fn(message: []u8): void return log(LogLevel.Error, message)
$warn := fn(message: []u8): void return log(LogLevel.Warn, message)
$info := fn(message: []u8): void return log(LogLevel.Info, message)
$debug := fn(message: []u8): void return log(LogLevel.Debug, message)
$trace := fn(message: []u8): void return log(LogLevel.Trace, message)
2024-12-19 11:19:57 -06:00
print_buffer := memory.dangling(u8)
print := fn(v: @Any(), opts: fmt.FormatOptions): void {
if print_buffer == memory.dangling(u8) {
print_buffer = memory.request_page(1)
}
2024-12-22 13:48:12 -06:00
len := @inline(fmt.format, v, print_buffer[0..memory.PAGE_SIZE], opts)
2024-12-19 11:19:57 -06:00
@eca(3, 1, LogMsg.(opts.log, print_buffer, len), @sizeof(LogMsg))
2024-12-22 13:48:12 -06:00
memory.set(u8, &0, print_buffer, len)
}
2024-12-22 13:48:12 -06:00
printf := fn(str: []u8, v: @Any(), opts: fmt.FormatOptions): void {
if print_buffer == memory.dangling(u8) {
print_buffer = memory.request_page(1)
}
2024-12-22 13:48:12 -06:00
len := @inline(fmt.format_with_str, v, str, print_buffer[0..memory.PAGE_SIZE], opts)
@eca(3, 1, LogMsg.(opts.log, print_buffer, len), @sizeof(LogMsg))
2024-12-22 13:48:12 -06:00
print(len, .{})
memory.set(u8, &0, print_buffer, len)
2024-12-19 11:19:57 -06:00
}