Crates.io | nih_log |
lib.rs | nih_log |
version | 0.3.1 |
source | src |
created_at | 2023-03-01 17:53:37.743151 |
updated_at | 2023-04-24 21:56:21.329144 |
description | An opinionated yet flexible logger catering to the needs of the NIH-plug plugin framework |
homepage | |
repository | https://github.com/robbert-vdh/nih-log |
max_upload_size | |
id | 798197 |
size | 44,114 |
A logger for the log crate made specifically to cater to the needs of the NIH-plug plugin framework.
Log messages are formatted similarly to simplelog. Because simplelog is great.
By default the log output goes to STDERR, unless a Windows debugger is
attached. In that case the output is sent to the Windows debugger using the
OutputDebugString()
function. This check is performed at runtime to accommodate debuggers being
attached to already running processes.
The log's output target can be changed by setting the NIH_LOG
environment
variable:
stderr
causes the log to be printed to STDERR.windbg
causes the log to be output to the Windows debugger.The latter two options are useful on Windows where accessing the standard IO streams may be difficult.
If NIH_LOG
is not set, then a dynamic logging output target is used instead.
On Windows this causes log messages to be sent to the Windows debugger when
one is attached. This check is done just before printing the message to make
it possible to attach a debugger to a running process. When the debugger is
not attached the output goes directly to STDERR. On non-Windows platforms
STDERR is always used.
(not yet implemented) The logger's output can be changed to output to a custom function after the logger has been created. This makes it possible to integrate with external logging APIs that are not yet available when the logger is first initialized, like the CLAP plugin API's logging extension.
NIH_LOG
was set explicitly, then this is honored and the regular
behavior won't be overridden.Because NIH-log is opinionated for use with NIH-plug, it only exposes the bare minimum of settings by design. The only configuration options are to control the output target and to filter out log messages based on the crate and module they're sent from.
The logger itself does not try to be realtime-safe. It does however try to be as performant as reasonably possible.
NIH_LOG
environment variable. This is very specific behavior is needed to
use assert_no_alloc
's
log feature as an allocation while writing to the logger (for instance
because the buffers aren't large enough to format all of the logger's text)
should also be logged using the logger, but in that case the log target's
mutex will already be locked.