| 1 | use crate::resolver::ResolverError; |
| 2 | use fluent_syntax::parser::ParserError; |
| 3 | use std::error::Error; |
| 4 | |
| 5 | #[derive (Debug, PartialEq, Eq, Clone)] |
| 6 | pub enum EntryKind { |
| 7 | Message, |
| 8 | Term, |
| 9 | Function, |
| 10 | } |
| 11 | |
| 12 | impl std::fmt::Display for EntryKind { |
| 13 | fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { |
| 14 | match self { |
| 15 | Self::Message => f.write_str(data:"message" ), |
| 16 | Self::Term => f.write_str(data:"term" ), |
| 17 | Self::Function => f.write_str(data:"function" ), |
| 18 | } |
| 19 | } |
| 20 | } |
| 21 | |
| 22 | /// Core error type for Fluent runtime system. |
| 23 | /// |
| 24 | /// It contains three main types of errors that may come up |
| 25 | /// during runtime use of the fluent-bundle crate. |
| 26 | #[derive (Debug, PartialEq, Eq, Clone)] |
| 27 | pub enum FluentError { |
| 28 | /// An error which occurs when |
| 29 | /// [`FluentBundle::add_resource`](crate::bundle::FluentBundle::add_resource) |
| 30 | /// adds entries that are already registered in a given [`FluentBundle`](crate::FluentBundle). |
| 31 | /// |
| 32 | /// # Example |
| 33 | /// |
| 34 | /// ``` |
| 35 | /// use fluent_bundle::{FluentBundle, FluentResource}; |
| 36 | /// use unic_langid::langid; |
| 37 | /// |
| 38 | /// let ftl_string = String::from("intro = Welcome, { $name }." ); |
| 39 | /// let res1 = FluentResource::try_new(ftl_string) |
| 40 | /// .expect("Could not parse an FTL string." ); |
| 41 | /// |
| 42 | /// let ftl_string = String::from("intro = Hi, { $name }." ); |
| 43 | /// let res2 = FluentResource::try_new(ftl_string) |
| 44 | /// .expect("Could not parse an FTL string." ); |
| 45 | /// |
| 46 | /// let langid_en = langid!("en-US" ); |
| 47 | /// let mut bundle = FluentBundle::new(vec![langid_en]); |
| 48 | /// |
| 49 | /// bundle.add_resource(&res1) |
| 50 | /// .expect("Failed to add FTL resources to the bundle." ); |
| 51 | /// |
| 52 | /// assert!(bundle.add_resource(&res2).is_err()); |
| 53 | /// ``` |
| 54 | Overriding { |
| 55 | kind: EntryKind, |
| 56 | id: String, |
| 57 | }, |
| 58 | ParserError(ParserError), |
| 59 | ResolverError(ResolverError), |
| 60 | } |
| 61 | |
| 62 | impl std::fmt::Display for FluentError { |
| 63 | fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { |
| 64 | match self { |
| 65 | Self::Overriding { kind: &EntryKind, id: &String } => { |
| 66 | write!(f, "Attempt to override an existing {}: \"{}\"." , kind, id) |
| 67 | } |
| 68 | Self::ParserError(err: &ParserError) => write!(f, "Parser error: {}" , err), |
| 69 | Self::ResolverError(err: &ResolverError) => write!(f, "Resolver error: {}" , err), |
| 70 | } |
| 71 | } |
| 72 | } |
| 73 | |
| 74 | impl Error for FluentError {} |
| 75 | |
| 76 | impl From<ResolverError> for FluentError { |
| 77 | fn from(error: ResolverError) -> Self { |
| 78 | Self::ResolverError(error) |
| 79 | } |
| 80 | } |
| 81 | |
| 82 | impl From<ParserError> for FluentError { |
| 83 | fn from(error: ParserError) -> Self { |
| 84 | Self::ParserError(error) |
| 85 | } |
| 86 | } |
| 87 | |