Logger-error
Emit an error-level record through the synchronous logger. This is the convenience wrapper for log(Level::Error, ...).
Interface
pub fn[S : Sink] Logger::error(self : Logger[S], message : String, fields~ : Array[Field] = []) -> Unit {}input
self : Logger[S]- Logger that should emit the error record.message : String- Error message text.fields : Array[Field]- Optional structured fields attached to the record.
output
Unit- No return value. The record is handled according to the logger threshold and sink pipeline.
Explanation
Detailed rules explaining key parameters and behaviors
- This helper delegates to
log(Level::Error, ...). Erroris the highest built-in severity in this sync logger API.- This helper does not accept a per-call target override. It uses the logger's stored target unless the logger was derived earlier with
with_target(...)orchild(...). - Sink composition, filtering, patching, and queue wrappers still apply normally.
How to Use
Here are some specific examples provided.
When Report A Failing Operation
When an operation should emit a high-severity failure event:
logger.error("worker execution failed")In this example, the call site clearly communicates failure severity.
When Attach Structured Error Context
When an error event should include diagnostic fields:
logger.error("dispatch failed", fields=[field("job_id", "42")])In this example, the record carries machine-readable context without dropping to the generic log(...) form.
And any shared context already carried by the logger still participates through the sink pipeline.
The write still uses the logger's stored target because this shortcut does not take a one-off target= override.
Error Case
e.g.:
If the logger minimum level is above
Error, the call still returns without writing, though this configuration is unusual.If a target override is required, use
log(...)instead of this severity shortcut.
Notes
Use this helper for high-severity application failures.
Emitting an error record is separate from throwing or handling program exceptions.