Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Implement conversions between Option<Level> and LevelFilter #644

Closed
wants to merge 1 commit into from

Conversation

joshka
Copy link

@joshka joshka commented Nov 14, 2024

This is nice to have when working with the log crate, as it allows
for more ergonomic conversions between the two types. Specifically, This
allows type bounds that require Into or Into<Option>
to be used. This in turn makes it possible to write more generic code
that can work with tracing and log crates interchangeably.

Specifically, this supports some ideas in
clap-rs/clap-verbosity-flag#121

This is nice to have when working with the `log` crate, as it allows
for more ergonomic conversions between the two types. Specifically, This
allows type bounds that require Into<LevelFilter> or Into<Option<Level>>
to be used. This in turn makes it possible to write more generic code
that can work with tracing and log crates interchangeably.

Specifically, this supports some ideas in
clap-rs/clap-verbosity-flag#121
Copy link
Contributor

@tisonkun tisonkun left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

While From<LevelFilter> for Option<Level> is trivial and straightforward, None to LevelFilter::Off may not. I suppose different system may have different opinion for the "default" level filter.

@tisonkun
Copy link
Contributor

You may write:

opt_level_filter.unwrap_or(LevelFilter::Off).into()

fn from(level: Option<Level>) -> LevelFilter {
match level {
Some(level) => level.to_level_filter(),
None => LevelFilter::Off,
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm sure this is always going to be obvious.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Did you leave out "not" or are you disagreeing with the comment above here and saying that this is actually fine and a reasonable choice to convert Option<Level>::None to LevelFilter::Off?

@joshka
Copy link
Author

joshka commented Nov 14, 2024

While From<LevelFilter> for Option<Level> is trivial and straightforward, None to LevelFilter::Off may not. I suppose different system may have different opinion for the "default" level filter.

Is None indicating a default, or the absence of a level? The benefit of making None -> Off is that it round trips. Perhaps a doc comment about this would be sufficient.

You may write:

opt_level_filter.unwrap_or(LevelFilter::Off).into()

There's no Option<LevelFilter> in this change. Can you clarify what you meant here?

@joshka
Copy link
Author

joshka commented Nov 14, 2024

BTW, I solved the underlying need for this through another means (changed the trait associated type bounds), so I'm unblocked from an implementation perspective for now at least.

@KodrAus
Copy link
Contributor

KodrAus commented Jan 9, 2025

Thanks for the PR @joshka! Since you're unblocked in another way I'll go ahead and close this one. The semantics you've chosen are reasonable, but when they're hidden in standard conversions they'll always trip somebody up so we're best off not introducing them where they're not fully unambiguous.

@KodrAus KodrAus closed this Jan 9, 2025
@joshka
Copy link
Author

joshka commented Jan 10, 2025

No problem - thanks for the feedback. I don't generally use log myself as I prefer the tracing ecosystem, so the implementation here was mainly for completeness and consistency with the same approach in the tracing crate, rather than personal usefulness.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants