While working on a Rust application, I became interested in downcasting a Value associated with a log record when using the kv feature of the log crate. To my surprise, I discovered that this capability was removed when the kv feature was stabilized:
|
/// Check whether this value can be downcast to `T`. |
|
#[cfg(feature = "kv_unstable")] |
|
#[deprecated( |
|
note = "downcasting has been removed; log an issue at https://github.com/rust-lang/log/issues if this is something you rely on" |
|
)] |
|
pub fn is<T: 'static>(&self) -> bool { |
|
false |
|
} |
In my view, there are compelling use cases for downcasting log record Values: that enables different software components to process them in a loosely coupled way, effectively repurposing log Records as a versatile, typed message-passing mechanism.
For instance, imagine integrating an existing codebase that logs anyhow::Errors with sentry reporting, with the requirement that generated Sentry events should include the error backtrace. With Value downcasting, this could be achieved by doing this at the logging site:
log::error!(error = anyhow_error; "Something went wrong");
And then, to emit Sentry events from these log records with the error backtrace, one could simply pass a custom mapper function to a SentryLogger that retrieves the error value from the record, downcasts it to an anyhow::Error, calls the backtrace() method on it, and attaches that backtrace to the Sentry event.
Without record Value downcasting, there isn’t an elegant solution for the scenario above. Approaches like using custom serde serializers or establishing an additional communication channel between log sites and logger implementations may work in certain cases, but they are far from ideal.
On a different codebase, but this time proof of concept and open-source, I've also found downcasting useful for passing along typed status update messages that get formatted in the way most appropriate for the target environment by just switching between custom logger implementations.
I've scoured the repository for any issues or commits explaining the rationale for removing Value downcasting but couldn’t find anything beyond a suggestion to file an issue if this is a feature "you rely on". Therefore, I’m opening this issue to understand the context of its removal and to inquire if adding it back is feasible. Are there any drawbacks or implementation constraints I might be overlooking?
Edit: after giving it more thought, the Sentry integration example above perhaps could be solved by using the downcast method available on dyn Error, as anyhow::Errors implement the Error trait... But that's still not helpful for the different codebase example, and not applicable when introspecting Values other than Errors is desired.
Edit 2: nevermind the edit above, anyhow::Error does not implement std::error::Error and thus cannot be downcasted like that.
While working on a Rust application, I became interested in downcasting a
Valueassociated with a log record when using thekvfeature of thelogcrate. To my surprise, I discovered that this capability was removed when thekvfeature was stabilized:log/src/kv/value.rs
Lines 1100 to 1107 in 96dbf58
In my view, there are compelling use cases for downcasting log record
Values: that enables different software components to process them in a loosely coupled way, effectively repurposing logRecords as a versatile, typed message-passing mechanism.For instance, imagine integrating an existing codebase that logs
anyhow::Errors withsentryreporting, with the requirement that generated Sentry events should include the error backtrace. WithValuedowncasting, this could be achieved by doing this at the logging site:And then, to emit Sentry events from these log records with the error backtrace, one could simply pass a custom mapper function to a
SentryLoggerthat retrieves theerrorvalue from the record, downcasts it to ananyhow::Error, calls thebacktrace()method on it, and attaches that backtrace to the Sentry event.Without record
Valuedowncasting, there isn’t an elegant solution for the scenario above. Approaches like using customserdeserializers or establishing an additional communication channel between log sites and logger implementations may work in certain cases, but they are far from ideal.On a different codebase, but this time proof of concept and open-source, I've also found downcasting useful for passing along typed status update messages that get formatted in the way most appropriate for the target environment by just switching between custom logger implementations.
I've scoured the repository for any issues or commits explaining the rationale for removing
Valuedowncasting but couldn’t find anything beyond a suggestion to file an issue if this is a feature "you rely on". Therefore, I’m opening this issue to understand the context of its removal and to inquire if adding it back is feasible. Are there any drawbacks or implementation constraints I might be overlooking?Edit: after giving it more thought, the Sentry integration example above perhaps could be solved by using the
downcastmethod available ondyn Error, asanyhow::Errors implement theErrortrait... But that's still not helpful for the different codebase example, and not applicable when introspectingValues other thanErrors is desired.Edit 2: nevermind the edit above,
anyhow::Errordoes not implementstd::error::Errorand thus cannot be downcasted like that.