Skip to content

Parse-and-build-application-logger

Parse raw JSON config text and build an ApplicationLogger in one step. This facade is the application-oriented counterpart to parse_and_build_logger(...).

Interface

moonbit
pub fn parse_and_build_application_logger(
  input : String,
) -> ApplicationLogger raise ConfigError {

input

  • input : String - Raw JSON logger config text.

output

  • ApplicationLogger - Application-facing configured runtime logger built from parsed config.

Explanation

Detailed rules explaining key parameters and behaviors

  • This API delegates to parse_and_build_logger(...) directly.
  • JSON parsing and config validation happen before the logger is built.
  • The parsed config still goes through the normal configured runtime logger build path, including runtime sink selection, optional queue wrapping, and timestamp application.
  • Because the result is only the ApplicationLogger alias over ConfiguredLogger, this parse-and-build path returns the same underlying configured runtime logger value that parse_and_build_logger(...) would produce directly, without hiding any queue, drain, flush, or file runtime helper methods.
  • That preserved configured runtime helper surface also remains directly exposed on the returned alias rather than being rebuilt or hidden behind an unwrap step.
  • The returned alias also keeps inherited Logger behavior such as with_target(...), child(...), and per-call target= overrides on log(...).
  • That means log(..., target=...) can override the target for one write, while severity helpers such as info(...), warn(...), and error(...) continue to use the stored logger target unless a derived logger was created first with with_target(...) or child(...).
  • Use parse_and_build_library_logger(...) instead when the same parsed configured logger result should be wrapped and narrowed for a library boundary.

How to Use

Here are some specific examples provided.

When Need Direct JSON Bootstrapping For Applications

When config is stored as text and should be built immediately:

moonbit
let logger = parse_and_build_application_logger(
  "{\"min_level\":\"warn\",\"target\":\"app\",\"sink\":{\"kind\":\"console\"}}",
)

In this example, parsing and runtime construction are combined into one facade call.

And any queue/file/runtime helpers selected by the parsed config remain directly available on the returned alias value.

And unlike parse_and_build_library_logger(...), no to_logger() unwrap is required to reach that helper surface.

The returned value also keeps the ordinary logger target semantics because this facade does not wrap or narrow the configured runtime logger result.

When Need A Per-call Target Override After JSON Boot

When parsed app configuration should keep the same direct target override behavior as the ordinary configured logger:

moonbit
let logger = parse_and_build_application_logger(raw) catch {
  err => return
}
logger.log(Level::Error, "boom", target="app.audit")

In this example, the emitted record uses app.audit for that call.

And later info(...), warn(...), or error(...) calls still use the logger's stored target unless code derives another logger first with with_target(...) or child(...).

Error Case

e.g.:

  • If the JSON is malformed, a ConfigError is raised.

  • If the parsed config is invalid, such as an empty file sink path, a ConfigError is raised.

Notes

  1. Use this facade when application code wants a text-to-runtime entry point.

  2. Use build_application_logger(...) when the config is already typed as LoggerConfig.

  3. Use parse_and_build_library_logger(...) instead when text-driven construction should narrow the public sync logger surface for a library boundary.

Published from the repository docs folder with VitePress.