#shared #cloned #sent #cached #cloneable #context #serializable

cloneable_errors

A library similar to anyhow, that allows the errors to be cloned, shared, cached and even sent over the network

4 stable releases

1.0.3 Dec 24, 2024

#99 in Caching

Download history 278/week @ 2024-12-24 2/week @ 2025-01-07

280 downloads per month

MIT license

20KB
363 lines

the cloneable_errors crate

this is basically the core functionality of anyhow, but written from scratch, in safe rust.

this library was previously an internal error_handling crate in DeArrow Browser and was licensed together with the entire project under AGPL. it was spun off into it's own public crate and is now licensed under MIT.

why?

anyhow errors are not cloneable - caching them is annoying, especially if you want to add more context later on

this crate aims to be a simpler, hopefully less annoying alternative if you do the things I do

  • errors use Arc<> internally
  • there's a serializable variant that drops a lot of data, but makes it easy to send error info between workers or over the wire

deps

  • no required dependencies
  • serde optionally required for serializing the serializable error variant (enable the serde feature)
  • anyhow optionally required for turning anyhow errors into serializable errors (enable the anyhow feature)

Dependencies

~195KB