Files
adler32
aho_corasick
alloc_no_stdlib
alloc_stdlib
ansi_term
assert_matches
atty
backtrace
backtrace_sys
bincode
binjs
binjs_convert_from_json
binjs_decode
binjs_dump
binjs_encode
binjs_es6
binjs_generate_prediction_tables
binjs_generic
binjs_io
binjs_meta
binjs_shared
bitflags
brotli
brotli_decompressor
byteorder
c2_chacha
cfg_if
clap
crc32fast
derive_more
downcast_rs
either
env_logger
failure
flate2
getrandom
humantime
inflector
cases
camelcase
case
classcase
kebabcase
pascalcase
screamingsnakecase
sentencecase
snakecase
tablecase
titlecase
traincase
numbers
deordinalize
ordinalize
suffix
foreignkey
itertools
itoa
lazy_static
libc
log
lzw
memchr
miniz_oxide
nom
ppv_lite86
proc_macro2
quick_error
quote
rand
rand_chacha
rand_core
rand_pcg
range_encoding
regex
regex_syntax
rustc_demangle
ryu
serde
serde_derive
serde_json
smallvec
strsim
syn
termcolor
textwrap
thread_local
unicode_width
unicode_xid
vec_map
weedle
which
xml
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
use Fail;

/// The `AsFail` trait
///
/// This trait is similar to `AsRef<Fail>`, but it is specialized to handle
/// the dynamic object of `Fail`. Implementors of `Fail` have a blanket
/// implementation. It is used in `failure_derive` in order to generate a
/// custom cause.
pub trait AsFail {
    /// Converts a reference to `Self` into a dynamic trait object of `Fail`.
    fn as_fail(&self) -> &dyn Fail;
}

impl<T> AsFail for T
where
    T: Fail,
{
    fn as_fail(&self) -> &dyn Fail {
        self
    }
}

impl AsFail for dyn Fail {
    fn as_fail(&self) -> &dyn Fail {
        self
    }
}

with_std! {
    use error::Error;

    impl AsFail for Error {
        fn as_fail(&self) -> &dyn Fail {
            self.as_fail()
        }
    }
}