@snaggen to Rust • 5 months agoAnnouncing Rust 1.76.0blog.rust-lang.orgexternal-linkmessage-square23arrow-up1104arrow-down10
arrow-up1104arrow-down1external-linkAnnouncing Rust 1.76.0blog.rust-lang.org@snaggen to Rust • 5 months agomessage-square23
minus-square@[email protected]linkfedilinkEnglish17•5 months agoOh, inspect has finally arrived! That will help a ton with debug logging.
minus-squareλλλlink7•edit-25 months agoDo you mind explaining? Maybe with the context of another languages equivalent?
minus-square@[email protected]linkfedilinkEnglish13•5 months agolet bar: Result<T, E> = ...; let foo = bar.inspect(|value| log::debug("{}", value)); is equivalent to let bar: Result<T, E> = ...; let foo = bar.map(|value| { log::debug("{}", value); value });
minus-square@xavlink1•5 months agoWarning: in the first case “value” is actually a shared reference, not a value.
minus-square@[email protected]linkfedilink2•5 months agoLooks vaguely like Stream::peek from Java, I think? There’s an equivalent method in Iterator::inspect.
minus-square@owseilink1•edit-25 months agoit’s just a way to use map with a reference instead of the value, by what I understood. could be usefull for logging values in a Result so you can see it. However I think you can already do that by just mapping and returning the variable.
Oh,
inspect
has finally arrived! That will help a ton with debug logging.Do you mind explaining? Maybe with the context of another languages equivalent?
let bar: Result<T, E> = ...; let foo = bar.inspect(|value| log::debug("{}", value));
is equivalent to
let bar: Result<T, E> = ...; let foo = bar.map(|value| { log::debug("{}", value); value });
Elegant. Thanks!
Warning: in the first case “value” is actually a shared reference, not a value.
Looks vaguely like
Stream::peek
from Java, I think? There’s an equivalent method inIterator::inspect
.it’s just a way to use map with a reference instead of the value, by what I understood.
could be usefull for logging values in a Result so you can see it. However I think you can already do that by just mapping and returning the variable.