From 55cb61278782caaffab85aee45f4d0938936a64e Mon Sep 17 00:00:00 2001 From: zach Date: Thu, 24 Oct 2024 10:48:37 -0700 Subject: [PATCH] chore: add trace logging (#48) --- env.go | 14 ++++++++++---- extism_pdk.go | 10 ++++++++-- 2 files changed, 18 insertions(+), 6 deletions(-) diff --git a/env.go b/env.go index 5416b45..528ba20 100644 --- a/env.go +++ b/env.go @@ -126,25 +126,31 @@ func extismHTTPStatusCode() int32 func extismHTTPHeaders() extismPointer // extismLogInfo logs an "info" string to the host from the previously-written UTF-8 string written to `offset`. -// Note that the memory at `offset` can be immediately freed because it is immediately logged. // //go:wasmimport extism:host/env log_info func extismLogInfo(offset extismPointer) // extismLogDebug logs a "debug" string to the host from the previously-written UTF-8 string written to `offset`. -// Note that the memory at `offset` can be immediately freed because it is immediately logged. // //go:wasmimport extism:host/env log_debug func extismLogDebug(offset extismPointer) // extismLogWarn logs a "warning" string to the host from the previously-written UTF-8 string written to `offset`. -// Note that the memory at `offset` can be immediately freed because it is immediately logged. // //go:wasmimport extism:host/env log_warn func extismLogWarn(offset extismPointer) // extismLogError logs an "error" string to the host from the previously-written UTF-8 string written to `offset`. -// Note that the memory at `offset` can be immediately freed because it is immediately logged. // //go:wasmimport extism:host/env log_error func extismLogError(offset extismPointer) + +// extismLogTrace logs an "error" string to the host from the previously-written UTF-8 string written to `offset`. +// +//go:wasmimport extism:host/env log_error +func extismLogTrace(offset extismPointer) + +// extismGetLogLevel returns the configured log level +// +//go:wasmimport extism:host/env get_log_level +func extismGetLogLevel() int32 diff --git a/extism_pdk.go b/extism_pdk.go index 32914ba..0101d05 100644 --- a/extism_pdk.go +++ b/extism_pdk.go @@ -15,11 +15,11 @@ type Memory struct { type LogLevel int const ( - LogInfo LogLevel = iota + LogTrace LogLevel = iota LogDebug + LogInfo LogWarn LogError - LogTrace ) func load(offset extismPointer, buf []byte) { @@ -205,6 +205,10 @@ func GetConfig(key string) (string, bool) { // LogMemory logs the `memory` block on the host using the provided log `level`. func LogMemory(level LogLevel, memory Memory) { + configuredLevel := extismGetLogLevel() + if level < LogLevel(configuredLevel) { + return + } switch level { case LogInfo: extismLogInfo(memory.offset) @@ -214,6 +218,8 @@ func LogMemory(level LogLevel, memory Memory) { extismLogWarn(memory.offset) case LogError: extismLogError(memory.offset) + case LogTrace: + extismLogTrace(memory.offset) } }