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
// Necessary for pretty doc links.
#[allow(unused_imports)]
use crate::{Mood, MoodConfig};
use chrono::ParseError as ChronoError;
use csv::Error as CsvError;
use std::fmt;

/// Errors that can occur while working with this library.
#[derive(Debug)]
pub enum DaylioError {
    /// Failed to parse the `.csv` file.
    CsvError(CsvError),
    /// Failed to parse the time in a row.
    ChronoError(ChronoError),
    /// A [`Mood`] was not found in the provided [`MoodConfig`].
    MoodNotFound,
}

impl std::error::Error for DaylioError {}

impl fmt::Display for DaylioError {
    fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
        use DaylioError::*;
        let message = match self {
            CsvError(e) => format!("CSV parsing error: {}", e),
            ChronoError(e) => format!("Chrono parsing error: {}", e),
            MoodNotFound => "Provided mood not found in config.".into(),
        };

        write!(f, "{}", message)
    }
}

impl From<CsvError> for DaylioError {
    fn from(e: CsvError) -> Self {
        DaylioError::CsvError(e)
    }
}

impl From<ChronoError> for DaylioError {
    fn from(e: ChronoError) -> Self {
        DaylioError::ChronoError(e)
    }
}