mirror of
https://github.com/google/comprehensive-rust.git
synced 2025-04-05 01:55:31 +02:00
Reverts google/comprehensive-rust#2383 Since #2397 is merged, to align the goal in #2478, rollback this temp workaround.
27 lines
846 B
Markdown
27 lines
846 B
Markdown
---
|
|
minutes: 20
|
|
---
|
|
|
|
# Exercise: Logger Trait
|
|
|
|
Let's design a simple logging utility, using a trait `Logger` with a `log`
|
|
method. Code which might log its progress can then take an `&impl Logger`. In
|
|
testing, this might put messages in the test logfile, while in a production
|
|
build it would send messages to a log server.
|
|
|
|
However, the `StderrLogger` given below logs all messages, regardless of
|
|
verbosity. Your task is to write a `VerbosityFilter` type that will ignore
|
|
messages above a maximum verbosity.
|
|
|
|
This is a common pattern: a struct wrapping a trait implementation and
|
|
implementing that same trait, adding behavior in the process. What other kinds
|
|
of wrappers might be useful in a logging utility?
|
|
|
|
```rust,compile_fail
|
|
{{#include exercise.rs:setup}}
|
|
|
|
// TODO: Define and implement `VerbosityFilter`.
|
|
|
|
{{#include exercise.rs:main}}
|
|
```
|