Library-logger-error
Emit an error-level record through the library-facing sync logger. This is the convenience wrapper for log(Level::Error, ...) on LibraryLogger[S].
Interface
pub fn[S : Sink] LibraryLogger::error(
self : LibraryLogger[S],
message : String,
fields~ : Array[Field] = [],
) -> Unit {input
self : LibraryLogger[S]- Library-facing 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 current threshold and wrapped sink pipeline.
Explanation
Detailed rules explaining key parameters and behaviors
- This helper delegates to
error(...)on the wrapped logger, which in turn useslog(Level::Error, ...). Erroris the highest built-in severity in this sync facade API.- This helper does not accept a per-call target override. It uses the facade's stored target unless the facade was derived earlier with
with_target(...)orchild(...). - Sink composition, filtering, patching, and queue wrappers still apply normally.
- Broader composition helpers remain on the underlying
Logger[S]and requireto_logger()first.
How to Use
Here are some specific examples provided.
When Report A Failing Library 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 facade still participates through the wrapped logger pipeline.
And the write still uses the facade'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.If callers need broader composition helpers after logging, they must unwrap first with
to_logger().
Notes
Use this helper for high-severity library failures.
Emitting an error record is separate from throwing or handling program exceptions.
Use
log(...)instead when the call site needs a per-call target override or a dynamic level.