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
38
39
40
41
42
43
44
45
46
//! `Error` management module
//!
//! Provides all excel error conversion and description
//! Also provides `Result` as a alias of `Result<_, Error>

#![allow(missing_docs)]

use quick_xml::errors::Error as XmlError;

error_chain! {
    foreign_links {
        Io(::std::io::Error);
        Zip(::zip::result::ZipError);
        Xml(XmlError);
        ParseInt(::std::num::ParseIntError);
        ParseFloat(::std::num::ParseFloatError);
        Utf8(::std::str::Utf8Error);
        FromUtf8(::std::string::FromUtf8Error);
    }

    errors {
        InvalidExtension(ext: String) {
            description("invalid extension")
            display("invalid extension: '{}'", ext)
        }
        CellOutOfRange(try_pos: (u32, u32), min_pos: (u32, u32)) {
            description("no cell found at this position")
            display("there is no cell at position '{:?}'. Minimum position is '{:?}'",
                    try_pos, min_pos)
        }
        WorksheetName(name: String) {
            description("invalid worksheet name")
            display("invalid worksheet name: '{}'", name)
        }
        WorksheetIndex(idx: usize) {
            description("invalid worksheet index")
            display("invalid worksheet index: {}", idx)
        }
    }
}

impl From<(XmlError, usize)> for Error {
    fn from(err: (XmlError, usize)) -> Error {
        err.0.into()
    }
}