From e77d353c526ae638085350b364ee876378f4d5f2 Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Tue, 29 Aug 2017 14:15:05 +0200 Subject: [PATCH 01/32] Rewrite macros to do error-chain behind the scenes --- bin/core/imag-store/src/error.rs | 24 +- lib/core/libimagerror/Cargo.toml | 1 + lib/core/libimagerror/src/error_gen.rs | 344 +++-------------- lib/core/libimagerror/src/lib.rs | 3 + lib/core/libimagrt/src/configuration.rs | 42 ++- lib/core/libimagstore/src/error.rs | 349 +++++++++++++----- lib/domain/libimagbookmark/src/error.rs | 42 ++- lib/domain/libimagcounter/src/error.rs | 42 ++- lib/domain/libimagdiary/src/error.rs | 72 +++- lib/domain/libimagmail/src/error.rs | 34 +- lib/domain/libimagnotes/src/error.rs | 36 +- lib/domain/libimagtimetrack/src/error.rs | 43 ++- lib/domain/libimagtodo/src/error.rs | 42 ++- lib/entry/libimagentryannotation/src/error.rs | 47 ++- lib/entry/libimagentrycategory/src/error.rs | 42 ++- .../src/datepath/error.rs | 29 +- lib/entry/libimagentrydatetime/src/error.rs | 64 +++- lib/entry/libimagentrydatetime/src/range.rs | 29 +- lib/entry/libimagentryedit/src/error.rs | 36 +- lib/entry/libimagentrylink/src/error.rs | 84 ++++- lib/entry/libimagentrylist/src/error.rs | 42 ++- lib/entry/libimagentrymarkdown/src/error.rs | 24 +- lib/entry/libimagentryref/src/error.rs | 146 ++++++-- lib/entry/libimagentrytag/src/error.rs | 36 +- lib/entry/libimagentryview/src/error.rs | 42 ++- lib/etc/libimaginteraction/src/error.rs | 78 +++- 26 files changed, 1152 insertions(+), 621 deletions(-) diff --git a/bin/core/imag-store/src/error.rs b/bin/core/imag-store/src/error.rs index bc248ade..d74e4a30 100644 --- a/bin/core/imag-store/src/error.rs +++ b/bin/core/imag-store/src/error.rs @@ -17,12 +17,24 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -generate_error_module!( - generate_error_types!(StoreError, StoreErrorKind, - BackendError => "Backend Error", - NoCommandlineCall => "No commandline call" - ); -); +error_chain! { + types { + StoreError, StoreErrorKind, ResultExt, Result; + } + + errors { + BackendError { + description("Backend Error") + display("Backend Error") + } + + NoCommandlineCall { + description("No commandline call") + display("No commandline call") + } + + } +} pub use self::error::StoreError; pub use self::error::StoreErrorKind; diff --git a/lib/core/libimagerror/Cargo.toml b/lib/core/libimagerror/Cargo.toml index 5f490746..fbfd1bbb 100644 --- a/lib/core/libimagerror/Cargo.toml +++ b/lib/core/libimagerror/Cargo.toml @@ -16,3 +16,4 @@ homepage = "http://imag-pim.org" [dependencies] log = "0.3" ansi_term = "0.9" +error-chain = "0.10" diff --git a/lib/core/libimagerror/src/error_gen.rs b/lib/core/libimagerror/src/error_gen.rs index eb06692c..a03c998f 100644 --- a/lib/core/libimagerror/src/error_gen.rs +++ b/lib/core/libimagerror/src/error_gen.rs @@ -17,138 +17,55 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -#[macro_export] -macro_rules! generate_error_imports { - () => { - use std::error::Error; - use std::fmt::Error as FmtError; - use std::fmt::{Display, Formatter}; - - use $crate::into::IntoError; - } -} - #[macro_export] macro_rules! generate_error_module { ( $exprs:item ) => { pub mod error { - generate_error_imports!(); $exprs } } } #[macro_export] -macro_rules! generate_custom_error_types { +macro_rules! generate_error_types { { $name: ident, $kindname: ident, - $customMemberTypeName: ident, $($kind:ident => $string:expr),* } => { - #[derive(Clone, Copy, Debug, PartialEq)] - pub enum $kindname { - $( $kind ),* - } - - impl Display for $kindname { - - fn fmt(&self, fmt: &mut Formatter) -> Result<(), FmtError> { - let s = match *self { - $( $kindname::$kind => $string ),* - }; - try!(write!(fmt, "{}", s)); - Ok(()) - } - - } - - impl IntoError for $kindname { - type Target = $name; - - fn into_error(self) -> Self::Target { - $name::new(self, None) - } - - fn into_error_with_cause(self, cause: Box) -> Self::Target { - $name::new(self, Some(cause)) - } - - } - - #[derive(Debug)] - pub struct $name { - err_type: $kindname, - cause: Option>, - custom_data: Option<$customMemberTypeName>, - } - - impl $name { - - pub fn new(errtype: $kindname, cause: Option>) -> $name { - $name { - err_type: errtype, - cause: cause, - custom_data: None, - } - } - - #[allow(dead_code)] - pub fn err_type(&self) -> $kindname { - self.err_type - } - - #[allow(dead_code)] - pub fn with_custom_data(mut self, custom: $customMemberTypeName) -> $name { - self.custom_data = Some(custom); - self - } - - } - - impl Into<$name> for $kindname { - - fn into(self) -> $name { - $name::new(self, None) - } - - } - - impl Display for $name { - - fn fmt(&self, fmt: &mut Formatter) -> Result<(), FmtError> { - try!(write!(fmt, "[{}]", self.err_type)); - match self.custom_data { - Some(ref c) => write!(fmt, "{}", c), - None => Ok(()), - } - } - - } - - impl Error for $name { - - fn description(&self) -> &str { - match self.err_type { - $( $kindname::$kind => $string ),* - } - } - - fn cause(&self) -> Option<&Error> { - self.cause.as_ref().map(|e| &**e) - } - + error_chain! { + types { + $name, $kindname, ResultExt, Result; + } + + links { + // None + } + + foreign_links { + // None + } + + errors { + $( + $kind { + description($string) + display($string) + } + )* + } } + generate_result_helper!($name, $kindname); + generate_option_helper!($name, $kindname); } } #[macro_export] macro_rules! generate_result_helper { - ( - $name: ident, - $kindname: ident - ) => { + { + $name:ident, $kindname:ident + } => { /// Trait to replace /// /// ```ignore @@ -163,15 +80,14 @@ macro_rules! generate_result_helper { /// foo.map_err_into(SomeType::SomeErrorKind) /// ``` /// - pub trait MapErrInto { - fn map_err_into(self, error_kind: $kindname) -> Result; + pub trait MapErrInto { + fn map_err_into(self, error_kind: $kindname) -> ::std::result::Result; } - impl MapErrInto for Result { + impl MapErrInto for Result { - fn map_err_into(self, error_kind: $kindname) -> Result { - self.map_err(Box::new) - .map_err(|e| error_kind.into_error_with_cause(e)) + fn map_err_into(self, error_kind: $kindname) -> ::std::result::Result { + self.chain_err(|| error_kind) } } @@ -180,10 +96,9 @@ macro_rules! generate_result_helper { #[macro_export] macro_rules! generate_option_helper { - ( - $name: ident, - $kindname: ident - ) => { + { + $name:ident, $kindname:ident + } => { /// Trait to replace /// /// ```ignore @@ -196,193 +111,45 @@ macro_rules! generate_option_helper { /// foo.ok_or_errkind(SomeType::SomeErrorKind) /// ``` pub trait OkOrErr { - fn ok_or_errkind(self, kind: $kindname) -> Result; + fn ok_or_errkind(self, kind: $kindname) -> Result; } impl OkOrErr for Option { - fn ok_or_errkind(self, kind: $kindname) -> Result { - self.ok_or(kind.into_error()) + fn ok_or_errkind(self, kind: $kindname) -> Result { + self.ok_or($name::from_kind(kind)) } } } } -#[macro_export] -macro_rules! generate_error_types { - ( - $name: ident, - $kindname: ident, - $($kind:ident => $string:expr),* - ) => { - #[derive(Debug, Clone, Eq, PartialEq, Ord, PartialOrd, Copy)] - pub struct SomeNotExistingTypeWithATypeNameNoOneWillEverChoose {} - - impl Display for SomeNotExistingTypeWithATypeNameNoOneWillEverChoose { - fn fmt(&self, _: &mut Formatter) -> Result<(), FmtError> { - Ok(()) - } - } - - generate_custom_error_types!($name, $kindname, - SomeNotExistingTypeWithATypeNameNoOneWillEverChoose, - $($kind => $string),*); - - generate_result_helper!($name, $kindname); - generate_option_helper!($name, $kindname); - } -} - #[cfg(test)] #[allow(dead_code)] mod test { - generate_error_module!( - generate_error_types!(TestError, TestErrorKind, - TestErrorKindA => "testerrorkind a", - TestErrorKindB => "testerrorkind B"); - ); - - #[derive(Debug, Clone, Eq, PartialEq, Ord, PartialOrd, Copy)] - pub struct CustomData { - pub test: i32, - pub othr: i64, - } - - impl Display for CustomData { - fn fmt(&self, _: &mut Formatter) -> Result<(), FmtError> { - Ok(()) - } - } - - generate_error_imports!(); - - #[allow(dead_code)] - generate_custom_error_types!(CustomTestError, CustomTestErrorKind, - CustomData, - CustomErrorKindA => "customerrorkind a", - CustomErrorKindB => "customerrorkind B"); - - // Allow dead code here. - // We wrote this to show that custom test types can be implemented. - #[allow(dead_code)] - impl CustomTestError { - pub fn test(&self) -> i32 { - match self.custom_data { - Some(t) => t.test, - None => 0, - } - } - - pub fn bar(&self) -> i64 { - match self.custom_data { - Some(t) => t.othr, - None => 0, - } - } - } - - - #[test] - fn test_a() { - use self::error::{TestError, TestErrorKind}; - - let kind = TestErrorKind::TestErrorKindA; - assert_eq!(String::from("testerrorkind a"), format!("{}", kind)); - - let e = TestError::new(kind, None); - assert_eq!(String::from("[testerrorkind a]"), format!("{}", e)); - } - - #[test] - fn test_b() { - use self::error::{TestError, TestErrorKind}; - - let kind = TestErrorKind::TestErrorKindB; - assert_eq!(String::from("testerrorkind B"), format!("{}", kind)); - - let e = TestError::new(kind, None); - assert_eq!(String::from("[testerrorkind B]"), format!("{}", e)); - - } - - #[test] - fn test_ab() { - use std::error::Error; - use self::error::{TestError, TestErrorKind}; - - let kinda = TestErrorKind::TestErrorKindA; - let kindb = TestErrorKind::TestErrorKindB; - assert_eq!(String::from("testerrorkind a"), format!("{}", kinda)); - assert_eq!(String::from("testerrorkind B"), format!("{}", kindb)); - - let e = TestError::new(kinda, Some(Box::new(TestError::new(kindb, None)))); - assert_eq!(String::from("[testerrorkind a]"), format!("{}", e)); - assert_eq!(TestErrorKind::TestErrorKindA, e.err_type()); - assert_eq!(String::from("[testerrorkind B]"), format!("{}", e.cause().unwrap())); - } + generate_error_types!(TestError, TestErrorKind, + TestErrorKindA => "testerrorkind a", + TestErrorKindB => "testerrorkind B"); pub mod anothererrormod { - generate_error_imports!(); generate_error_types!(TestError, TestErrorKind, TestErrorKindA => "testerrorkind a", TestErrorKindB => "testerrorkind B"); } - #[test] - fn test_other_a() { - use self::anothererrormod::{TestError, TestErrorKind}; - - let kind = TestErrorKind::TestErrorKindA; - assert_eq!(String::from("testerrorkind a"), format!("{}", kind)); - - let e = TestError::new(kind, None); - assert_eq!(String::from("[testerrorkind a]"), format!("{}", e)); - } - - #[test] - fn test_other_b() { - use self::anothererrormod::{TestError, TestErrorKind}; - - let kind = TestErrorKind::TestErrorKindB; - assert_eq!(String::from("testerrorkind B"), format!("{}", kind)); - - let e = TestError::new(kind, None); - assert_eq!(String::from("[testerrorkind B]"), format!("{}", e)); - - } - - #[test] - fn test_other_ab() { - use std::error::Error; - use self::anothererrormod::{TestError, TestErrorKind}; - - let kinda = TestErrorKind::TestErrorKindA; - let kindb = TestErrorKind::TestErrorKindB; - assert_eq!(String::from("testerrorkind a"), format!("{}", kinda)); - assert_eq!(String::from("testerrorkind B"), format!("{}", kindb)); - - let e = TestError::new(kinda, Some(Box::new(TestError::new(kindb, None)))); - assert_eq!(String::from("[testerrorkind a]"), format!("{}", e)); - assert_eq!(TestErrorKind::TestErrorKindA, e.err_type()); - assert_eq!(String::from("[testerrorkind B]"), format!("{}", e.cause().unwrap())); - } - #[test] fn test_error_kind_mapping() { - use std::io::{Error, ErrorKind}; - use self::error::MapErrInto; - use self::error::TestErrorKind; + use self::MapErrInto; + use self::TestErrorKind; - let err : Result<(), _> = Err(Error::new(ErrorKind::Other, "")); - let err : Result<(), _> = err.map_err_into(TestErrorKind::TestErrorKindA); + let err : Result<()> = Err(TestError::from_kind(TestErrorKind::TestErrorKindB)); + let err : Result<()> = err.map_err_into(TestErrorKind::TestErrorKindA); assert!(err.is_err()); - let err = err.unwrap_err(); - match err.err_type() { + match *err.unwrap_err().kind() { TestErrorKind::TestErrorKindA => assert!(true), _ => assert!(false), } @@ -390,17 +157,16 @@ mod test { #[test] fn test_error_kind_double_mapping() { - use std::io::{Error, ErrorKind}; - use self::error::MapErrInto; - use self::error::TestErrorKind; + use self::TestErrorKind; + use std::error::Error; - let err : Result<(), _> = Err(Error::new(ErrorKind::Other, "")); - let err : Result<(), _> = err.map_err_into(TestErrorKind::TestErrorKindA) + let err : Result<()> = Err(TestError::from_kind(TestErrorKind::TestErrorKindB)); + let err : Result<()> = err.map_err_into(TestErrorKind::TestErrorKindA) .map_err_into(TestErrorKind::TestErrorKindB); assert!(err.is_err()); let err = err.unwrap_err(); - match err.err_type() { + match *err.kind() { TestErrorKind::TestErrorKindB => assert!(true), _ => assert!(false), } @@ -415,8 +181,8 @@ mod test { #[test] fn test_error_option_good() { - use self::error::OkOrErr; - use self::error::TestErrorKind; + use self::OkOrErr; + use self::TestErrorKind; let something = Some(1); match something.ok_or_errkind(TestErrorKind::TestErrorKindA) { @@ -427,8 +193,8 @@ mod test { #[test] fn test_error_option_bad() { - use self::error::OkOrErr; - use self::error::TestErrorKind; + use self::OkOrErr; + use self::TestErrorKind; let something : Option = None; match something.ok_or_errkind(TestErrorKind::TestErrorKindA) { diff --git a/lib/core/libimagerror/src/lib.rs b/lib/core/libimagerror/src/lib.rs index 0ed1e7f3..f9aa7f98 100644 --- a/lib/core/libimagerror/src/lib.rs +++ b/lib/core/libimagerror/src/lib.rs @@ -36,6 +36,9 @@ #[macro_use] extern crate log; extern crate ansi_term; +#[cfg(test)] +#[macro_use] extern crate error_chain; + pub mod into; pub mod error_gen; pub mod trace; diff --git a/lib/core/libimagrt/src/configuration.rs b/lib/core/libimagrt/src/configuration.rs index bc3b52b4..4e064c02 100644 --- a/lib/core/libimagrt/src/configuration.rs +++ b/lib/core/libimagrt/src/configuration.rs @@ -24,24 +24,42 @@ use std::ops::Deref; use toml::Value; use clap::App; -generate_error_module!( - generate_error_types!(ConfigError, ConfigErrorKind, - TOMLParserError => "TOML Parsing error", - NoConfigFileFound => "No config file found", +error_chain! { + types { + ConfigError, ConfigErrorKind, ResultExt, Result; + } - ConfigOverrideError => "Config override error", - ConfigOverrideKeyNotAvailable => "Key not available", - ConfigOverrideTypeNotMatching => "Configuration Type not matching" + errors { + TOMLParserError { + description("TOML Parsing error") + display("TOML Parsing error") + } - ); -); + NoConfigFileFound { + description("No config file found") + display("No config file found") + } + + ConfigOverrideError { + description("Config override error") + display("Config override error") + } + + ConfigOverrideKeyNotAvailable { + description("Key not available") + display("Key not available") + } + + ConfigOverrideTypeNotMatching { + description("Configuration Type not matching") + display("Configuration Type not matching") + } + } +} pub use self::error::{ConfigError, ConfigErrorKind, MapErrInto}; use libimagerror::into::IntoError; -/// Result type of this module. Either `T` or `ConfigError` -pub type Result = RResult; - /// `Configuration` object /// /// Holds all config variables which are globally available plus the configuration object from the diff --git a/lib/core/libimagstore/src/error.rs b/lib/core/libimagstore/src/error.rs index 00e47681..8bba587f 100644 --- a/lib/core/libimagstore/src/error.rs +++ b/lib/core/libimagstore/src/error.rs @@ -17,99 +17,278 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -generate_error_imports!(); -use std::convert::From; - -#[derive(Debug, Clone, Eq, PartialEq, Ord, PartialOrd, Copy)] -pub struct CustomErrorData {} - -impl Display for CustomErrorData { - fn fmt(&self, _: &mut Formatter) -> Result<(), FmtError> { - Ok(()) // Do nothing here, we don't need to print smth +error_chain! { + types { + StoreError, StoreErrorKind, ResultExt, Result; } -} -generate_custom_error_types!(StoreError, StoreErrorKind, CustomErrorData, - ConfigurationError => "Store Configuration Error", - ConfigTypeError => "Store configuration type error", - ConfigKeyMissingError => "Configuration Key missing", + errors { - VersionError => "Incompatible store versions detected", + ConfigurationError { + description("Store Configuration Error") + display("Store Configuration Error") + } - CreateStoreDirDenied => "Creating store directory implicitely denied", - FileError => "File Error", - IoError => "IO Error", - IdLocked => "ID locked", - IdNotFound => "ID not found", - OutOfMemory => "Out of Memory", - FileNotFound => "File corresponding to ID not found", - FileNotCreated => "File corresponding to ID could not be created", - FileNotWritten => "File corresponding to ID could not be written to", - FileNotSeeked => "File corresponding to ID could not be seeked", - FileNotRemoved => "File corresponding to ID could not be removed", - FileNotRenamed => "File corresponding to ID could not be renamed", - FileNotCopied => "File could not be copied", - DirNotCreated => "Directory/Directories could not be created", - StorePathExists => "Store path exists", - StorePathCreate => "Store path create", - LockError => "Error locking datastructure", - LockPoisoned => "The internal Store Lock has been poisoned", - EntryAlreadyBorrowed => "Entry is already borrowed", - EntryAlreadyExists => "Entry already exists", - MalformedEntry => "Entry has invalid formatting, missing header", - HeaderPathSyntaxError => "Syntax error in accessor string", - HeaderPathTypeFailure => "Header has wrong type for path", - HeaderKeyNotFound => "Header Key not found", - HeaderTypeFailure => "Header type is wrong", - StorePathLacksVersion => "The supplied store path has no version part", - GlobError => "glob() error", - EncodingError => "Encoding error", - StorePathError => "Store Path error", - EntryRenameError => "Entry rename error", - StoreIdHandlingError => "StoreId handling error", - StoreIdLocalPartAbsoluteError => "StoreId 'id' part is absolute (starts with '/') which is not allowed", - StoreIdBuildFromFullPathError => "Building StoreId from full file path failed", - StoreIdHasNoBaseError => "StoreId has no 'base' part", + ConfigTypeError { + description("Store configuration type error") + display("Store configuration type error") + } - CreateCallError => "Error when calling create()", - RetrieveCallError => "Error when calling retrieve()", - GetCallError => "Error when calling get()", - GetAllVersionsCallError => "Error when calling get_all_versions()", - RetrieveForModuleCallError => "Error when calling retrieve_for_module()", - UpdateCallError => "Error when calling update()", - RetrieveCopyCallError => "Error when calling retrieve_copy()", - DeleteCallError => "Error when calling delete()", - MoveCallError => "Error when calling move()", - MoveByIdCallError => "Error when calling move_by_id()" -); + ConfigKeyMissingError { + description("Configuration Key missing") + display("Configuration Key missing") + } -generate_result_helper!(StoreError, StoreErrorKind); -generate_option_helper!(StoreError, StoreErrorKind); + VersionError { + description("Incompatible store versions detected") + display("Incompatible store versions detected") + } -generate_custom_error_types!(ParserError, ParserErrorKind, CustomErrorData, - TOMLParserErrors => "Several TOML-Parser-Errors", - MissingMainSection => "Missing main section", - MissingVersionInfo => "Missing version information in main section", - NonTableInBaseTable => "A non-table was found in the base table", - HeaderInconsistency => "The header is inconsistent" -); + CreateStoreDirDenied { + description("Creating store directory implicitely denied") + display("Creating store directory implicitely denied") + } -impl From for StoreError { - fn from(ps: ParserError) -> StoreError { - StoreError { - err_type: StoreErrorKind::MalformedEntry, - cause: Some(Box::new(ps)), - custom_data: None, - } - } -} - -impl From<::std::io::Error> for StoreError { - fn from(ps: ::std::io::Error) -> StoreError { - StoreError { - err_type: StoreErrorKind::IoError, - cause: Some(Box::new(ps)), - custom_data: None, + FileError { + description("File Error") + display("File Error") + } + + IoError { + description("IO Error") + display("IO Error") + } + + IdLocked { + description("ID locked") + display("ID locked") + } + + IdNotFound { + description("ID not found") + display("ID not found") + } + + OutOfMemory { + description("Out of Memory") + display("Out of Memory") + } + + FileNotFound { + description("File corresponding to ID not found") + display("File corresponding to ID not found") + } + + FileNotCreated { + description("File corresponding to ID could not be created") + display("File corresponding to ID could not be created") + } + + FileNotWritten { + description("File corresponding to ID could not be written to") + display("File corresponding to ID could not be written to") + } + + FileNotSeeked { + description("File corresponding to ID could not be seeked") + display("File corresponding to ID could not be seeked") + } + + FileNotRemoved { + description("File corresponding to ID could not be removed") + display("File corresponding to ID could not be removed") + } + + FileNotRenamed { + description("File corresponding to ID could not be renamed") + display("File corresponding to ID could not be renamed") + } + + FileNotCopied { + description("File could not be copied") + display("File could not be copied") + } + + DirNotCreated { + description("Directory/Directories could not be created") + display("Directory/Directories could not be created") + } + + StorePathExists { + description("Store path exists") + display("Store path exists") + } + + StorePathCreate { + description("Store path create") + display("Store path create") + } + + LockError { + description("Error locking datastructure") + display("Error locking datastructure") + } + + LockPoisoned { + description("The internal Store Lock has been poisoned") + display("The internal Store Lock has been poisoned") + } + + EntryAlreadyBorrowed { + description("Entry is already borrowed") + display("Entry is already borrowed") + } + + EntryAlreadyExists { + description("Entry already exists") + display("Entry already exists") + } + + MalformedEntry { + description("Entry has invalid formatting, missing header") + display("Entry has invalid formatting, missing header") + } + + HeaderPathSyntaxError { + description("Syntax error in accessor string") + display("Syntax error in accessor string") + } + + HeaderPathTypeFailure { + description("Header has wrong type for path") + display("Header has wrong type for path") + } + + HeaderKeyNotFound { + description("Header Key not found") + display("Header Key not found") + } + + HeaderTypeFailure { + description("Header type is wrong") + display("Header type is wrong") + } + + StorePathLacksVersion { + description("The supplied store path has no version part") + display("The supplied store path has no version part") + } + + GlobError { + description("glob() error") + display("glob() error") + } + + EncodingError { + description("Encoding error") + display("Encoding error") + } + + StorePathError { + description("Store Path error") + display("Store Path error") + } + + EntryRenameError { + description("Entry rename error") + display("Entry rename error") + } + + StoreIdHandlingError { + description("StoreId handling error") + display("StoreId handling error") + } + + StoreIdLocalPartAbsoluteError { + description("StoreId 'id' part is absolute (starts with '/') which is not allowed") + display("StoreId 'id' part is absolute (starts with '/') which is not allowed") + } + + StoreIdBuildFromFullPathError { + description("Building StoreId from full file path failed") + display("Building StoreId from full file path failed") + } + + StoreIdHasNoBaseError { + description("StoreId has no 'base' part") + display("StoreId has no 'base' part") + } + + CreateCallError { + description("Error when calling create()") + display("Error when calling create()") + } + + RetrieveCallError { + description("Error when calling retrieve()") + display("Error when calling retrieve()") + } + + GetCallError { + description("Error when calling get()") + display("Error when calling get()") + } + + GetAllVersionsCallError { + description("Error when calling get_all_versions()") + display("Error when calling get_all_versions()") + } + + RetrieveForModuleCallError { + description("Error when calling retrieve_for_module()") + display("Error when calling retrieve_for_module()") + } + + UpdateCallError { + description("Error when calling update()") + display("Error when calling update()") + } + + RetrieveCopyCallError { + description("Error when calling retrieve_copy()") + display("Error when calling retrieve_copy()") + } + + DeleteCallError { + description("Error when calling delete()") + display("Error when calling delete()") + } + + MoveCallError { + description("Error when calling move()") + display("Error when calling move()") + } + + MoveByIdCallError { + description("Error when calling move_by_id()") + display("Error when calling move_by_id()") + } + + // Parser-related errors + + TOMLParserErrors { + description("Several TOML-Parser-Errors") + display("Several TOML-Parser-Errors") + } + + MissingMainSection { + description("Missing main section") + display("Missing main section") + } + + MissingVersionInfo { + description("Missing version information in main section") + display("Missing version information in main section") + } + + NonTableInBaseTable { + description("A non-table was found in the base table") + display("A non-table was found in the base table") + } + + HeaderInconsistency { + description("The header is inconsistent") + display("The header is inconsistent") } } } diff --git a/lib/domain/libimagbookmark/src/error.rs b/lib/domain/libimagbookmark/src/error.rs index 9b52a169..ef01a790 100644 --- a/lib/domain/libimagbookmark/src/error.rs +++ b/lib/domain/libimagbookmark/src/error.rs @@ -17,15 +17,39 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -generate_error_module!( - generate_error_types!(BookmarkError, BookmarkErrorKind, - StoreReadError => "Store read error", - LinkError => "Link error", - LinkParsingError => "Link parsing error", - LinkingError => "Error while linking", - CollectionNotFound => "Link-Collection not found" - ); -); +error_chain! { + types { + BookmarkError, BookmarkErrorKind, ResultExt, Result; + } + + errors { + StoreReadError { + description("Store read error") + display("Store read error") + } + + LinkError { + description("Link error") + display("Link error") + } + + LinkParsingError { + description("Link parsing error") + display("Link parsing error") + } + + LinkingError { + description("Error while linking") + display("Error while linking") + } + + CollectionNotFound { + description("Link-Collection not found") + display("Link-Collection not found") + } + + } +} pub use self::error::BookmarkError; pub use self::error::BookmarkErrorKind; diff --git a/lib/domain/libimagcounter/src/error.rs b/lib/domain/libimagcounter/src/error.rs index c886d901..726eed60 100644 --- a/lib/domain/libimagcounter/src/error.rs +++ b/lib/domain/libimagcounter/src/error.rs @@ -17,15 +17,39 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -generate_error_module!( - generate_error_types!(CounterError, CounterErrorKind, - StoreIdError => "StoreId error", - StoreReadError => "Store read error", - StoreWriteError => "Store write error", - HeaderTypeError => "Header type error", - HeaderFieldMissingError => "Header field missing error" - ); -); +error_chain! { + types { + CounterError, CounterErrorKind, ResultExt, Result; + } + + errors { + StoreIdError { + description("StoreId error") + display("StoreId error") + } + + StoreReadError { + description("Store read error") + display("Store read error") + } + + StoreWriteError { + description("Store write error") + display("Store write error") + } + + HeaderTypeError { + description("Header type error") + display("Header type error") + } + + HeaderFieldMissingError { + description("Header field missing error") + display("Header field missing error") + } + + } +} pub use self::error::CounterError; pub use self::error::CounterErrorKind; diff --git a/lib/domain/libimagdiary/src/error.rs b/lib/domain/libimagdiary/src/error.rs index b5406b12..53b484a7 100644 --- a/lib/domain/libimagdiary/src/error.rs +++ b/lib/domain/libimagdiary/src/error.rs @@ -17,20 +17,64 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -generate_error_module!( - generate_error_types!(DiaryError, DiaryErrorKind, - StoreWriteError => "Error writing store", - StoreReadError => "Error reading store", - CannotFindDiary => "Cannot find diary", - CannotCreateNote => "Cannot create Note object for diary entry", - DiaryEditError => "Cannot edit diary entry", - PathConversionError => "Error while converting paths internally", - EntryNotInDiary => "Entry not in Diary", - IOError => "IO Error", - ViewError => "Error viewing diary entry", - IdParseError => "Error while parsing ID" - ); -); +error_chain! { + types { + DiaryError, DiaryErrorKind, ResultExt, Result; + } + + errors { + StoreWriteError { + description("Error writing store") + display("Error writing store") + } + + StoreReadError { + description("Error reading store") + display("Error reading store") + } + + CannotFindDiary { + description("Cannot find diary") + display("Cannot find diary") + } + + CannotCreateNote { + description("Cannot create Note object for diary entry") + display("Cannot create Note object for diary entry") + } + + DiaryEditError { + description("Cannot edit diary entry") + display("Cannot edit diary entry") + } + + PathConversionError { + description("Error while converting paths internally") + display("Error while converting paths internally") + } + + EntryNotInDiary { + description("Entry not in Diary") + display("Entry not in Diary") + } + + IOError { + description("IO Error") + display("IO Error") + } + + ViewError { + description("Error viewing diary entry") + display("Error viewing diary entry") + } + + IdParseError { + description("Error while parsing ID") + display("Error while parsing ID") + } + + } +} pub use self::error::DiaryError; pub use self::error::DiaryErrorKind; diff --git a/lib/domain/libimagmail/src/error.rs b/lib/domain/libimagmail/src/error.rs index 8c616fba..19a67fd6 100644 --- a/lib/domain/libimagmail/src/error.rs +++ b/lib/domain/libimagmail/src/error.rs @@ -17,17 +17,31 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -generate_error_module!( - generate_error_types!(MailError, MailErrorKind, - RefCreationError => "Error creating a reference to a file/directory", - RefHandlingError => "Error while handling the internal reference object", - MailParsingError => "Error while parsing mail", +error_chain! { + types { + MailError, MailErrorKind, ResultExt, Result; + } - FetchByHashError => "Error fetching mail from Store by hash", - FetchError => "Error fetching mail from Store", - IOError => "IO Error" - ); -); + errors { + RefCreationError { + description("Error creating a reference to a file/directory") + display("Error creating a reference to a file/directory") + } + + FetchByHashError { + description("Error fetching mail from Store by hash") + display("Error fetching mail from Store by hash") + } + FetchError { + description("Error fetching mail from Store") + display("Error fetching mail from Store") + } + IOError { + description("IO Error") + display("IO Error") + } + } +} pub use self::error::MailError; pub use self::error::MailErrorKind; diff --git a/lib/domain/libimagnotes/src/error.rs b/lib/domain/libimagnotes/src/error.rs index 9fd51218..e2793b1c 100644 --- a/lib/domain/libimagnotes/src/error.rs +++ b/lib/domain/libimagnotes/src/error.rs @@ -17,14 +17,34 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -generate_error_module!( - generate_error_types!(NoteError, NoteErrorKind, - StoreWriteError => "Error writing store", - StoreReadError => "Error reading store", - HeaderTypeError => "Header type error", - NoteToEntryConversion => "Error converting Note instance to Entry instance" - ); -); +error_chain! { + types { + NoteError, NoteErrorKind, ResultExt, Result; + } + + errors { + StoreWriteError { + description("Error writing store") + display("Error writing store") + } + + StoreReadError { + description("Error reading store") + display("Error reading store") + } + + HeaderTypeError { + description("Header type error") + display("Header type error") + } + + NoteToEntryConversion { + description("Error converting Note instance to Entry instance") + display("Error converting Note instance to Entry instance") + } + + } +} pub use self::error::NoteError; pub use self::error::NoteErrorKind; diff --git a/lib/domain/libimagtimetrack/src/error.rs b/lib/domain/libimagtimetrack/src/error.rs index 3ac4a11a..429d302a 100644 --- a/lib/domain/libimagtimetrack/src/error.rs +++ b/lib/domain/libimagtimetrack/src/error.rs @@ -17,21 +17,40 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -generate_error_module!( - generate_error_types!(TimeTrackError, TimeTrackErrorKind, - StoreReadError => "Store read error", - StoreWriteError => "Store write error", +error_chain! { + types { + TimeTrackError, TimeTrackErrorKind, ResultExt, Result; + } - StoreIdError => "Error while handling StoreId", + errors { + StoreIdError { + description("Error while handling StoreId") + display("Error while handling StoreId") + } - TagFormat => "Tag has invalid format", + TagFormat { + description("Tag has invalid format") + display("Tag has invalid format") + } - HeaderReadError => "Error writing header", - HeaderWriteError => "Error writing header", - HeaderFieldTypeError => "Type error in header", - DateTimeParserError => "Error while parsing DateTime" - ); -); + HeaderReadError { + description("Error writing header") + display("Error writing header") + } + HeaderWriteError { + description("Error writing header") + display("Error writing header") + } + HeaderFieldTypeError { + description("Type error in header") + display("Type error in header") + } + DateTimeParserError { + description("Error while parsing DateTime") + display("Error while parsing DateTime") + } + } +} pub use self::error::TimeTrackError; pub use self::error::TimeTrackErrorKind; diff --git a/lib/domain/libimagtodo/src/error.rs b/lib/domain/libimagtodo/src/error.rs index 621d3249..84a822b2 100644 --- a/lib/domain/libimagtodo/src/error.rs +++ b/lib/domain/libimagtodo/src/error.rs @@ -17,15 +17,39 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -generate_error_module!( - generate_error_types!(TodoError, TodoErrorKind, - ConversionError => "Conversion Error", - StoreError => "Store Error", - StoreIdError => "Store Id handling error", - ImportError => "Error importing", - UTF8Error => "Encountered non-UTF8 characters while reading input" - ); -); +error_chain! { + types { + TodoError, TodoErrorKind, ResultExt, Result; + } + + errors { + ConversionError { + description("Conversion Error"") + display("Conversion Error") + } + + StoreError { + description("Store Error") + display("Store Error") + } + + StoreIdError { + description("Store Id handling error") + display("Store Id handling error") + } + + ImportError { + description("Error importing") + display("Error importing") + } + + UTF8Error { + description("Encountered non-UTF8 characters while reading input) + display("Encountered non-UTF8 characters while reading input) + } + + } +} pub use self::error::TodoError; pub use self::error::TodoErrorKind; diff --git a/lib/entry/libimagentryannotation/src/error.rs b/lib/entry/libimagentryannotation/src/error.rs index 25fc0048..e53c925f 100644 --- a/lib/entry/libimagentryannotation/src/error.rs +++ b/lib/entry/libimagentryannotation/src/error.rs @@ -17,17 +17,44 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -generate_error_module!( - generate_error_types!(AnnotationError, AnnotationErrorKind, - StoreReadError => "Store read error", - StoreWriteError => "Store write error", +error_chain! { + types { + AnnotationError, AnnotationErrorKind, ResultExt, Result; + } - LinkingError => "Error while linking", - HeaderWriteError => "Couldn't write Header for annotation", - HeaderReadError => "Couldn't read Header of Entry", - HeaderTypeError => "Header field has unexpected type" - ); -); + errors { + StoreReadError { + description("Store read error") + display("Store read error") + } + + StoreWriteError { + description("Store write error") + display("Store write error") + } + + LinkingError { + description("Error while linking") + display("Error while linking") + } + + HeaderWriteError { + description("Couldn't write Header for annotation") + display("Couldn't write Header for annotation") + } + + HeaderReadError { + description("Couldn't read Header of Entry") + display("Couldn't read Header of Entry") + } + + HeaderTypeError { + description("Header field has unexpected type") + display("Header field has unexpected type") + } + + } +} pub use self::error::AnnotationError; pub use self::error::AnnotationErrorKind; diff --git a/lib/entry/libimagentrycategory/src/error.rs b/lib/entry/libimagentrycategory/src/error.rs index 72824337..3de6d768 100644 --- a/lib/entry/libimagentrycategory/src/error.rs +++ b/lib/entry/libimagentrycategory/src/error.rs @@ -17,18 +17,38 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -generate_error_module!( - generate_error_types!(CategoryError, CategoryErrorKind, - StoreReadError => "Store Read error", - StoreWriteError => "Store Write error", - StoreIdHandlingError => "StoreId handling error", - HeaderReadError => "Header read error", - HeaderWriteError => "Header write error", - TypeError => "Found wrong type in header", +error_chain! { + types { + CategoryError, CategoryErrorKind, ResultExt, Result; + } - CategoryDoesNotExist => "Category does not exist" - ); -); + errors { + StoreReadError { + description("Store Read error") + display("Store Read error") + } + + StoreWriteError { + description("Store Write error") + display("Store Write error") + } + + StoreIdHandlingError { + description("StoreId handling error") + display("StoreId handling error") + } + + HeaderReadError { + description("Header read error") + display("Header read error") + } + + CategoryDoesNotExist { + description("Category does not exist") + display("Category does not exist") + } + } +} pub use self::error::CategoryError; pub use self::error::CategoryErrorKind; diff --git a/lib/entry/libimagentrydatetime/src/datepath/error.rs b/lib/entry/libimagentrydatetime/src/datepath/error.rs index 1a163208..d0b28665 100644 --- a/lib/entry/libimagentrydatetime/src/datepath/error.rs +++ b/lib/entry/libimagentrydatetime/src/datepath/error.rs @@ -17,14 +17,23 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -/// Error module for the DatePathCompiler type -generate_error_module! { - generate_error_types!(DatePathCompilerError, DatePathCompilerErrorKind, - UnknownDatePathCompilerError => "Unknown DatePathCompiler error", - StoreIdBuildFailed => "Failed building StoreId object" - ); -} -pub use self::error::DatePathCompilerError; -pub use self::error::DatePathCompilerErrorKind; -pub use self::error::MapErrInto; +error_chain! { + types { + DatePathCompilerError, DatePathCompilerErrorKind, ResultExt, Result; + } + errors { + UnknownDatePathCompilerError { + description("Unknown DatePathCompiler error") + display("Unknown DatePathCompiler error") + } + + StoreIdBuildFailed { + description("Failed building StoreId object") + display("Failed building StoreId object") + } + + } +} + +pub use self::error::DatePathCompilerError; diff --git a/lib/entry/libimagentrydatetime/src/error.rs b/lib/entry/libimagentrydatetime/src/error.rs index 0f0166a0..cf434aca 100644 --- a/lib/entry/libimagentrydatetime/src/error.rs +++ b/lib/entry/libimagentrydatetime/src/error.rs @@ -17,21 +17,59 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -generate_error_module!( - generate_error_types!(DateError, DateErrorKind, - DeleteDateError => "Error deleting date", - ReadDateError => "Error reading date", - SetDateError => "Error setting date", - DeleteDateTimeRangeError => "Error deleting date-time range", - ReadDateTimeRangeError => "Error reading date-time range", - SetDateTimeRangeError => "Error setting date-time range", +error_chain! { + types { + DateError, DateErrorKind, ResultExt, Result; + } - DateTimeRangeError => "DateTime Range error", + errors { + DeleteDateError { + description("Error deleting date") + display("Error deleting date") + } - DateHeaderFieldTypeError => "Expected the header field in the entry to have type 'String', but have other type", - DateTimeParsingError => "Error parsing DateTime" - ); -); + ReadDateError { + description("Error reading date") + display("Error reading date") + } + + SetDateError { + description("Error setting date") + display("Error setting date") + } + + DeleteDateTimeRangeError { + description("Error deleting date-time range") + display("Error deleting date-time range") + } + + ReadDateTimeRangeError { + description("Error reading date-time range") + display("Error reading date-time range") + } + + SetDateTimeRangeError { + description("Error setting date-time range") + display("Error setting date-time range") + } + + DateTimeRangeError { + description("DateTime Range error") + display("DateTime Range error") + } + + DateHeaderFieldTypeError { + description("Expected the header field in the entry to have type 'String', but have other type") + display("Expected the header field in the entry to have type 'String', but have other type") + } + + DateTimeParsingError { + description("Error parsing DateTime") + display("Error parsing DateTime") + } + + } +} pub use self::error::DateError; pub use self::error::DateErrorKind; diff --git a/lib/entry/libimagentrydatetime/src/range.rs b/lib/entry/libimagentrydatetime/src/range.rs index 8820b7a3..52c8095a 100644 --- a/lib/entry/libimagentrydatetime/src/range.rs +++ b/lib/entry/libimagentrydatetime/src/range.rs @@ -18,25 +18,22 @@ // /// Error types for range module -pub mod error { - generate_error_module!( - generate_error_types!(DateTimeRangeError, DateTimeRangeErrorKind, - EndDateTimeBeforeStartDateTime => "End datetime is before start datetime" - ); - ); +error_chain! { + types { + DateTimeRangeError, DateTimeRangeErrorKind, ResultExt, Result; + } - pub use self::error::DateTimeRangeError; - pub use self::error::DateTimeRangeErrorKind; - pub use self::error::MapErrInto; + errors { + EndDateTimeBeforeStartDateTime { + description("End datetime is before start datetime") + display("End datetime is before start datetime") + } + } } -/// Result type for range module -pub mod result { - use std::result::Result as RResult; - use super::error::DateTimeRangeError; - - pub type Result = RResult; -} +pub use self::error::DateTimeRangeError; +pub use self::error::DateTimeRangeErrorKind; +pub use self::error::MapErrInto; use chrono::naive::NaiveDateTime; use libimagerror::into::IntoError; diff --git a/lib/entry/libimagentryedit/src/error.rs b/lib/entry/libimagentryedit/src/error.rs index 478d5d2c..fde19983 100644 --- a/lib/entry/libimagentryedit/src/error.rs +++ b/lib/entry/libimagentryedit/src/error.rs @@ -17,14 +17,34 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -generate_error_module!( - generate_error_types!(EditError, EditErrorKind, - IOError => "IO Error", - NoEditor => "No editor set", - ProcessExitFailure => "Process did not exit properly", - InstantiateError => "Instantation error" - ); -); +error_chain! { + types { + EditError, EditErrorKind, ResultExt, Result; + } + + errors { + IOError { + description("IO Error") + display("IO Error") + } + + NoEditor { + description("No editor set") + display("No editor set") + } + + ProcessExitFailure { + description("Process did not exit properly") + display("Process did not exit properly") + } + + InstantiateError { + description("Instantation error") + display("Instantation error") + } + + } +} pub use self::error::EditError; pub use self::error::EditErrorKind; diff --git a/lib/entry/libimagentrylink/src/error.rs b/lib/entry/libimagentrylink/src/error.rs index 10d83f94..5b315149 100644 --- a/lib/entry/libimagentrylink/src/error.rs +++ b/lib/entry/libimagentrylink/src/error.rs @@ -17,22 +17,74 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -generate_error_module!( - generate_error_types!(LinkError, LinkErrorKind, - EntryHeaderReadError => "Error while reading an entry header", - EntryHeaderWriteError => "Error while writing an entry header", - ExistingLinkTypeWrong => "Existing link entry has wrong type", - LinkTargetDoesNotExist => "Link target does not exist in the store", - LinkParserError => "Link cannot be parsed", - LinkParserFieldMissingError => "Link cannot be parsed: Field missing", - LinkParserFieldTypeError => "Link cannot be parsed: Field type wrong", - InternalConversionError => "Error while converting values internally", - InvalidUri => "URI is not valid", - StoreReadError => "Store read error", - StoreWriteError => "Store write error", - StoreIdError => "StoreId handling error" - ); -); +error_chain! { + types { + LinkError, LinkErrorKind, ResultExt, Result; + } + + errors { + EntryHeaderReadError { + description("Error while reading an entry header") + display("Error while reading an entry header") + } + + EntryHeaderWriteError { + description("Error while writing an entry header") + display("Error while writing an entry header") + } + + ExistingLinkTypeWrong { + description("Existing link entry has wrong type") + display("Existing link entry has wrong type") + } + + LinkTargetDoesNotExist { + description("Link target does not exist in the store") + display("Link target does not exist in the store") + } + + LinkParserError { + description("Link cannot be parsed") + display("Link cannot be parsed") + } + + LinkParserFieldMissingError { + description("Link cannot be parsed: Field missing") + display("Link cannot be parsed: Field missing") + } + + LinkParserFieldTypeError { + description("Link cannot be parsed: Field type wrong") + display("Link cannot be parsed: Field type wrong") + } + + InternalConversionError { + description("Error while converting values internally") + display("Error while converting values internally") + } + + InvalidUri { + description("URI is not valid") + display("URI is not valid") + } + + StoreReadError { + description("Store read error") + display("Store read error") + } + + StoreWriteError { + description("Store write error") + display("Store write error") + } + + StoreIdError { + description("StoreId handling error") + display("StoreId handling error") + } + + } +} pub use self::error::LinkError; pub use self::error::LinkErrorKind; diff --git a/lib/entry/libimagentrylist/src/error.rs b/lib/entry/libimagentrylist/src/error.rs index 9c3b1ccc..e743c468 100644 --- a/lib/entry/libimagentrylist/src/error.rs +++ b/lib/entry/libimagentrylist/src/error.rs @@ -17,15 +17,39 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -generate_error_module!( - generate_error_types!(ListError, ListErrorKind, - IOError => "IO Error", - FormatError => "FormatError", - EntryError => "EntryError", - IterationError => "IterationError", - CLIError => "No CLI subcommand for listing entries" - ); -); +error_chain! { + types { + ListError, ListErrorKind, ResultExt, Result; + } + + errors { + IOError { + description("IO Error") + display("IO Error") + } + + FormatError { + description("FormatError") + display("FormatError") + } + + EntryError { + description("EntryError") + display("EntryError") + } + + IterationError { + description("IterationError") + display("IterationError") + } + + CLIError { + description("No CLI subcommand for listing entries") + display("No CLI subcommand for listing entries") + } + + } +} pub use self::error::ListError; pub use self::error::ListErrorKind; diff --git a/lib/entry/libimagentrymarkdown/src/error.rs b/lib/entry/libimagentrymarkdown/src/error.rs index 1186d5f3..da099a7d 100644 --- a/lib/entry/libimagentrymarkdown/src/error.rs +++ b/lib/entry/libimagentrymarkdown/src/error.rs @@ -17,12 +17,24 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -generate_error_module!( - generate_error_types!(MarkdownError, MarkdownErrorKind, - MarkdownRenderError => "Markdown render error", - LinkParsingError => "Link parsing error" - ); -); +error_chain! { + types { + MarkdownError, MarkdownErrorKind, ResultExt, Result; + } + + errors { + MarkdownRenderError { + description("Markdown render error") + display("Markdown render error") + } + + LinkParsingError { + description("Link parsing error") + display("Link parsing error") + } + + } +} pub use self::error::MarkdownError; pub use self::error::MarkdownErrorKind; diff --git a/lib/entry/libimagentryref/src/error.rs b/lib/entry/libimagentryref/src/error.rs index 56c1e869..fb413929 100644 --- a/lib/entry/libimagentryref/src/error.rs +++ b/lib/entry/libimagentryref/src/error.rs @@ -17,37 +17,129 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -generate_error_module!( - generate_error_types!(RefError, RefErrorKind, - StoreReadError => "Store read error", - StoreWriteError => "Store write error", - IOError => "IO Error", - UTF8Error => "UTF8 Error", - StoreIdError => "Error with storeid", - HeaderTomlError => "Error while working with TOML Header", - HeaderTypeError => "Header type error", - HeaderFieldMissingError => "Header field missing error", - HeaderFieldWriteError => "Header field cannot be written", - HeaderFieldReadError => "Header field cannot be read", - HeaderFieldAlreadyExistsError => "Header field already exists, cannot override", - PathUTF8Error => "Path cannot be converted because of UTF8 Error", - PathHashingError => "Path cannot be hashed", - PathCanonicalizationError => "Path cannot be canonicalized", +error_chain! { + types { + RefError, RefErrorKind, ResultExt, Result; + } - TypeConversionError => "Couldn't convert types", - RefToDisplayError => "Cannot convert Ref to string to show it to user", + errors { + StoreReadError { + description("Store read error") + display("Store read error") + } - RefNotInStore => "Ref/StoreId does not exist in store", + StoreWriteError { + description("Store write error") + display("Store write error") + } - RefTargetDoesNotExist => "Ref Target does not exist", - RefTargetPermissionError => "Ref Target permissions insufficient for referencing", - RefTargetCannotBeHashed => "Ref Target cannot be hashed (is it a directory?)", - RefTargetFileCannotBeOpened => "Ref Target File cannot be open()ed", - RefTargetCannotReadPermissions => "Ref Target: Cannot read permissions", + IOError { + description("IO Error") + display("IO Error") + } - RefHashingError => "Error while hashing" - ); -); + UTF8Error { + description("UTF8 Error") + display("UTF8 Error") + } + + StoreIdError { + description("Error with storeid") + display("Error with storeid") + } + + HeaderTomlError { + description("Error while working with TOML Header") + display("Error while working with TOML Header") + } + + HeaderTypeError { + description("Header type error") + display("Header type error") + } + + HeaderFieldMissingError { + description("Header field missing error") + display("Header field missing error") + } + + HeaderFieldWriteError { + description("Header field cannot be written") + display("Header field cannot be written") + } + + HeaderFieldReadError { + description("Header field cannot be read") + display("Header field cannot be read") + } + + HeaderFieldAlreadyExistsError { + description("Header field already exists, cannot override") + display("Header field already exists, cannot override") + } + + PathUTF8Error { + description("Path cannot be converted because of UTF8 Error") + display("Path cannot be converted because of UTF8 Error") + } + + PathHashingError { + description("Path cannot be hashed") + display("Path cannot be hashed") + } + + PathCanonicalizationError { + description("Path cannot be canonicalized") + display("Path cannot be canonicalized") + } + + TypeConversionError { + description("Couldn't convert types") + display("Couldn't convert types") + } + + RefToDisplayError { + description("Cannot convert Ref to string to show it to user") + display("Cannot convert Ref to string to show it to user") + } + + RefNotInStore { + description("Ref/StoreId does not exist in store") + display("Ref/StoreId does not exist in store") + } + + RefTargetDoesNotExist { + description("Ref Target does not exist") + display("Ref Target does not exist") + } + + RefTargetPermissionError { + description("Ref Target permissions insufficient for referencing") + display("Ref Target permissions insufficient for referencing") + } + + RefTargetCannotBeHashed { + description("Ref Target cannot be hashed (is it a directory?)") + display("Ref Target cannot be hashed (is it a directory?)") + } + + RefTargetFileCannotBeOpened { + description("Ref Target File cannot be open()ed") + display("Ref Target File cannot be open()ed") + } + + RefTargetCannotReadPermissions { + description("Ref Target: Cannot read permissions") + display("Ref Target: Cannot read permissions") + } + + RefHashingError { + description("Error while hashing") + display("Error while hashing") + } + + } +} pub use self::error::RefError; pub use self::error::RefErrorKind; diff --git a/lib/entry/libimagentrytag/src/error.rs b/lib/entry/libimagentrytag/src/error.rs index 579e3ce8..cde51b1c 100644 --- a/lib/entry/libimagentrytag/src/error.rs +++ b/lib/entry/libimagentrytag/src/error.rs @@ -17,14 +17,34 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -generate_error_module!( - generate_error_types!(TagError, TagErrorKind, - TagTypeError => "Entry Header Tag Type wrong", - HeaderReadError => "Error while reading entry header", - HeaderWriteError => "Error while writing entry header", - NotATag => "String is not a tag" - ); -); +error_chain! { + types { + TagError, TagErrorKind, ResultExt, Result; + } + + errors { + TagTypeError { + description("Entry Header Tag Type wrong") + display("Entry Header Tag Type wrong") + } + + HeaderReadError { + description("Error while reading entry header") + display("Error while reading entry header") + } + + HeaderWriteError { + description("Error while writing entry header") + display("Error while writing entry header") + } + + NotATag { + description("String is not a tag") + display("String is not a tag") + } + + } +} pub use self::error::TagError; pub use self::error::TagErrorKind; diff --git a/lib/entry/libimagentryview/src/error.rs b/lib/entry/libimagentryview/src/error.rs index c471b3f3..5e1c5f11 100644 --- a/lib/entry/libimagentryview/src/error.rs +++ b/lib/entry/libimagentryview/src/error.rs @@ -17,15 +17,39 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -generate_error_module!( - generate_error_types!(ViewError, ViewErrorKind, - Unknown => "Unknown view error", - GlobError => "Error while glob()ing", - PatternError => "Error in glob() pattern", - PatternBuildingError => "Could not build glob() pattern", - ViewError => "Failed to start viewer" - ); -); +error_chain! { + types { + ViewError, ViewErrorKind, ResultExt, Result; + } + + errors { + Unknown { + description("Unknown view error") + display("Unknown view error") + } + + GlobError { + description("Error while glob()ing") + display("Error while glob()ing") + } + + PatternError { + description("Error in glob() pattern") + display("Error in glob() pattern") + } + + PatternBuildingError { + description("Could not build glob() pattern") + display("Could not build glob() pattern") + } + + ViewError { + description("Failed to start viewer") + display("Failed to start viewer") + } + + } +} pub use self::error::ViewError; pub use self::error::ViewErrorKind; diff --git a/lib/etc/libimaginteraction/src/error.rs b/lib/etc/libimaginteraction/src/error.rs index 1a4be7df..b54c54a4 100644 --- a/lib/etc/libimaginteraction/src/error.rs +++ b/lib/etc/libimaginteraction/src/error.rs @@ -17,21 +17,69 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -generate_error_module!( - generate_error_types!(InteractionError, InteractionErrorKind, - Unknown => "Unknown Error", - CLIError => "Error on commandline", - IdMissingError => "Commandline: ID missing", - StoreIdParsingError => "Error while parsing StoreId", - IdSelectingError => "Error while selecting id", - ConfigError => "Configuration error", - ConfigMissingError => "Configuration missing", - ConfigTypeError => "Config Type Error", - NoConfigError => "No configuration", - ReadlineHistoryFileCreationError => "Could not create history file for readline", - ReadlineError => "Readline error" - ); -); +error_chain! { + types { + InteractionError, InteractionErrorKind, ResultExt, Result; + } + + errors { + Unknown { + description("Unknown Error") + display("Unknown Error") + } + + CLIError { + description("Error on commandline") + display("Error on commandline") + } + + IdMissingError { + description("Commandline: ID missing") + display("Commandline: ID missing") + } + + StoreIdParsingError { + description("Error while parsing StoreId") + display("Error while parsing StoreId") + } + + IdSelectingError { + description("Error while selecting id") + display("Error while selecting id") + } + + ConfigError { + description("Configuration error") + display("Configuration error") + } + + ConfigMissingError { + description("Configuration missing") + display("Configuration missing") + } + + ConfigTypeError { + description("Config Type Error") + display("Config Type Error") + } + + NoConfigError { + description("No configuration") + display("No configuration") + } + + ReadlineHistoryFileCreationError { + description("Could not create history file for readline") + display("Could not create history file for readline") + } + + ReadlineError { + description("Readline error") + display("Readline error") + } + + } +} pub use self::error::InteractionError; pub use self::error::InteractionErrorKind; From 11d881d3a903a60bdefb8da838be27b0afb2d79e Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Thu, 31 Aug 2017 21:37:52 +0200 Subject: [PATCH 02/32] Add dependency to crates: error_chain = 0.10 --- bin/core/imag-store/Cargo.toml | 1 + bin/core/imag-store/src/main.rs | 1 + lib/core/libimagrt/Cargo.toml | 1 + lib/core/libimagrt/src/lib.rs | 1 + lib/core/libimagstore/Cargo.toml | 1 + lib/core/libimagstore/src/lib.rs | 1 + lib/domain/libimagbookmark/Cargo.toml | 1 + lib/domain/libimagbookmark/src/lib.rs | 1 + lib/domain/libimagcounter/Cargo.toml | 1 + lib/domain/libimagcounter/src/lib.rs | 1 + lib/domain/libimagdiary/Cargo.toml | 1 + lib/domain/libimagdiary/src/lib.rs | 1 + lib/domain/libimagmail/Cargo.toml | 1 + lib/domain/libimagmail/src/lib.rs | 1 + lib/domain/libimagnotes/Cargo.toml | 1 + lib/domain/libimagnotes/src/lib.rs | 1 + lib/domain/libimagtimetrack/Cargo.toml | 1 + lib/domain/libimagtimetrack/src/lib.rs | 1 + lib/domain/libimagtodo/Cargo.toml | 1 + lib/domain/libimagtodo/src/lib.rs | 1 + lib/entry/libimagentryannotation/Cargo.toml | 1 + lib/entry/libimagentryannotation/src/lib.rs | 1 + lib/entry/libimagentrycategory/Cargo.toml | 1 + lib/entry/libimagentrycategory/src/lib.rs | 1 + lib/entry/libimagentrydatetime/Cargo.toml | 1 + lib/entry/libimagentrydatetime/src/lib.rs | 1 + lib/entry/libimagentryedit/Cargo.toml | 1 + lib/entry/libimagentryedit/src/lib.rs | 1 + lib/entry/libimagentrylink/Cargo.toml | 1 + lib/entry/libimagentrylink/src/lib.rs | 1 + lib/entry/libimagentrylist/Cargo.toml | 1 + lib/entry/libimagentrylist/src/lib.rs | 1 + lib/entry/libimagentrymarkdown/Cargo.toml | 1 + lib/entry/libimagentrymarkdown/src/lib.rs | 1 + lib/entry/libimagentryref/Cargo.toml | 1 + lib/entry/libimagentryref/src/lib.rs | 1 + lib/entry/libimagentrytag/Cargo.toml | 1 + lib/entry/libimagentrytag/src/lib.rs | 1 + lib/entry/libimagentryview/Cargo.toml | 1 + lib/entry/libimagentryview/src/lib.rs | 1 + lib/etc/libimaginteraction/Cargo.toml | 1 + lib/etc/libimaginteraction/src/lib.rs | 1 + 42 files changed, 42 insertions(+) diff --git a/bin/core/imag-store/Cargo.toml b/bin/core/imag-store/Cargo.toml index a3715a61..be5b1521 100644 --- a/bin/core/imag-store/Cargo.toml +++ b/bin/core/imag-store/Cargo.toml @@ -18,6 +18,7 @@ clap = ">=2.17" log = "0.3" version = "2.0.1" toml = "^0.4" +error-chain = "0.10" libimagstore = { version = "0.4.0", path = "../../../lib/core/libimagstore", features = ["verify"] } libimagrt = { version = "0.4.0", path = "../../../lib/core/libimagrt" } diff --git a/bin/core/imag-store/src/main.rs b/bin/core/imag-store/src/main.rs index 9e5c5267..45212628 100644 --- a/bin/core/imag-store/src/main.rs +++ b/bin/core/imag-store/src/main.rs @@ -36,6 +36,7 @@ extern crate clap; #[macro_use] extern crate log; extern crate toml; #[macro_use] extern crate version; +#[macro_use] extern crate error_chain; extern crate libimagrt; extern crate libimagstore; diff --git a/lib/core/libimagrt/Cargo.toml b/lib/core/libimagrt/Cargo.toml index 1cdd8cc4..90b2dcbd 100644 --- a/lib/core/libimagrt/Cargo.toml +++ b/lib/core/libimagrt/Cargo.toml @@ -23,6 +23,7 @@ itertools = "0.5" ansi_term = "0.9" is-match = "0.1" toml-query = "0.3.0" +error-chain = "0.10" libimagstore = { version = "0.4.0", path = "../../../lib/core/libimagstore" } libimagerror = { version = "0.4.0", path = "../../../lib/core/libimagerror" } diff --git a/lib/core/libimagrt/src/lib.rs b/lib/core/libimagrt/src/lib.rs index ce0e08c1..876c26ef 100644 --- a/lib/core/libimagrt/src/lib.rs +++ b/lib/core/libimagrt/src/lib.rs @@ -34,6 +34,7 @@ )] #[macro_use] extern crate log; +#[macro_use] extern crate error_chain; extern crate itertools; #[cfg(unix)] extern crate xdg_basedir; extern crate env_logger; diff --git a/lib/core/libimagstore/Cargo.toml b/lib/core/libimagstore/Cargo.toml index 589d2bf1..94af976e 100644 --- a/lib/core/libimagstore/Cargo.toml +++ b/lib/core/libimagstore/Cargo.toml @@ -26,6 +26,7 @@ is-match = "0.1" serde = "1.0" serde_json = "1.0" serde_derive = "1.0" +error-chain = "0.10" libimagerror = { version = "0.4.0", path = "../../../lib/core/libimagerror" } libimagutil = { version = "0.4.0", path = "../../../lib/etc/libimagutil" } diff --git a/lib/core/libimagstore/src/lib.rs b/lib/core/libimagstore/src/lib.rs index 96147ef2..756d4c13 100644 --- a/lib/core/libimagstore/src/lib.rs +++ b/lib/core/libimagstore/src/lib.rs @@ -45,6 +45,7 @@ extern crate walkdir; #[macro_use] extern crate is_match; extern crate serde_json; #[macro_use] extern crate serde_derive; +#[macro_use] extern crate error_chain; #[macro_use] extern crate libimagerror; extern crate libimagutil; diff --git a/lib/domain/libimagbookmark/Cargo.toml b/lib/domain/libimagbookmark/Cargo.toml index 8c3da73c..179cff7f 100644 --- a/lib/domain/libimagbookmark/Cargo.toml +++ b/lib/domain/libimagbookmark/Cargo.toml @@ -16,6 +16,7 @@ homepage = "http://imag-pim.org" [dependencies] url = "1.2" regex = "0.1" +error-chain = "0.10" libimagstore = { version = "0.4.0", path = "../../../lib/core/libimagstore" } libimagerror = { version = "0.4.0", path = "../../../lib/core/libimagerror" } diff --git a/lib/domain/libimagbookmark/src/lib.rs b/lib/domain/libimagbookmark/src/lib.rs index 0a864121..45400e59 100644 --- a/lib/domain/libimagbookmark/src/lib.rs +++ b/lib/domain/libimagbookmark/src/lib.rs @@ -35,6 +35,7 @@ extern crate url; extern crate regex; +#[macro_use] extern crate error_chain; #[macro_use] extern crate libimagstore; #[macro_use] extern crate libimagerror; diff --git a/lib/domain/libimagcounter/Cargo.toml b/lib/domain/libimagcounter/Cargo.toml index 16d5e1b4..c6c61abb 100644 --- a/lib/domain/libimagcounter/Cargo.toml +++ b/lib/domain/libimagcounter/Cargo.toml @@ -17,6 +17,7 @@ homepage = "http://imag-pim.org" log = "0.3" toml = "0.4.*" toml-query = "0.3.*" +error-chain = "0.10" libimagstore = { version = "0.4.0", path = "../../../lib/core/libimagstore" } libimagerror = { version = "0.4.0", path = "../../../lib/core/libimagerror" } diff --git a/lib/domain/libimagcounter/src/lib.rs b/lib/domain/libimagcounter/src/lib.rs index cbbd043c..3952047c 100644 --- a/lib/domain/libimagcounter/src/lib.rs +++ b/lib/domain/libimagcounter/src/lib.rs @@ -36,6 +36,7 @@ extern crate toml; extern crate toml_query; #[macro_use] extern crate log; +#[macro_use] extern crate error_chain; #[macro_use] extern crate libimagstore; #[macro_use] extern crate libimagerror; diff --git a/lib/domain/libimagdiary/Cargo.toml b/lib/domain/libimagdiary/Cargo.toml index bdd65d36..55a5fce4 100644 --- a/lib/domain/libimagdiary/Cargo.toml +++ b/lib/domain/libimagdiary/Cargo.toml @@ -19,6 +19,7 @@ log = "0.3" toml = "0.4.*" toml-query = "0.3.*" itertools = "0.5" +error-chain = "0.10" libimagstore = { version = "0.4.0", path = "../../../lib/core/libimagstore" } libimagerror = { version = "0.4.0", path = "../../../lib/core/libimagerror" } diff --git a/lib/domain/libimagdiary/src/lib.rs b/lib/domain/libimagdiary/src/lib.rs index ca54f902..62ce9c29 100644 --- a/lib/domain/libimagdiary/src/lib.rs +++ b/lib/domain/libimagdiary/src/lib.rs @@ -38,6 +38,7 @@ extern crate chrono; extern crate toml; extern crate toml_query; extern crate itertools; +#[macro_use] extern crate error_chain; #[macro_use] extern crate libimagstore; #[macro_use] extern crate libimagerror; diff --git a/lib/domain/libimagmail/Cargo.toml b/lib/domain/libimagmail/Cargo.toml index ccfb6c53..f1c67aa3 100644 --- a/lib/domain/libimagmail/Cargo.toml +++ b/lib/domain/libimagmail/Cargo.toml @@ -17,6 +17,7 @@ homepage = "http://imag-pim.org" log = "0.3" email = "0.0.17" filters = "0.1.*" +error-chain = "0.10" libimagstore = { version = "0.4.0", path = "../../../lib/core/libimagstore" } libimagerror = { version = "0.4.0", path = "../../../lib/core/libimagerror" } diff --git a/lib/domain/libimagmail/src/lib.rs b/lib/domain/libimagmail/src/lib.rs index 14200eaf..c2462fac 100644 --- a/lib/domain/libimagmail/src/lib.rs +++ b/lib/domain/libimagmail/src/lib.rs @@ -36,6 +36,7 @@ #[macro_use] extern crate log; extern crate email; extern crate filters; +#[macro_use] extern crate error_chain; #[macro_use] extern crate libimagerror; extern crate libimagstore; diff --git a/lib/domain/libimagnotes/Cargo.toml b/lib/domain/libimagnotes/Cargo.toml index 6cb7526a..d9f05e75 100644 --- a/lib/domain/libimagnotes/Cargo.toml +++ b/lib/domain/libimagnotes/Cargo.toml @@ -17,6 +17,7 @@ homepage = "http://imag-pim.org" log = "0.3" toml = "^0.4" toml-query = "0.3.0" +error-chain = "0.10" libimagstore = { version = "0.4.0", path = "../../../lib/core/libimagstore" } libimagerror = { version = "0.4.0", path = "../../../lib/core/libimagerror" } diff --git a/lib/domain/libimagnotes/src/lib.rs b/lib/domain/libimagnotes/src/lib.rs index 699701ac..3fd229c9 100644 --- a/lib/domain/libimagnotes/src/lib.rs +++ b/lib/domain/libimagnotes/src/lib.rs @@ -36,6 +36,7 @@ #[macro_use] extern crate log; extern crate toml; extern crate toml_query; +#[macro_use] extern crate error_chain; extern crate libimagrt; #[macro_use] extern crate libimagstore; diff --git a/lib/domain/libimagtimetrack/Cargo.toml b/lib/domain/libimagtimetrack/Cargo.toml index 6b29fa95..8660b85f 100644 --- a/lib/domain/libimagtimetrack/Cargo.toml +++ b/lib/domain/libimagtimetrack/Cargo.toml @@ -20,6 +20,7 @@ toml = "0.4" toml-query = "0.3" lazy_static = "0.2" is-match = "0.1" +error-chain = "0.10" libimagerror = { version = "0.4.0", path = "../../../lib/core/libimagerror" } libimagstore = { version = "0.4.0", path = "../../../lib/core/libimagstore" } diff --git a/lib/domain/libimagtimetrack/src/lib.rs b/lib/domain/libimagtimetrack/src/lib.rs index 0e92d2e8..ea39f6b2 100644 --- a/lib/domain/libimagtimetrack/src/lib.rs +++ b/lib/domain/libimagtimetrack/src/lib.rs @@ -41,6 +41,7 @@ extern crate toml_query; extern crate lazy_static; #[macro_use] extern crate is_match; +#[macro_use] extern crate error_chain; #[macro_use] extern crate libimagerror; diff --git a/lib/domain/libimagtodo/Cargo.toml b/lib/domain/libimagtodo/Cargo.toml index 656b4d5f..a1f6e435 100644 --- a/lib/domain/libimagtodo/Cargo.toml +++ b/lib/domain/libimagtodo/Cargo.toml @@ -20,6 +20,7 @@ toml = "0.4.*" toml-query = "0.3.*" log = "0.3" serde_json = "0.8" +error-chain = "0.10" libimagstore = { version = "0.4.0", path = "../../../lib/core/libimagstore" } libimagerror = { version = "0.4.0", path = "../../../lib/core/libimagerror" } diff --git a/lib/domain/libimagtodo/src/lib.rs b/lib/domain/libimagtodo/src/lib.rs index 7961a7a1..b09257b1 100644 --- a/lib/domain/libimagtodo/src/lib.rs +++ b/lib/domain/libimagtodo/src/lib.rs @@ -38,6 +38,7 @@ extern crate toml; extern crate toml_query; #[macro_use] extern crate log; extern crate serde_json; +#[macro_use] extern crate error_chain; #[macro_use] extern crate libimagstore; #[macro_use] extern crate libimagerror; diff --git a/lib/entry/libimagentryannotation/Cargo.toml b/lib/entry/libimagentryannotation/Cargo.toml index d4720dc4..ec992855 100644 --- a/lib/entry/libimagentryannotation/Cargo.toml +++ b/lib/entry/libimagentryannotation/Cargo.toml @@ -13,6 +13,7 @@ license = "LGPL-2.1" lazy_static = "0.1.15" toml = "^0.4" toml-query = "0.3.0" +error-chain = "0.10" libimagstore = { version = "0.4.0", path = "../../../lib/core/libimagstore" } libimagerror = { version = "0.4.0", path = "../../../lib/core/libimagerror" } diff --git a/lib/entry/libimagentryannotation/src/lib.rs b/lib/entry/libimagentryannotation/src/lib.rs index 5b784de4..9e37a866 100644 --- a/lib/entry/libimagentryannotation/src/lib.rs +++ b/lib/entry/libimagentryannotation/src/lib.rs @@ -35,6 +35,7 @@ extern crate toml; extern crate toml_query; +#[macro_use] extern crate error_chain; #[macro_use] extern crate libimagerror; extern crate libimagstore; diff --git a/lib/entry/libimagentrycategory/Cargo.toml b/lib/entry/libimagentrycategory/Cargo.toml index e7e54feb..428dcd48 100644 --- a/lib/entry/libimagentrycategory/Cargo.toml +++ b/lib/entry/libimagentrycategory/Cargo.toml @@ -18,6 +18,7 @@ log = "0.3" toml = "0.4" toml-query = "0.3" is-match = "0.1" +error-chain = "0.10" libimagerror = { version = "0.4.0", path = "../../../lib/core/libimagerror" } libimagstore = { version = "0.4.0", path = "../../../lib/core/libimagstore" } diff --git a/lib/entry/libimagentrycategory/src/lib.rs b/lib/entry/libimagentrycategory/src/lib.rs index c2b4daae..a88feace 100644 --- a/lib/entry/libimagentrycategory/src/lib.rs +++ b/lib/entry/libimagentrycategory/src/lib.rs @@ -39,6 +39,7 @@ extern crate toml; extern crate is_match; #[macro_use] extern crate log; +#[macro_use] extern crate error_chain; #[macro_use] extern crate libimagerror; diff --git a/lib/entry/libimagentrydatetime/Cargo.toml b/lib/entry/libimagentrydatetime/Cargo.toml index 15df2055..c2dc483b 100644 --- a/lib/entry/libimagentrydatetime/Cargo.toml +++ b/lib/entry/libimagentrydatetime/Cargo.toml @@ -18,6 +18,7 @@ chrono = "0.4" toml-query = "0.3" lazy_static = "0.2" toml = "0.4" +error-chain = "0.10" libimagerror = { version = "0.4.0", path = "../../../lib/core/libimagerror" } libimagstore = { version = "0.4.0", path = "../../../lib/core/libimagstore" } diff --git a/lib/entry/libimagentrydatetime/src/lib.rs b/lib/entry/libimagentrydatetime/src/lib.rs index 06cf6f22..d59e0056 100644 --- a/lib/entry/libimagentrydatetime/src/lib.rs +++ b/lib/entry/libimagentrydatetime/src/lib.rs @@ -37,6 +37,7 @@ extern crate chrono; extern crate toml_query; extern crate toml; +#[macro_use] extern crate error_chain; #[macro_use] extern crate libimagerror; extern crate libimagstore; diff --git a/lib/entry/libimagentryedit/Cargo.toml b/lib/entry/libimagentryedit/Cargo.toml index 98087aa6..f9857133 100644 --- a/lib/entry/libimagentryedit/Cargo.toml +++ b/lib/entry/libimagentryedit/Cargo.toml @@ -14,6 +14,7 @@ repository = "https://github.com/matthiasbeyer/imag" homepage = "http://imag-pim.org" [dependencies] +error-chain = "0.10" libimagerror = { version = "0.4.0", path = "../../../lib/core/libimagerror" } libimagrt = { version = "0.4.0", path = "../../../lib/core/libimagrt" } diff --git a/lib/entry/libimagentryedit/src/lib.rs b/lib/entry/libimagentryedit/src/lib.rs index 9d9187cd..ab706c77 100644 --- a/lib/entry/libimagentryedit/src/lib.rs +++ b/lib/entry/libimagentryedit/src/lib.rs @@ -37,6 +37,7 @@ extern crate libimagstore; extern crate libimagrt; extern crate libimagutil; +#[macro_use] extern crate error_chain; pub mod edit; pub mod error; diff --git a/lib/entry/libimagentrylink/Cargo.toml b/lib/entry/libimagentrylink/Cargo.toml index 5487c344..ba071fe3 100644 --- a/lib/entry/libimagentrylink/Cargo.toml +++ b/lib/entry/libimagentrylink/Cargo.toml @@ -22,6 +22,7 @@ rust-crypto = "0.2" env_logger = "0.3" is-match = "0.1" toml-query = "0.3.0" +error-chain = "0.10" libimagstore = { version = "0.4.0", path = "../../../lib/core/libimagstore" } libimagerror = { version = "0.4.0", path = "../../../lib/core/libimagerror" } diff --git a/lib/entry/libimagentrylink/src/lib.rs b/lib/entry/libimagentrylink/src/lib.rs index 4df88cc7..94313f98 100644 --- a/lib/entry/libimagentrylink/src/lib.rs +++ b/lib/entry/libimagentrylink/src/lib.rs @@ -40,6 +40,7 @@ extern crate toml_query; extern crate url; extern crate crypto; #[macro_use] extern crate is_match; +#[macro_use] extern crate error_chain; #[cfg(test)] extern crate env_logger; diff --git a/lib/entry/libimagentrylist/Cargo.toml b/lib/entry/libimagentrylist/Cargo.toml index 9775dc41..7746d216 100644 --- a/lib/entry/libimagentrylist/Cargo.toml +++ b/lib/entry/libimagentrylist/Cargo.toml @@ -17,6 +17,7 @@ homepage = "http://imag-pim.org" clap = ">=2.17" log = "0.3" prettytable-rs = "0.6.*" +error-chain = "0.10" libimagstore = { version = "0.4.0", path = "../../../lib/core/libimagstore" } libimagerror = { version = "0.4.0", path = "../../../lib/core/libimagerror" } diff --git a/lib/entry/libimagentrylist/src/lib.rs b/lib/entry/libimagentrylist/src/lib.rs index 8fb0186e..73f01d44 100644 --- a/lib/entry/libimagentrylist/src/lib.rs +++ b/lib/entry/libimagentrylist/src/lib.rs @@ -36,6 +36,7 @@ extern crate clap; #[macro_use] extern crate log; extern crate prettytable; +#[macro_use] extern crate error_chain; extern crate libimagstore; extern crate libimagutil; diff --git a/lib/entry/libimagentrymarkdown/Cargo.toml b/lib/entry/libimagentrymarkdown/Cargo.toml index 5f8364fe..3b962eac 100644 --- a/lib/entry/libimagentrymarkdown/Cargo.toml +++ b/lib/entry/libimagentrymarkdown/Cargo.toml @@ -17,6 +17,7 @@ homepage = "http://imag-pim.org" log = "0.3" hoedown = "5.0.0" url = "1.2" +error-chain = "0.10" libimagstore = { version = "0.4.0", path = "../../../lib/core/libimagstore" } libimagerror = { version = "0.4.0", path = "../../../lib/core/libimagerror" } diff --git a/lib/entry/libimagentrymarkdown/src/lib.rs b/lib/entry/libimagentrymarkdown/src/lib.rs index 4cd31d0a..e2c05cd1 100644 --- a/lib/entry/libimagentrymarkdown/src/lib.rs +++ b/lib/entry/libimagentrymarkdown/src/lib.rs @@ -37,6 +37,7 @@ extern crate hoedown; extern crate url; extern crate libimagstore; #[macro_use] extern crate libimagerror; +#[macro_use] extern crate error_chain; pub mod error; pub mod html; diff --git a/lib/entry/libimagentryref/Cargo.toml b/lib/entry/libimagentryref/Cargo.toml index 842c5535..983de732 100644 --- a/lib/entry/libimagentryref/Cargo.toml +++ b/lib/entry/libimagentryref/Cargo.toml @@ -20,6 +20,7 @@ rust-crypto = "0.2" toml = "^0.4" walkdir = "1.0.*" toml-query = "0.3.0" +error-chain = "0.10" libimagstore = { version = "0.4.0", path = "../../../lib/core/libimagstore" } libimagerror = { version = "0.4.0", path = "../../../lib/core/libimagerror" } diff --git a/lib/entry/libimagentryref/src/lib.rs b/lib/entry/libimagentryref/src/lib.rs index 17cbe112..5a96c79b 100644 --- a/lib/entry/libimagentryref/src/lib.rs +++ b/lib/entry/libimagentryref/src/lib.rs @@ -43,6 +43,7 @@ extern crate walkdir; #[macro_use] extern crate libimagstore; #[macro_use] extern crate libimagerror; extern crate libimagentrylist; +#[macro_use] extern crate error_chain; module_entry_path_mod!("ref"); diff --git a/lib/entry/libimagentrytag/Cargo.toml b/lib/entry/libimagentrytag/Cargo.toml index e80aeed6..c9e3d099 100644 --- a/lib/entry/libimagentrytag/Cargo.toml +++ b/lib/entry/libimagentrytag/Cargo.toml @@ -22,6 +22,7 @@ itertools = "0.5" is-match = "0.1" filters = "0.1" toml-query = "0.3.0" +error-chain = "0.10" libimagstore = { version = "0.4.0", path = "../../../lib/core/libimagstore" } libimagerror = { version = "0.4.0", path = "../../../lib/core/libimagerror" } diff --git a/lib/entry/libimagentrytag/src/lib.rs b/lib/entry/libimagentrytag/src/lib.rs index 4c1fdcb3..ea9c2e71 100644 --- a/lib/entry/libimagentrytag/src/lib.rs +++ b/lib/entry/libimagentrytag/src/lib.rs @@ -41,6 +41,7 @@ extern crate toml; extern crate toml_query; #[macro_use] extern crate is_match; extern crate filters; +#[macro_use] extern crate error_chain; extern crate libimagstore; #[macro_use] extern crate libimagerror; diff --git a/lib/entry/libimagentryview/Cargo.toml b/lib/entry/libimagentryview/Cargo.toml index 42536398..315958a4 100644 --- a/lib/entry/libimagentryview/Cargo.toml +++ b/lib/entry/libimagentryview/Cargo.toml @@ -16,6 +16,7 @@ homepage = "http://imag-pim.org" [dependencies] log = "0.3" toml = "^0.4" +error-chain = "0.10" libimagrt = { version = "0.4.0", path = "../../../lib/core/libimagrt" } libimagstore = { version = "0.4.0", path = "../../../lib/core/libimagstore" } diff --git a/lib/entry/libimagentryview/src/lib.rs b/lib/entry/libimagentryview/src/lib.rs index 1aefc2eb..dc5a4f0e 100644 --- a/lib/entry/libimagentryview/src/lib.rs +++ b/lib/entry/libimagentryview/src/lib.rs @@ -34,6 +34,7 @@ )] extern crate toml; +#[macro_use] extern crate error_chain; extern crate libimagstore; extern crate libimagrt; diff --git a/lib/etc/libimaginteraction/Cargo.toml b/lib/etc/libimaginteraction/Cargo.toml index a72de4af..c409e9b8 100644 --- a/lib/etc/libimaginteraction/Cargo.toml +++ b/lib/etc/libimaginteraction/Cargo.toml @@ -21,6 +21,7 @@ lazy_static = "0.2.*" log = "0.3" regex = "0.2" toml = "^0.4" +error-chain = "0.10" libimagstore = { version = "0.4.0", path = "../../../lib/core/libimagstore" } libimagerror = { version = "0.4.0", path = "../../../lib/core/libimagerror" } diff --git a/lib/etc/libimaginteraction/src/lib.rs b/lib/etc/libimaginteraction/src/lib.rs index cd38071a..be0926aa 100644 --- a/lib/etc/libimaginteraction/src/lib.rs +++ b/lib/etc/libimaginteraction/src/lib.rs @@ -39,6 +39,7 @@ extern crate ansi_term; extern crate regex; extern crate clap; extern crate toml; +#[macro_use] extern crate error_chain; extern crate libimagstore; #[macro_use] extern crate libimagerror; From a309fdb280d5d11e5402641258a531a1ed512433 Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Thu, 31 Aug 2017 21:45:09 +0200 Subject: [PATCH 03/32] Add recursion limits to crates --- lib/core/libimagrt/src/lib.rs | 2 ++ lib/core/libimagstore/src/lib.rs | 2 ++ lib/domain/libimagbookmark/src/lib.rs | 2 ++ lib/domain/libimagcounter/src/lib.rs | 2 ++ lib/domain/libimagdiary/src/lib.rs | 2 ++ lib/domain/libimagmail/src/lib.rs | 2 ++ lib/domain/libimagnotes/src/lib.rs | 2 ++ lib/domain/libimagtimetrack/src/lib.rs | 2 ++ lib/domain/libimagtodo/src/lib.rs | 2 ++ lib/entry/libimagentryannotation/src/lib.rs | 2 ++ lib/entry/libimagentrycategory/src/lib.rs | 2 ++ lib/entry/libimagentrydatetime/src/lib.rs | 2 ++ lib/entry/libimagentryedit/src/lib.rs | 2 ++ lib/entry/libimagentrylink/src/lib.rs | 2 ++ lib/entry/libimagentrylist/src/lib.rs | 2 ++ lib/entry/libimagentrymarkdown/src/lib.rs | 2 ++ lib/entry/libimagentryref/src/lib.rs | 2 ++ lib/entry/libimagentrytag/src/lib.rs | 2 ++ lib/entry/libimagentryview/src/lib.rs | 2 ++ lib/etc/libimaginteraction/src/lib.rs | 2 ++ 20 files changed, 40 insertions(+) diff --git a/lib/core/libimagrt/src/lib.rs b/lib/core/libimagrt/src/lib.rs index 876c26ef..da098517 100644 --- a/lib/core/libimagrt/src/lib.rs +++ b/lib/core/libimagrt/src/lib.rs @@ -17,6 +17,8 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +#![recursion_limit="256"] + #![deny( dead_code, non_camel_case_types, diff --git a/lib/core/libimagstore/src/lib.rs b/lib/core/libimagstore/src/lib.rs index 756d4c13..58aa8ad4 100644 --- a/lib/core/libimagstore/src/lib.rs +++ b/lib/core/libimagstore/src/lib.rs @@ -17,6 +17,8 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +#![recursion_limit="256"] + #![deny( dead_code, non_camel_case_types, diff --git a/lib/domain/libimagbookmark/src/lib.rs b/lib/domain/libimagbookmark/src/lib.rs index 45400e59..7176bfcf 100644 --- a/lib/domain/libimagbookmark/src/lib.rs +++ b/lib/domain/libimagbookmark/src/lib.rs @@ -17,6 +17,8 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +#![recursion_limit="256"] + #![deny( dead_code, non_camel_case_types, diff --git a/lib/domain/libimagcounter/src/lib.rs b/lib/domain/libimagcounter/src/lib.rs index 3952047c..a023437e 100644 --- a/lib/domain/libimagcounter/src/lib.rs +++ b/lib/domain/libimagcounter/src/lib.rs @@ -17,6 +17,8 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +#![recursion_limit="256"] + #![deny( dead_code, non_camel_case_types, diff --git a/lib/domain/libimagdiary/src/lib.rs b/lib/domain/libimagdiary/src/lib.rs index 62ce9c29..0ef328c5 100644 --- a/lib/domain/libimagdiary/src/lib.rs +++ b/lib/domain/libimagdiary/src/lib.rs @@ -17,6 +17,8 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +#![recursion_limit="256"] + #![deny( dead_code, non_camel_case_types, diff --git a/lib/domain/libimagmail/src/lib.rs b/lib/domain/libimagmail/src/lib.rs index c2462fac..5fd42347 100644 --- a/lib/domain/libimagmail/src/lib.rs +++ b/lib/domain/libimagmail/src/lib.rs @@ -17,6 +17,8 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +#![recursion_limit="256"] + #![deny( dead_code, non_camel_case_types, diff --git a/lib/domain/libimagnotes/src/lib.rs b/lib/domain/libimagnotes/src/lib.rs index 3fd229c9..fd646913 100644 --- a/lib/domain/libimagnotes/src/lib.rs +++ b/lib/domain/libimagnotes/src/lib.rs @@ -17,6 +17,8 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +#![recursion_limit="256"] + #![deny( dead_code, non_camel_case_types, diff --git a/lib/domain/libimagtimetrack/src/lib.rs b/lib/domain/libimagtimetrack/src/lib.rs index ea39f6b2..69e5a086 100644 --- a/lib/domain/libimagtimetrack/src/lib.rs +++ b/lib/domain/libimagtimetrack/src/lib.rs @@ -17,6 +17,8 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +#![recursion_limit="256"] + #![deny( dead_code, non_camel_case_types, diff --git a/lib/domain/libimagtodo/src/lib.rs b/lib/domain/libimagtodo/src/lib.rs index b09257b1..7c1da19e 100644 --- a/lib/domain/libimagtodo/src/lib.rs +++ b/lib/domain/libimagtodo/src/lib.rs @@ -17,6 +17,8 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +#![recursion_limit="256"] + #![deny( dead_code, non_camel_case_types, diff --git a/lib/entry/libimagentryannotation/src/lib.rs b/lib/entry/libimagentryannotation/src/lib.rs index 9e37a866..e2f9fb51 100644 --- a/lib/entry/libimagentryannotation/src/lib.rs +++ b/lib/entry/libimagentryannotation/src/lib.rs @@ -17,6 +17,8 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +#![recursion_limit="256"] + #![deny( dead_code, non_camel_case_types, diff --git a/lib/entry/libimagentrycategory/src/lib.rs b/lib/entry/libimagentrycategory/src/lib.rs index a88feace..bfe9d6f7 100644 --- a/lib/entry/libimagentrycategory/src/lib.rs +++ b/lib/entry/libimagentrycategory/src/lib.rs @@ -17,6 +17,8 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +#![recursion_limit="256"] + #![deny( dead_code, non_camel_case_types, diff --git a/lib/entry/libimagentrydatetime/src/lib.rs b/lib/entry/libimagentrydatetime/src/lib.rs index d59e0056..7359093c 100644 --- a/lib/entry/libimagentrydatetime/src/lib.rs +++ b/lib/entry/libimagentrydatetime/src/lib.rs @@ -17,6 +17,8 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +#![recursion_limit="256"] + #![deny( dead_code, non_camel_case_types, diff --git a/lib/entry/libimagentryedit/src/lib.rs b/lib/entry/libimagentryedit/src/lib.rs index ab706c77..ca054538 100644 --- a/lib/entry/libimagentryedit/src/lib.rs +++ b/lib/entry/libimagentryedit/src/lib.rs @@ -17,6 +17,8 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +#![recursion_limit="256"] + #![deny( dead_code, non_camel_case_types, diff --git a/lib/entry/libimagentrylink/src/lib.rs b/lib/entry/libimagentrylink/src/lib.rs index 94313f98..170d5668 100644 --- a/lib/entry/libimagentrylink/src/lib.rs +++ b/lib/entry/libimagentrylink/src/lib.rs @@ -17,6 +17,8 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +#![recursion_limit="256"] + #![deny( dead_code, non_camel_case_types, diff --git a/lib/entry/libimagentrylist/src/lib.rs b/lib/entry/libimagentrylist/src/lib.rs index 73f01d44..de83b60b 100644 --- a/lib/entry/libimagentrylist/src/lib.rs +++ b/lib/entry/libimagentrylist/src/lib.rs @@ -17,6 +17,8 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +#![recursion_limit="256"] + #![deny( dead_code, non_camel_case_types, diff --git a/lib/entry/libimagentrymarkdown/src/lib.rs b/lib/entry/libimagentrymarkdown/src/lib.rs index e2c05cd1..44bc6d35 100644 --- a/lib/entry/libimagentrymarkdown/src/lib.rs +++ b/lib/entry/libimagentrymarkdown/src/lib.rs @@ -17,6 +17,8 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +#![recursion_limit="256"] + #![deny( dead_code, non_camel_case_types, diff --git a/lib/entry/libimagentryref/src/lib.rs b/lib/entry/libimagentryref/src/lib.rs index 5a96c79b..fd850447 100644 --- a/lib/entry/libimagentryref/src/lib.rs +++ b/lib/entry/libimagentryref/src/lib.rs @@ -17,6 +17,8 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +#![recursion_limit="256"] + #![deny( dead_code, non_camel_case_types, diff --git a/lib/entry/libimagentrytag/src/lib.rs b/lib/entry/libimagentrytag/src/lib.rs index ea9c2e71..705293df 100644 --- a/lib/entry/libimagentrytag/src/lib.rs +++ b/lib/entry/libimagentrytag/src/lib.rs @@ -17,6 +17,8 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +#![recursion_limit="256"] + #![deny( dead_code, non_camel_case_types, diff --git a/lib/entry/libimagentryview/src/lib.rs b/lib/entry/libimagentryview/src/lib.rs index dc5a4f0e..0cef0542 100644 --- a/lib/entry/libimagentryview/src/lib.rs +++ b/lib/entry/libimagentryview/src/lib.rs @@ -17,6 +17,8 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +#![recursion_limit="256"] + #![deny( dead_code, non_camel_case_types, diff --git a/lib/etc/libimaginteraction/src/lib.rs b/lib/etc/libimaginteraction/src/lib.rs index be0926aa..ae78b8c8 100644 --- a/lib/etc/libimaginteraction/src/lib.rs +++ b/lib/etc/libimaginteraction/src/lib.rs @@ -17,6 +17,8 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +#![recursion_limit="256"] + #![deny( dead_code, non_camel_case_types, From 9713a4632ca2c52af4fab392bd6c479b4ac7db1a Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sat, 2 Sep 2017 22:30:36 +0200 Subject: [PATCH 04/32] Remove error_gen module entirely --- lib/core/libimagerror/src/error_gen.rs | 206 ------------------------- lib/core/libimagerror/src/lib.rs | 1 - 2 files changed, 207 deletions(-) delete mode 100644 lib/core/libimagerror/src/error_gen.rs diff --git a/lib/core/libimagerror/src/error_gen.rs b/lib/core/libimagerror/src/error_gen.rs deleted file mode 100644 index a03c998f..00000000 --- a/lib/core/libimagerror/src/error_gen.rs +++ /dev/null @@ -1,206 +0,0 @@ -// -// imag - the personal information management suite for the commandline -// Copyright (C) 2015, 2016 Matthias Beyer and contributors -// -// This library is free software; you can redistribute it and/or -// modify it under the terms of the GNU Lesser General Public -// License as published by the Free Software Foundation; version -// 2.1 of the License. -// -// This library is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Lesser General Public License for more details. -// -// You should have received a copy of the GNU Lesser General Public -// License along with this library; if not, write to the Free Software -// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA -// - -#[macro_export] -macro_rules! generate_error_module { - ( $exprs:item ) => { - pub mod error { - $exprs - } - } -} - -#[macro_export] -macro_rules! generate_error_types { - { - $name: ident, - $kindname: ident, - $($kind:ident => $string:expr),* - } => { - error_chain! { - types { - $name, $kindname, ResultExt, Result; - } - - links { - // None - } - - foreign_links { - // None - } - - errors { - $( - $kind { - description($string) - display($string) - } - )* - } - } - - generate_result_helper!($name, $kindname); - generate_option_helper!($name, $kindname); - } -} - -#[macro_export] -macro_rules! generate_result_helper { - { - $name:ident, $kindname:ident - } => { - /// Trait to replace - /// - /// ```ignore - /// foo.map_err(Box::new).map_err(|e| SomeType::SomeErrorKind.into_error_with_cause(e)) - /// // or: - /// foo.map_err(|e| SomeType::SomeErrorKind.into_error_with_cause(Box::new(e))) - /// ``` - /// - /// with much nicer - /// - /// ```ignore - /// foo.map_err_into(SomeType::SomeErrorKind) - /// ``` - /// - pub trait MapErrInto { - fn map_err_into(self, error_kind: $kindname) -> ::std::result::Result; - } - - impl MapErrInto for Result { - - fn map_err_into(self, error_kind: $kindname) -> ::std::result::Result { - self.chain_err(|| error_kind) - } - - } - } -} - -#[macro_export] -macro_rules! generate_option_helper { - { - $name:ident, $kindname:ident - } => { - /// Trait to replace - /// - /// ```ignore - /// foo.ok_or(SomeType::SomeErrorKind.into_error()) - /// ``` - /// - /// with - /// - /// ```ignore - /// foo.ok_or_errkind(SomeType::SomeErrorKind) - /// ``` - pub trait OkOrErr { - fn ok_or_errkind(self, kind: $kindname) -> Result; - } - - impl OkOrErr for Option { - - fn ok_or_errkind(self, kind: $kindname) -> Result { - self.ok_or($name::from_kind(kind)) - } - - } - } -} - - -#[cfg(test)] -#[allow(dead_code)] -mod test { - - generate_error_types!(TestError, TestErrorKind, - TestErrorKindA => "testerrorkind a", - TestErrorKindB => "testerrorkind B"); - - pub mod anothererrormod { - generate_error_types!(TestError, TestErrorKind, - TestErrorKindA => "testerrorkind a", - TestErrorKindB => "testerrorkind B"); - } - - #[test] - fn test_error_kind_mapping() { - use self::MapErrInto; - use self::TestErrorKind; - - let err : Result<()> = Err(TestError::from_kind(TestErrorKind::TestErrorKindB)); - let err : Result<()> = err.map_err_into(TestErrorKind::TestErrorKindA); - - assert!(err.is_err()); - - match *err.unwrap_err().kind() { - TestErrorKind::TestErrorKindA => assert!(true), - _ => assert!(false), - } - } - - #[test] - fn test_error_kind_double_mapping() { - use self::TestErrorKind; - use std::error::Error; - - let err : Result<()> = Err(TestError::from_kind(TestErrorKind::TestErrorKindB)); - let err : Result<()> = err.map_err_into(TestErrorKind::TestErrorKindA) - .map_err_into(TestErrorKind::TestErrorKindB); - - assert!(err.is_err()); - let err = err.unwrap_err(); - match *err.kind() { - TestErrorKind::TestErrorKindB => assert!(true), - _ => assert!(false), - } - - // not sure how to test that the inner error is of TestErrorKindA, actually... - match err.cause() { - Some(_) => assert!(true), - None => assert!(false), - } - - } - - #[test] - fn test_error_option_good() { - use self::OkOrErr; - use self::TestErrorKind; - - let something = Some(1); - match something.ok_or_errkind(TestErrorKind::TestErrorKindA) { - Ok(1) => assert!(true), - _ => assert!(false), - } - } - - #[test] - fn test_error_option_bad() { - use self::OkOrErr; - use self::TestErrorKind; - - let something : Option = None; - match something.ok_or_errkind(TestErrorKind::TestErrorKindA) { - Ok(_) => assert!(false), - Err(_) => assert!(true), - } - } - -} diff --git a/lib/core/libimagerror/src/lib.rs b/lib/core/libimagerror/src/lib.rs index f9aa7f98..e66b6b06 100644 --- a/lib/core/libimagerror/src/lib.rs +++ b/lib/core/libimagerror/src/lib.rs @@ -40,6 +40,5 @@ extern crate ansi_term; #[macro_use] extern crate error_chain; pub mod into; -pub mod error_gen; pub mod trace; pub mod iter; From 603808a9faba93bc1dea8a5004ffc402e2630a5d Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 3 Sep 2017 13:53:55 +0200 Subject: [PATCH 05/32] Impl IntoError for error kinds --- bin/core/imag-store/src/error.rs | 11 +++++++++++ lib/core/libimagrt/src/configuration.rs | 12 ++++++++++++ lib/core/libimagstore/src/error.rs | 11 +++++++++++ lib/domain/libimagbookmark/src/error.rs | 11 +++++++++++ lib/domain/libimagcounter/src/error.rs | 11 +++++++++++ lib/domain/libimagdiary/src/error.rs | 11 +++++++++++ lib/domain/libimagmail/src/error.rs | 11 +++++++++++ lib/domain/libimagnotes/src/error.rs | 11 +++++++++++ lib/domain/libimagtimetrack/src/error.rs | 11 +++++++++++ lib/domain/libimagtodo/src/error.rs | 11 +++++++++++ lib/entry/libimagentryannotation/src/error.rs | 11 +++++++++++ lib/entry/libimagentrycategory/src/error.rs | 11 +++++++++++ lib/entry/libimagentrydatetime/src/datepath/error.rs | 12 ++++++++++++ lib/entry/libimagentrydatetime/src/error.rs | 11 +++++++++++ lib/entry/libimagentrydatetime/src/range.rs | 12 ++++++++++++ lib/entry/libimagentryedit/src/error.rs | 12 ++++++++++++ lib/entry/libimagentrylink/src/error.rs | 11 +++++++++++ lib/entry/libimagentrylist/src/error.rs | 11 +++++++++++ lib/entry/libimagentrymarkdown/src/error.rs | 11 +++++++++++ lib/entry/libimagentryref/src/error.rs | 11 +++++++++++ lib/entry/libimagentrytag/src/error.rs | 11 +++++++++++ lib/entry/libimagentryview/src/error.rs | 12 ++++++++++++ lib/etc/libimaginteraction/src/error.rs | 11 +++++++++++ 23 files changed, 258 insertions(+) diff --git a/bin/core/imag-store/src/error.rs b/bin/core/imag-store/src/error.rs index d74e4a30..163ae344 100644 --- a/bin/core/imag-store/src/error.rs +++ b/bin/core/imag-store/src/error.rs @@ -39,3 +39,14 @@ error_chain! { pub use self::error::StoreError; pub use self::error::StoreErrorKind; +impl IntoError for StoreErrorKind { + type Target = StoreError; + + fn into_error(self) -> Self::Target { + StoreError::from_kind(self) + } + + fn into_error_with_cause(self, cause: Box) -> Self::Target { + StoreError::from_kind(self) + } +} diff --git a/lib/core/libimagrt/src/configuration.rs b/lib/core/libimagrt/src/configuration.rs index 4e064c02..ef2fe267 100644 --- a/lib/core/libimagrt/src/configuration.rs +++ b/lib/core/libimagrt/src/configuration.rs @@ -60,6 +60,18 @@ error_chain! { pub use self::error::{ConfigError, ConfigErrorKind, MapErrInto}; use libimagerror::into::IntoError; +impl IntoError for ConfigErrorKind { + type Target = ConfigError; + + fn into_error(self) -> Self::Target { + ConfigError::from_kind(self) + } + + fn into_error_with_cause(self, cause: Box) -> Self::Target { + ConfigError::from_kind(self) + } +} + /// `Configuration` object /// /// Holds all config variables which are globally available plus the configuration object from the diff --git a/lib/core/libimagstore/src/error.rs b/lib/core/libimagstore/src/error.rs index 8bba587f..61bf7835 100644 --- a/lib/core/libimagstore/src/error.rs +++ b/lib/core/libimagstore/src/error.rs @@ -293,3 +293,14 @@ error_chain! { } } +impl IntoError for StoreErrorKind { + type Target: StoreError; + + fn into_error(self) -> Self::Target { + StoreError::from_kind(self) + } + + fn into_error_with_cause(self, cause: Box) -> Self::Target { + StoreError::from_kind(self) + } +} diff --git a/lib/domain/libimagbookmark/src/error.rs b/lib/domain/libimagbookmark/src/error.rs index ef01a790..671c0ead 100644 --- a/lib/domain/libimagbookmark/src/error.rs +++ b/lib/domain/libimagbookmark/src/error.rs @@ -55,3 +55,14 @@ pub use self::error::BookmarkError; pub use self::error::BookmarkErrorKind; pub use self::error::MapErrInto; +impl IntoError for BookmarkErrorKind { + type Target = BookmarkError; + + fn into_error(self) -> Self::Target { + BookmarkError::from_kind(self) + } + + fn into_error_with_cause(self, cause: Box) -> Self::Target { + BookmarkError::from_kind(self) + } +} diff --git a/lib/domain/libimagcounter/src/error.rs b/lib/domain/libimagcounter/src/error.rs index 726eed60..7bf42d16 100644 --- a/lib/domain/libimagcounter/src/error.rs +++ b/lib/domain/libimagcounter/src/error.rs @@ -54,3 +54,14 @@ error_chain! { pub use self::error::CounterError; pub use self::error::CounterErrorKind; +impl IntoError for CounterErrorKind { + type Target = CounterError; + + fn into_error(self) -> Self::Target { + CounterError::from_kind(self) + } + + fn into_error_with_cause(self, cause: Box) -> Self::Target { + CounterError::from_kind(self) + } +} diff --git a/lib/domain/libimagdiary/src/error.rs b/lib/domain/libimagdiary/src/error.rs index 53b484a7..5eb12274 100644 --- a/lib/domain/libimagdiary/src/error.rs +++ b/lib/domain/libimagdiary/src/error.rs @@ -80,3 +80,14 @@ pub use self::error::DiaryError; pub use self::error::DiaryErrorKind; pub use self::error::MapErrInto; +impl IntoError for DiaryErrorKind { + type Target = DiaryError; + + fn into_error(self) -> Self::Target { + DiaryError::from_kind(self) + } + + fn into_error_with_cause(self, cause: Box) -> Self::Target { + DiaryError::from_kind(self) + } +} diff --git a/lib/domain/libimagmail/src/error.rs b/lib/domain/libimagmail/src/error.rs index 19a67fd6..65eb2b31 100644 --- a/lib/domain/libimagmail/src/error.rs +++ b/lib/domain/libimagmail/src/error.rs @@ -47,3 +47,14 @@ pub use self::error::MailError; pub use self::error::MailErrorKind; pub use self::error::MapErrInto; +impl IntoError for MailErrorKind { + type Target = MailError; + + fn into_error(self) -> Self::Target { + MailError::from_kind(self) + } + + fn into_error_with_cause(self, cause: Box) -> Self::Target { + MailError::from_kind(self) + } +} diff --git a/lib/domain/libimagnotes/src/error.rs b/lib/domain/libimagnotes/src/error.rs index e2793b1c..8b7e6186 100644 --- a/lib/domain/libimagnotes/src/error.rs +++ b/lib/domain/libimagnotes/src/error.rs @@ -50,3 +50,14 @@ pub use self::error::NoteError; pub use self::error::NoteErrorKind; pub use self::error::MapErrInto; +impl IntoError for NoteErrorKind { + type Target = NoteError; + + fn into_error(self) -> Self::Target { + NoteError::from_kind(self) + } + + fn into_error_with_cause(self, cause: Box) -> Self::Target { + NoteError::from_kind(self) + } +} diff --git a/lib/domain/libimagtimetrack/src/error.rs b/lib/domain/libimagtimetrack/src/error.rs index 429d302a..008074a7 100644 --- a/lib/domain/libimagtimetrack/src/error.rs +++ b/lib/domain/libimagtimetrack/src/error.rs @@ -56,3 +56,14 @@ pub use self::error::TimeTrackError; pub use self::error::TimeTrackErrorKind; pub use self::error::MapErrInto; +impl IntoError for TimeTrackErrorKind { + type Target = TimeTrackError; + + fn into_error(self) -> Self::Target { + TimeTrackError::from_kind(self) + } + + fn into_error_with_cause(self, cause: Box) -> Self::Target { + TimeTrackError::from_kind(self) + } +} diff --git a/lib/domain/libimagtodo/src/error.rs b/lib/domain/libimagtodo/src/error.rs index 84a822b2..bfb508d2 100644 --- a/lib/domain/libimagtodo/src/error.rs +++ b/lib/domain/libimagtodo/src/error.rs @@ -55,3 +55,14 @@ pub use self::error::TodoError; pub use self::error::TodoErrorKind; pub use self::error::MapErrInto; +impl IntoError for TodoErrorKind { + type Target = TodoError; + + fn into_error(self) -> Self::Target { + TodoError::from_kind(self) + } + + fn into_error_with_cause(self, cause: Box) -> Self::Target { + TodoError::from_kind(self) + } + } diff --git a/lib/entry/libimagentryannotation/src/error.rs b/lib/entry/libimagentryannotation/src/error.rs index e53c925f..6355048e 100644 --- a/lib/entry/libimagentryannotation/src/error.rs +++ b/lib/entry/libimagentryannotation/src/error.rs @@ -60,3 +60,14 @@ pub use self::error::AnnotationError; pub use self::error::AnnotationErrorKind; pub use self::error::MapErrInto; +impl IntoError for AnnotationErrorKind { + type Target = AnnotationError; + + fn into_error(self) -> Self::Target { + AnnotationError::from_kind(self) + } + + fn into_error_with_cause(self, cause: Box) -> Self::Target { + AnnotationError::from_kind(self) + } +} diff --git a/lib/entry/libimagentrycategory/src/error.rs b/lib/entry/libimagentrycategory/src/error.rs index 3de6d768..ceb114cb 100644 --- a/lib/entry/libimagentrycategory/src/error.rs +++ b/lib/entry/libimagentrycategory/src/error.rs @@ -54,3 +54,14 @@ pub use self::error::CategoryError; pub use self::error::CategoryErrorKind; pub use self::error::MapErrInto; +impl IntoError for CategoryErrorKind { + type Target = CategoryError; + + fn into_error(self) -> Self::Target { + CategoryError::from_kind(self) + } + + fn into_error_with_cause(self, cause: Box) -> Self::Target { + CategoryError::from_kind(self) + } +} diff --git a/lib/entry/libimagentrydatetime/src/datepath/error.rs b/lib/entry/libimagentrydatetime/src/datepath/error.rs index d0b28665..f080e5ac 100644 --- a/lib/entry/libimagentrydatetime/src/datepath/error.rs +++ b/lib/entry/libimagentrydatetime/src/datepath/error.rs @@ -37,3 +37,15 @@ error_chain! { } pub use self::error::DatePathCompilerError; + +impl IntoError for DatePathCompilerErrorKind { + type Target = DatePathCompilerError; + + fn into_error(self) -> Self::Target { + DatePathCompilerError::from_kind(self) + } + + fn into_error_with_cause(self, cause: Box) -> Self::Target { + DatePathCompilerError::from_kind(self) + } +} diff --git a/lib/entry/libimagentrydatetime/src/error.rs b/lib/entry/libimagentrydatetime/src/error.rs index cf434aca..c49bb8c4 100644 --- a/lib/entry/libimagentrydatetime/src/error.rs +++ b/lib/entry/libimagentrydatetime/src/error.rs @@ -75,3 +75,14 @@ pub use self::error::DateError; pub use self::error::DateErrorKind; pub use self::error::MapErrInto; +impl IntoError for DateErrorKind { + type Target = DateError; + + fn into_error(self) -> Self::Target { + DateError::from_kind(self) + } + + fn into_error_with_cause(self, cause: Box) -> Self::Target { + DateError::from_kind(self) + } +} diff --git a/lib/entry/libimagentrydatetime/src/range.rs b/lib/entry/libimagentrydatetime/src/range.rs index 52c8095a..f729dfde 100644 --- a/lib/entry/libimagentrydatetime/src/range.rs +++ b/lib/entry/libimagentrydatetime/src/range.rs @@ -35,6 +35,18 @@ pub use self::error::DateTimeRangeError; pub use self::error::DateTimeRangeErrorKind; pub use self::error::MapErrInto; +impl IntoError for DateTimeRangeErrorKind { + type Target = DateTimeRangeError; + + fn into_error(self) -> Self::Target { + DateTimeRangeError::from_kind(self) + } + + fn into_error_with_cause(self, cause: Box) -> Self::Target { + DateTimeRangeError::from_kind(self) + } +} + use chrono::naive::NaiveDateTime; use libimagerror::into::IntoError; use self::result::Result; diff --git a/lib/entry/libimagentryedit/src/error.rs b/lib/entry/libimagentryedit/src/error.rs index fde19983..a37c7e80 100644 --- a/lib/entry/libimagentryedit/src/error.rs +++ b/lib/entry/libimagentryedit/src/error.rs @@ -50,3 +50,15 @@ pub use self::error::EditError; pub use self::error::EditErrorKind; pub use self::error::MapErrInto; +impl IntoError for EditErrorKind { + type Target = EditError; + + fn into_error(self) -> Self::Target { + EditError::from_kind(self) + } + + fn into_error_with_cause(self, cause: Box) -> Self::Target { + EditError::from_kind(self) + } +} + diff --git a/lib/entry/libimagentrylink/src/error.rs b/lib/entry/libimagentrylink/src/error.rs index 5b315149..d9bf3db2 100644 --- a/lib/entry/libimagentrylink/src/error.rs +++ b/lib/entry/libimagentrylink/src/error.rs @@ -90,3 +90,14 @@ pub use self::error::LinkError; pub use self::error::LinkErrorKind; pub use self::error::MapErrInto; +impl IntoError for LinkErrorKind { + type Target = LinkError; + + fn into_error(self) -> Self::Target { + LinkError::from_kind(self) + } + + fn into_error_with_cause(self, cause: Box) -> Self::Target { + LinkError::from_kind(self) + } +} diff --git a/lib/entry/libimagentrylist/src/error.rs b/lib/entry/libimagentrylist/src/error.rs index e743c468..fd5aea59 100644 --- a/lib/entry/libimagentrylist/src/error.rs +++ b/lib/entry/libimagentrylist/src/error.rs @@ -55,3 +55,14 @@ pub use self::error::ListError; pub use self::error::ListErrorKind; pub use self::error::MapErrInto; +impl IntoError for ListErrorKind { + type Target = ListError; + + fn into_error(self) -> Self::Target { + ListError::from_kind(self) + } + + fn into_error_with_cause(self, cause: Box) -> Self::Target { + ListError::from_kind(self) + } +} diff --git a/lib/entry/libimagentrymarkdown/src/error.rs b/lib/entry/libimagentrymarkdown/src/error.rs index da099a7d..b3956d0e 100644 --- a/lib/entry/libimagentrymarkdown/src/error.rs +++ b/lib/entry/libimagentrymarkdown/src/error.rs @@ -40,3 +40,14 @@ pub use self::error::MarkdownError; pub use self::error::MarkdownErrorKind; +impl IntoError for MarkdownErrorKind { + type Target = MarkdownError; + + fn into_error(self) -> Self::Target { + MarkdownError::from_kind(self) + } + + fn into_error_with_cause(self, cause: Box) -> Self::Target { + MarkdownError::from_kind(self) + } +} diff --git a/lib/entry/libimagentryref/src/error.rs b/lib/entry/libimagentryref/src/error.rs index fb413929..4f9f155c 100644 --- a/lib/entry/libimagentryref/src/error.rs +++ b/lib/entry/libimagentryref/src/error.rs @@ -145,3 +145,14 @@ pub use self::error::RefError; pub use self::error::RefErrorKind; pub use self::error::MapErrInto; +impl IntoError for RefErrorKind { + type Target = RefError; + + fn into_error(self) -> Self::Target { + RefError::from_kind(self) + } + + fn into_error_with_cause(self, cause: Box) -> Self::Target { + RefError::from_kind(self) + } +} diff --git a/lib/entry/libimagentrytag/src/error.rs b/lib/entry/libimagentrytag/src/error.rs index cde51b1c..0c2e8204 100644 --- a/lib/entry/libimagentrytag/src/error.rs +++ b/lib/entry/libimagentrytag/src/error.rs @@ -50,3 +50,14 @@ pub use self::error::TagError; pub use self::error::TagErrorKind; pub use self::error::MapErrInto; +impl IntoError for TagErrorKind { + type Target = TagError; + + fn into_error(self) -> Self::Target { + TagError::from_kind(self) + } + + fn into_error_with_cause(self, cause: Box) -> Self::Target { + TagError::from_kind(self) + } +} diff --git a/lib/entry/libimagentryview/src/error.rs b/lib/entry/libimagentryview/src/error.rs index 5e1c5f11..a7d29d52 100644 --- a/lib/entry/libimagentryview/src/error.rs +++ b/lib/entry/libimagentryview/src/error.rs @@ -54,3 +54,15 @@ error_chain! { pub use self::error::ViewError; pub use self::error::ViewErrorKind; pub use self::error::MapErrInto; + +impl IntoError for ViewErrorKind { + type Target = ViewError; + + fn into_error(self) -> Self::Target { + ViewError::from_kind(self) + } + + fn into_error_with_cause(self, cause: Box) -> Self::Target { + ViewError::from_kind(self) + } +} diff --git a/lib/etc/libimaginteraction/src/error.rs b/lib/etc/libimaginteraction/src/error.rs index b54c54a4..271bf832 100644 --- a/lib/etc/libimaginteraction/src/error.rs +++ b/lib/etc/libimaginteraction/src/error.rs @@ -85,3 +85,14 @@ pub use self::error::InteractionError; pub use self::error::InteractionErrorKind; pub use self::error::MapErrInto; +impl IntoError for InteractionErrorKind { + type Target = InteractionError; + + fn into_error(self) -> Self::Target { + InteractionError::from_kind(self) + } + + fn into_error_with_cause(self, cause: Box) -> Self::Target { + InteractionError::from_kind(self) + } +} From 2df99524e7a3c74c67f5361459375e8505bd4deb Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sat, 2 Sep 2017 23:02:53 +0200 Subject: [PATCH 06/32] libimagstore: rewrite error handling code --- lib/core/libimagrt/src/runtime.rs | 2 +- lib/core/libimagstore/src/configuration.rs | 5 +- lib/core/libimagstore/src/error.rs | 12 +- .../libimagstore/src/file_abstraction/fs.rs | 29 +++-- .../src/file_abstraction/inmemory.rs | 20 +-- .../src/file_abstraction/stdio/mapper/json.rs | 21 ++- .../src/file_abstraction/stdio/mod.rs | 14 +- .../src/file_abstraction/stdio/out.rs | 4 +- lib/core/libimagstore/src/lib.rs | 2 +- lib/core/libimagstore/src/store.rs | 120 +++++++++--------- lib/core/libimagstore/src/storeid.rs | 15 ++- lib/core/libimagstore/src/util.rs | 7 +- 12 files changed, 128 insertions(+), 123 deletions(-) diff --git a/lib/core/libimagrt/src/runtime.rs b/lib/core/libimagrt/src/runtime.rs index 1b5f3f7c..dcdd8e1b 100644 --- a/lib/core/libimagrt/src/runtime.rs +++ b/lib/core/libimagrt/src/runtime.rs @@ -32,7 +32,7 @@ use log::LogLevelFilter; use configuration::{Configuration, InternalConfiguration}; use error::RuntimeError; use error::RuntimeErrorKind; -use error::MapErrInto; +use error::ResultExt; use logger::ImagLogger; use libimagstore::store::Store; diff --git a/lib/core/libimagstore/src/configuration.rs b/lib/core/libimagstore/src/configuration.rs index 0dfc0490..dc60311d 100644 --- a/lib/core/libimagstore/src/configuration.rs +++ b/lib/core/libimagstore/src/configuration.rs @@ -19,9 +19,8 @@ use toml::Value; -use libimagerror::into::IntoError; - use store::Result; +use error::StoreError as SE; /// Check whether the configuration is valid for the store pub fn config_is_valid(config: &Option) -> Result<()> { @@ -35,7 +34,7 @@ pub fn config_is_valid(config: &Option) -> Result<()> { Some(Value::Table(_)) => Ok(()), _ => { warn!("Store config is no table"); - Err(SEK::ConfigTypeError.into_error()) + Err(SE::from_kind(SEK::ConfigTypeError)) }, } } diff --git a/lib/core/libimagstore/src/error.rs b/lib/core/libimagstore/src/error.rs index 61bf7835..df20ac53 100644 --- a/lib/core/libimagstore/src/error.rs +++ b/lib/core/libimagstore/src/error.rs @@ -17,11 +17,19 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +use std::error::Error; +use libimagerror::into::IntoError; + error_chain! { types { StoreError, StoreErrorKind, ResultExt, Result; } + foreign_links { + Io(::std::io::Error); + TomlDeserError(::toml::de::Error); + } + errors { ConfigurationError { @@ -294,13 +302,13 @@ error_chain! { } impl IntoError for StoreErrorKind { - type Target: StoreError; + type Target = StoreError; fn into_error(self) -> Self::Target { StoreError::from_kind(self) } - fn into_error_with_cause(self, cause: Box) -> Self::Target { + fn into_error_with_cause(self, _: Box) -> Self::Target { StoreError::from_kind(self) } } diff --git a/lib/core/libimagstore/src/file_abstraction/fs.rs b/lib/core/libimagstore/src/file_abstraction/fs.rs index 9fd14456..bb47f275 100644 --- a/lib/core/libimagstore/src/file_abstraction/fs.rs +++ b/lib/core/libimagstore/src/file_abstraction/fs.rs @@ -21,7 +21,8 @@ use std::fs::{File, OpenOptions, create_dir_all, remove_file, copy, rename}; use std::io::{Seek, SeekFrom, Read}; use std::path::{Path, PathBuf}; -use error::{MapErrInto, StoreError as SE, StoreErrorKind as SEK}; +use error::{StoreError as SE, StoreErrorKind as SEK}; +use error::ResultExt; use super::FileAbstraction; use super::FileAbstractionInstance; @@ -47,22 +48,22 @@ impl FileAbstractionInstance for FSFileAbstractionInstance { // We seek to the beginning of the file since we expect each // access to the file to be in a different context try!(f.seek(SeekFrom::Start(0)) - .map_err_into(SEK::FileNotSeeked)); + .chain_err(|| SEK::FileNotSeeked)); let mut s = String::new(); f.read_to_string(&mut s) - .map_err_into(SEK::IoError) + .chain_err(|| SEK::IoError) .map(|_| s) .and_then(|s| Entry::from_str(id, &s)) }, FSFileAbstractionInstance::Absent(ref p) => - (try!(open_file(p).map_err_into(SEK::FileNotFound)), p.clone()), + (try!(open_file(p).chain_err(|| SEK::FileNotFound)), p.clone()), }; *self = FSFileAbstractionInstance::File(file, path); if let FSFileAbstractionInstance::File(ref mut f, _) = *self { let mut s = String::new(); f.read_to_string(&mut s) - .map_err_into(SEK::IoError) + .chain_err(|| SEK::IoError) .map(|_| s) .and_then(|s| Entry::from_str(id, &s)) } else { @@ -83,18 +84,18 @@ impl FileAbstractionInstance for FSFileAbstractionInstance { // We seek to the beginning of the file since we expect each // access to the file to be in a different context try!(f.seek(SeekFrom::Start(0)) - .map_err_into(SEK::FileNotCreated)); + .chain_err(|| SEK::FileNotCreated)); - try!(f.set_len(buf.len() as u64).map_err_into(SEK::FileNotWritten)); + try!(f.set_len(buf.len() as u64).chain_err(|| SEK::FileNotWritten)); - f.write_all(&buf).map_err_into(SEK::FileNotWritten) + f.write_all(&buf).chain_err(|| SEK::FileNotWritten) }, FSFileAbstractionInstance::Absent(ref p) => - (try!(create_file(p).map_err_into(SEK::FileNotCreated)), p.clone()), + (try!(create_file(p).chain_err(|| SEK::FileNotCreated)), p.clone()), }; *self = FSFileAbstractionInstance::File(file, path); if let FSFileAbstractionInstance::File(ref mut f, _) = *self { - return f.write_all(&buf).map_err_into(SEK::FileNotWritten); + return f.write_all(&buf).chain_err(|| SEK::FileNotWritten); } unreachable!(); } @@ -117,19 +118,19 @@ impl FSFileAbstraction { impl FileAbstraction for FSFileAbstraction { fn remove_file(&self, path: &PathBuf) -> Result<(), SE> { - remove_file(path).map_err_into(SEK::FileNotRemoved) + remove_file(path).chain_err(|| SEK::FileNotRemoved) } fn copy(&self, from: &PathBuf, to: &PathBuf) -> Result<(), SE> { - copy(from, to).map_err_into(SEK::FileNotCopied).map(|_| ()) + copy(from, to).chain_err(|| SEK::FileNotCopied).map(|_| ()) } fn rename(&self, from: &PathBuf, to: &PathBuf) -> Result<(), SE> { - rename(from, to).map_err_into(SEK::FileNotRenamed) + rename(from, to).chain_err(|| SEK::FileNotRenamed) } fn create_dir_all(&self, path: &PathBuf) -> Result<(), SE> { - create_dir_all(path).map_err_into(SEK::DirNotCreated) + create_dir_all(path).chain_err(|| SEK::DirNotCreated) } fn new_instance(&self, p: PathBuf) -> Box { diff --git a/lib/core/libimagstore/src/file_abstraction/inmemory.rs b/lib/core/libimagstore/src/file_abstraction/inmemory.rs index 4f318fe1..c1333aca 100644 --- a/lib/core/libimagstore/src/file_abstraction/inmemory.rs +++ b/lib/core/libimagstore/src/file_abstraction/inmemory.rs @@ -17,23 +17,24 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +use std::path::PathBuf; + use error::StoreError as SE; use error::StoreErrorKind as SEK; -use std::path::PathBuf; use std::collections::HashMap; use std::sync::Mutex; use std::cell::RefCell; use std::sync::Arc; use std::ops::Deref; -use libimagerror::into::IntoError; - use super::FileAbstraction; use super::FileAbstractionInstance; use super::Drain; use store::Entry; use storeid::StoreId; +use libimagerror::into::IntoError; + type Backend = Arc>>>; /// `FileAbstraction` type, this is the Test version! @@ -64,16 +65,15 @@ impl FileAbstractionInstance for InMemoryFileAbstractionInstance { fn get_file_content(&mut self, _: StoreId) -> Result { debug!("Getting lazy file: {:?}", self); - match self.fs_abstraction.lock() { - Ok(mut mtx) => { + self.fs_abstraction + .lock() + .map_err(|_| SEK::LockError.into_error()) + .and_then(|mut mtx| { mtx.get_mut() .get(&self.absent_path) .cloned() .ok_or(SEK::FileNotFound.into_error()) - } - - Err(_) => Err(SEK::LockError.into_error()) - } + }) } fn write_file_content(&mut self, buf: &Entry) -> Result<(), SE> { @@ -163,7 +163,7 @@ impl FileAbstraction for InMemoryFileAbstraction { fn fill<'a>(&'a mut self, mut d: Drain) -> Result<(), SE> { debug!("Draining into : {:?}", self); - let mut mtx = try!(self.backend().lock().map_err(|_| SEK::LockError.into_error())); + let mut mtx = try!(self.backend().lock().map_err(|_| SEK::LockError)); let backend = mtx.get_mut(); for (path, element) in d.iter() { diff --git a/lib/core/libimagstore/src/file_abstraction/stdio/mapper/json.rs b/lib/core/libimagstore/src/file_abstraction/stdio/mapper/json.rs index 0b66f91c..4af44a31 100644 --- a/lib/core/libimagstore/src/file_abstraction/stdio/mapper/json.rs +++ b/lib/core/libimagstore/src/file_abstraction/stdio/mapper/json.rs @@ -25,14 +25,13 @@ use serde_json; use toml; use error::StoreErrorKind as SEK; -use error::MapErrInto; +use error::StoreError as SE; +use error::ResultExt; use super::Mapper; use store::Result; use store::Entry; use storeid::StoreId; -use libimagerror::into::IntoError; - #[derive(Debug, Deserialize, Serialize)] struct BackendEntry { header: serde_json::Value, @@ -43,7 +42,7 @@ impl BackendEntry { fn to_string(self) -> Result { toml::to_string(&self.header) - .map_err_into(SEK::IoError) + .chain_err(|| SEK::IoError) .map(|hdr| { format!("---\n{header}---\n{content}", header = hdr, @@ -74,16 +73,16 @@ impl Mapper for JsonMapper { let mut document = { debug!("Reading Document"); let mut s = String::new(); - try!(r.read_to_string(&mut s).map_err_into(SEK::IoError)); + try!(r.read_to_string(&mut s).chain_err(|| SEK::IoError)); debug!("Document = {:?}", s); debug!("Parsing Document"); - let doc : Document = try!(serde_json::from_str(&s).map_err_into(SEK::IoError)); + let doc : Document = try!(serde_json::from_str(&s).chain_err(|| SEK::IoError)); debug!("Document = {:?}", doc); doc }; let _ = try!(::semver::Version::parse(&document.version) - .map_err_into(SEK::VersionError) + .chain_err(|| SEK::VersionError) .and_then(|doc_vers| { // safe because cargo does not compile if crate version is not valid let crate_version = ::semver::Version::parse(version!()).unwrap(); @@ -93,7 +92,7 @@ impl Mapper for JsonMapper { crate_vers = crate_version); if doc_vers > crate_version { - Err(SEK::VersionError.into_error()) + Err(SE::from_kind(SEK::VersionError)) } else { Ok(()) } @@ -150,9 +149,9 @@ impl Mapper for JsonMapper { }; serde_json::to_string(&doc) - .map_err_into(SEK::IoError) - .and_then(|json| out.write(&json.into_bytes()).map_err_into(SEK::IoError)) - .and_then(|_| out.flush().map_err_into(SEK::IoError)) + .chain_err(|| SEK::IoError) + .and_then(|json| out.write(&json.into_bytes()).chain_err(|| SEK::IoError)) + .and_then(|_| out.flush().chain_err(|| SEK::IoError)) .map(|_| ()) } } diff --git a/lib/core/libimagstore/src/file_abstraction/stdio/mod.rs b/lib/core/libimagstore/src/file_abstraction/stdio/mod.rs index e2ac5ec4..9fbb8413 100644 --- a/lib/core/libimagstore/src/file_abstraction/stdio/mod.rs +++ b/lib/core/libimagstore/src/file_abstraction/stdio/mod.rs @@ -29,8 +29,6 @@ use std::fmt::Debug; use std::fmt::Error as FmtError; use std::fmt::Formatter; -use libimagerror::into::IntoError; - use error::StoreErrorKind as SEK; use error::StoreError as SE; use super::FileAbstraction; @@ -39,6 +37,8 @@ use super::Drain; use super::InMemoryFileAbstraction; use store::Entry; +use libimagerror::into::IntoError; + pub mod mapper; pub mod out; use self::mapper::Mapper; @@ -57,11 +57,11 @@ impl StdIoFileAbstraction pub fn new(in_stream: &mut R, out_stream: Rc>, mapper: M) -> Result, SE> { StdoutFileAbstraction::new(out_stream, mapper) .and_then(|out| { - let fill_res = match out.backend().lock() { - Err(_) => Err(SEK::LockError.into_error()), - Ok(mut mtx) => out.mapper().read_to_fs(in_stream, mtx.get_mut()) - }; - let _ = try!(fill_res); + let _ = try!(out + .backend() + .lock() + .map_err(|_| SEK::LockError.into_error()) + .map(|mut mtx| out.mapper().read_to_fs(in_stream, mtx.get_mut()))); Ok(StdIoFileAbstraction(out)) }) diff --git a/lib/core/libimagstore/src/file_abstraction/stdio/out.rs b/lib/core/libimagstore/src/file_abstraction/stdio/out.rs index 37ccab62..48f2ff72 100644 --- a/lib/core/libimagstore/src/file_abstraction/stdio/out.rs +++ b/lib/core/libimagstore/src/file_abstraction/stdio/out.rs @@ -31,8 +31,8 @@ use std::sync::Arc; use std::sync::Mutex; use std::ops::Deref; -use libimagerror::into::IntoError; use libimagerror::trace::*; +use libimagerror::into::IntoError; use error::StoreErrorKind as SEK; use error::StoreError as SE; @@ -101,7 +101,7 @@ impl Drop for StdoutFileAbstraction use std::ops::DerefMut; let fill_res = match self.mem.backend().lock() { - Err(_) => Err(SEK::LockError.into_error()), + Err(_) => Err(SE::from_kind(SEK::LockError)), Ok(mut mtx) => { self.mapper.fs_to_write(mtx.get_mut(), self.out.borrow_mut().deref_mut()) }, diff --git a/lib/core/libimagstore/src/lib.rs b/lib/core/libimagstore/src/lib.rs index 58aa8ad4..891eb841 100644 --- a/lib/core/libimagstore/src/lib.rs +++ b/lib/core/libimagstore/src/lib.rs @@ -49,7 +49,7 @@ extern crate serde_json; #[macro_use] extern crate serde_derive; #[macro_use] extern crate error_chain; -#[macro_use] extern crate libimagerror; +extern crate libimagerror; extern crate libimagutil; #[macro_use] mod util; diff --git a/lib/core/libimagstore/src/store.rs b/lib/core/libimagstore/src/store.rs index ba66641a..abcdbcd5 100644 --- a/lib/core/libimagstore/src/store.rs +++ b/lib/core/libimagstore/src/store.rs @@ -38,8 +38,8 @@ use glob::glob; use walkdir::WalkDir; use walkdir::Iter as WalkDirIter; -use error::{StoreError as SE, StoreErrorKind as SEK, ParserError, ParserErrorKind}; -use error::MapErrInto; +use error::{StoreError as SE, StoreErrorKind as SEK}; +use error::ResultExt; use storeid::{IntoStoreId, StoreId, StoreIdIterator}; use file_abstraction::FileAbstractionInstance; @@ -48,8 +48,8 @@ pub use file_abstraction::FileAbstraction; pub use file_abstraction::FSFileAbstraction; pub use file_abstraction::InMemoryFileAbstraction; -use libimagerror::into::IntoError; use libimagerror::trace::trace_error; +use libimagerror::into::IntoError; use libimagutil::debug_result::*; use self::glob_store_iter::*; @@ -147,8 +147,8 @@ impl StoreEntry { #[cfg(feature = "fs-lock")] { try!(open_file(pb.clone()) - .and_then(|f| f.lock_exclusive().map_err_into(SEK::FileError)) - .map_err_into(SEK::IoError)); + .and_then(|f| f.lock_exclusive().chain_err(|| SEK::FileError)) + .chain_err(|| SEK::IoError)); } Ok(StoreEntry { @@ -168,13 +168,13 @@ impl StoreEntry { if !self.is_borrowed() { self.file .get_file_content(self.id.clone()) - .or_else(|err| if err.err_type() == SEK::FileNotFound { + .or_else(|err| if is_match!(err.kind(), &SEK::FileNotFound) { Ok(Entry::new(self.id.clone())) } else { Err(err) }) } else { - Err(SE::new(SEK::EntryAlreadyBorrowed, None)) + Err(SE::from_kind(SEK::EntryAlreadyBorrowed)) } } @@ -182,7 +182,7 @@ impl StoreEntry { if self.is_borrowed() { assert_eq!(self.id, entry.location); self.file.write_file_content(entry) - .map_err_into(SEK::FileError) + .chain_err(|| SEK::FileError) .map(|_| ()) } else { Ok(()) @@ -195,9 +195,9 @@ impl Drop for StoreEntry { fn drop(self) { self.get_entry() - .and_then(|entry| open_file(entry.get_location().clone()).map_err_into(SEK::IoError)) - .and_then(|f| f.unlock().map_err_into(SEK::FileError)) - .map_err_into(SEK::IoError) + .and_then(|entry| open_file(entry.get_location().clone()).chain_err(|| SEK::IoError)) + .and_then(|f| f.unlock().chain_err(|| SEK::FileError)) + .chain_err(|| SEK::IoError) } } @@ -266,7 +266,7 @@ impl Store { use configuration::*; debug!("Validating Store configuration"); - let _ = try!(config_is_valid(&store_config).map_err_into(SEK::ConfigurationError)); + let _ = try!(config_is_valid(&store_config).chain_err(|| SEK::ConfigurationError)); debug!("Building new Store object"); if !location.exists() { @@ -275,12 +275,12 @@ impl Store { warn!(" -> Either because configuration does not allow it"); warn!(" -> or because there is no configuration"); return Err(SEK::CreateStoreDirDenied.into_error()) - .map_err_into(SEK::FileError) - .map_err_into(SEK::IoError); + .chain_err(|| SEK::FileError) + .chain_err(|| SEK::IoError); } try!(backend.create_dir_all(&location) - .map_err_into(SEK::StorePathCreate) + .chain_err(|| SEK::StorePathCreate) .map_dbg_err_str("Failed")); } else if location.is_file() { debug!("Store path exists as file"); @@ -408,13 +408,13 @@ impl Store { { let mut hsmap = match self.entries.write() { - Err(_) => return Err(SEK::LockPoisoned.into_error()).map_err_into(SEK::CreateCallError), + Err(_) => return Err(SEK::LockPoisoned.into_error()).chain_err(|| SEK::CreateCallError), Ok(s) => s, }; if hsmap.contains_key(&id) { debug!("Cannot create, internal cache already contains: '{}'", id); - return Err(SEK::EntryAlreadyExists.into_error()).map_err_into(SEK::CreateCallError); + return Err(SEK::EntryAlreadyExists.into_error()).chain_err(|| SEK::CreateCallError); } hsmap.insert(id.clone(), { debug!("Creating: '{}'", id); @@ -449,7 +449,7 @@ impl Store { let entry = try!({ self.entries .write() - .map_err(|_| SE::new(SEK::LockPoisoned, None)) + .map_err(|_| SE::from_kind(SEK::LockPoisoned)) .and_then(|mut es| { let new_se = try!(StoreEntry::new(id.clone(), &self.backend)); let se = es.entry(id.clone()).or_insert(new_se); @@ -457,7 +457,7 @@ impl Store { se.status = StoreEntryStatus::Borrowed; entry }) - .map_err_into(SEK::RetrieveCallError) + .chain_err(|| SEK::RetrieveCallError) }); debug!("Constructing FileLockEntry: '{}'", id); @@ -482,8 +482,8 @@ impl Store { let exists = try!(id.exists()) || try!(self.entries .read() .map(|map| map.contains_key(&id)) - .map_err(|_| SE::new(SEK::LockPoisoned, None)) - .map_err_into(SEK::GetCallError) + .map_err(|_| SE::from_kind(SEK::LockPoisoned)) + .chain_err(|| SEK::GetCallError) ); if !exists { @@ -491,7 +491,7 @@ impl Store { return Ok(None); } - self.retrieve(id).map(Some).map_err_into(SEK::GetCallError) + self.retrieve(id).map(Some).chain_err(|| SEK::GetCallError) } /// Iterate over all StoreIds for one module name @@ -512,15 +512,15 @@ impl Store { debug!("Retrieving for module: '{}'", mod_name); path.to_str() - .ok_or(SE::new(SEK::EncodingError, None)) + .ok_or(SE::from_kind(SEK::EncodingError)) .and_then(|path| { let path = [ path, "/**/*" ].join(""); debug!("glob()ing with '{}'", path); - glob(&path[..]).map_err_into(SEK::GlobError) + glob(&path[..]).chain_err(|| SEK::GlobError) }) .map(|paths| GlobStoreIdIterator::new(paths, self.path().clone()).into()) - .map_err_into(SEK::GlobError) - .map_err_into(SEK::RetrieveForModuleCallError) + .chain_err(|| SEK::GlobError) + .chain_err(|| SEK::RetrieveForModuleCallError) } /// Walk the store tree for the module @@ -538,7 +538,7 @@ impl Store { /// pub fn update<'a>(&'a self, entry: &mut FileLockEntry<'a>) -> Result<()> { debug!("Updating FileLockEntry at '{}'", entry.get_location()); - self._update(entry, false).map_err_into(SEK::UpdateCallError) + self._update(entry, false).chain_err(|| SEK::UpdateCallError) } /// Internal method to write to the filesystem store. @@ -560,11 +560,11 @@ impl Store { /// fn _update<'a>(&'a self, entry: &mut FileLockEntry<'a>, modify_presence: bool) -> Result<()> { let mut hsmap = match self.entries.write() { - Err(_) => return Err(SE::new(SEK::LockPoisoned, None)), + Err(_) => return Err(SE::from_kind(SEK::LockPoisoned)), Ok(e) => e, }; - let se = try!(hsmap.get_mut(&entry.location).ok_or(SE::new(SEK::IdNotFound, None))); + let se = try!(hsmap.get_mut(&entry.location).ok_or(SE::from_kind(SEK::IdNotFound))); assert!(se.is_borrowed(), "Tried to update a non borrowed entry."); @@ -597,15 +597,15 @@ impl Store { debug!("Retrieving copy of '{}'", id); let entries = match self.entries.write() { Err(_) => { - return Err(SE::new(SEK::LockPoisoned, None)) - .map_err_into(SEK::RetrieveCopyCallError); + return Err(SE::from_kind(SEK::LockPoisoned)) + .chain_err(|| SEK::RetrieveCopyCallError); }, Ok(e) => e, }; // if the entry is currently modified by the user, we cannot drop it if entries.get(&id).map(|e| e.is_borrowed()).unwrap_or(false) { - return Err(SE::new(SEK::IdLocked, None)).map_err_into(SEK::RetrieveCopyCallError); + return Err(SE::from_kind(SEK::IdLocked)).chain_err(|| SEK::RetrieveCopyCallError); } try!(StoreEntry::new(id, &self.backend)).get_entry() @@ -629,18 +629,18 @@ impl Store { { let mut entries = match self.entries.write() { - Err(_) => return Err(SE::new(SEK::LockPoisoned, None)) - .map_err_into(SEK::DeleteCallError), + Err(_) => return Err(SE::from_kind(SEK::LockPoisoned)) + .chain_err(|| SEK::DeleteCallError), Ok(e) => e, }; // if the entry is currently modified by the user, we cannot drop it match entries.get(&id) { None => { - return Err(SEK::FileNotFound.into_error()).map_err_into(SEK::DeleteCallError) + return Err(SEK::FileNotFound.into_error()).chain_err(|| SEK::DeleteCallError) }, Some(e) => if e.is_borrowed() { - return Err(SE::new(SEK::IdLocked, None)).map_err_into(SEK::DeleteCallError) + return Err(SE::from_kind(SEK::IdLocked)).chain_err(|| SEK::DeleteCallError) } } @@ -648,8 +648,9 @@ impl Store { entries.remove(&id); let pb = try!(id.clone().with_base(self.path().clone()).into_pathbuf()); if let Err(e) = self.backend.remove_file(&pb) { - return Err(SEK::FileError.into_error_with_cause(Box::new(e))) - .map_err_into(SEK::DeleteCallError); + return Err(e) + .chain_err(|| SEK::FileError) + .chain_err(|| SEK::DeleteCallError); } } @@ -678,11 +679,11 @@ impl Store { self.entries .write() .map_err(|_| SEK::LockPoisoned.into_error()) - .map_err_into(SEK::MoveCallError) + .chain_err(|| SEK::MoveCallError) ); if hsmap.contains_key(&new_id) { - return Err(SEK::EntryAlreadyExists.into_error()).map_err_into(SEK::MoveCallError) + return Err(SEK::EntryAlreadyExists.into_error()).chain_err(|| SEK::MoveCallError) } let old_id = entry.get_location().clone(); @@ -698,8 +699,8 @@ impl Store { Ok(()) } }) - .map_err_into(SEK::FileError) - .map_err_into(SEK::MoveCallError) + .chain_err(|| SEK::FileError) + .chain_err(|| SEK::MoveCallError) } /// Move an entry without loading @@ -743,26 +744,26 @@ impl Store { { let mut hsmap = match self.entries.write() { - Err(_) => return Err(SE::new(SEK::LockPoisoned, None)), + Err(_) => return Err(SE::from_kind(SEK::LockPoisoned)), Ok(m) => m, }; if hsmap.contains_key(&new_id) { - return Err(SEK::EntryAlreadyExists.into_error()); + return Err(SE::from_kind(SEK::EntryAlreadyExists)); } // if we do not have an entry here, we fail in `FileAbstraction::rename()` below. // if we have one, but it is borrowed, we really should not rename it, as this might // lead to strange errors if hsmap.get(&old_id).map(|e| e.is_borrowed()).unwrap_or(false) { - return Err(SEK::EntryAlreadyBorrowed.into_error()); + return Err(SE::from_kind(SEK::EntryAlreadyBorrowed)); } let old_id_pb = try!(old_id.clone().with_base(self.path().clone()).into_pathbuf()); let new_id_pb = try!(new_id.clone().with_base(self.path().clone()).into_pathbuf()); match self.backend.rename(&old_id_pb, &new_id_pb) { - Err(e) => return Err(SEK::EntryRenameError.into_error_with_cause(Box::new(e))), + Err(e) => return Err(e).chain_err(|| SEK::EntryRenameError), Ok(_) => { debug!("Rename worked on filesystem"); @@ -1035,7 +1036,7 @@ mod glob_store_iter { use storeid::StoreIdIterator; use error::StoreErrorKind as SEK; - use error::MapErrInto; + use error::ResultExt; use libimagerror::trace::trace_error; @@ -1088,7 +1089,7 @@ mod glob_store_iter { fn next(&mut self) -> Option { while let Some(o) = self.paths.next() { debug!("GlobStoreIdIterator::next() => {:?}", o); - match o.map_err_into(SEK::StoreIdHandlingError) { + match o.chain_err(|| SEK::StoreIdHandlingError) { Ok(path) => { if path.exists() && path.is_file() { return match StoreId::from_full_path(&self.store_path, path) { @@ -1121,7 +1122,7 @@ mod glob_store_iter { /// top-level Value::Table, but not on intermediate tables. pub trait Header { fn verify(&self) -> Result<()>; - fn parse(s: &str) -> RResult; + fn parse(s: &str) -> Result; fn default_header() -> Value; } @@ -1130,15 +1131,15 @@ impl Header for Value { fn verify(&self) -> Result<()> { match *self { Value::Table(ref t) => verify_header(&t), - _ => Err(SE::new(SEK::HeaderTypeFailure, None)), + _ => Err(SE::from_kind(SEK::HeaderTypeFailure)), } } - fn parse(s: &str) -> RResult { + fn parse(s: &str) -> Result { use toml::de::from_str; from_str(s) - .map_err(|_| ParserErrorKind::TOMLParserErrors.into()) + .chain_err(|| SEK::TOMLParserErrors) .and_then(verify_header_consistency) .map(Value::Table) } @@ -1160,21 +1161,18 @@ impl Header for Value { } -fn verify_header_consistency(t: Table) -> RResult { - verify_header(&t) - .map_err(Box::new) - .map_err(|e| ParserErrorKind::HeaderInconsistency.into_error_with_cause(e)) - .map(|_| t) +fn verify_header_consistency(t: Table) -> Result { + verify_header(&t).chain_err(|| SEK::HeaderInconsistency).map(|_| t) } fn verify_header(t: &Table) -> Result<()> { if !has_main_section(t) { - Err(SE::from(ParserErrorKind::MissingMainSection.into_error())) + Err(SE::from_kind(SEK::MissingMainSection)) } else if !has_imag_version_in_main_section(t) { - Err(SE::from(ParserErrorKind::MissingVersionInfo.into_error())) + Err(SE::from_kind(SEK::MissingVersionInfo)) } else if !has_only_tables(t) { debug!("Could not verify that it only has tables in its base table"); - Err(SE::from(ParserErrorKind::NonTableInBaseTable.into_error())) + Err(SE::from_kind(SEK::NonTableInBaseTable)) } else { Ok(()) } @@ -1518,7 +1516,7 @@ mod store_tests { for n in 1..100 { let s = format!("test-{}", n % 50); store.create(PathBuf::from(s.clone())) - .map_err(|e| assert!(is_match!(e.err_type(), SEK::CreateCallError) && n >= 50)) + .map_err(|e| assert!(is_match!(e.kind(), &SEK::CreateCallError) && n >= 50)) .ok() .map(|entry| { assert!(entry.verify().is_ok()); diff --git a/lib/core/libimagstore/src/storeid.rs b/lib/core/libimagstore/src/storeid.rs index 211efbe8..b26eb4ac 100644 --- a/lib/core/libimagstore/src/storeid.rs +++ b/lib/core/libimagstore/src/storeid.rs @@ -26,12 +26,13 @@ use std::fmt::Error as FmtError; use std::result::Result as RResult; use std::path::Components; -use libimagerror::into::IntoError; - use error::StoreErrorKind as SEK; -use error::MapErrInto; +use error::StoreError as SE; +use error::ResultExt; use store::Result; +use libimagerror::into::IntoError; + /// The Index into the Store #[derive(Debug, Clone, Hash, Eq, PartialOrd, Ord)] pub struct StoreId { @@ -61,7 +62,7 @@ impl StoreId { where D: Deref { let p = try!( - full_path.strip_prefix(store_part).map_err_into(SEK::StoreIdBuildFromFullPathError) + full_path.strip_prefix(store_part).chain_err(|| SEK::StoreIdBuildFromFullPathError) ); StoreId::new(Some(store_part.clone()), PathBuf::from(p)) } @@ -69,7 +70,7 @@ impl StoreId { pub fn new_baseless(id: PathBuf) -> Result { debug!("Trying to get a new baseless id from: {:?}", id); if id.is_absolute() { - Err(SEK::StoreIdLocalPartAbsoluteError.into_error()) + Err(SE::from_kind(SEK::StoreIdLocalPartAbsoluteError)) } else { Ok(StoreId { base: None, @@ -91,7 +92,7 @@ impl StoreId { /// Transform the StoreId object into a PathBuf, error if the base of the StoreId is not /// specified. pub fn into_pathbuf(self) -> Result { - let mut base = try!(self.base.ok_or(SEK::StoreIdHasNoBaseError.into_error())); + let mut base = try!(self.base.ok_or(SEK::StoreIdHasNoBaseError)); base.push(self.id); Ok(base) } @@ -347,7 +348,7 @@ mod test { let pb = id.unwrap().into_pathbuf(); assert!(pb.is_err()); - assert_eq!(pb.unwrap_err().err_type(), SEK::StoreIdHasNoBaseError); + assert!(is_match!(pb.unwrap_err().kind(), &SEK::StoreIdHasNoBaseError)); } #[test] diff --git a/lib/core/libimagstore/src/util.rs b/lib/core/libimagstore/src/util.rs index 97b7cb74..e77e8eb3 100644 --- a/lib/core/libimagstore/src/util.rs +++ b/lib/core/libimagstore/src/util.rs @@ -20,11 +20,10 @@ use regex::Regex; use toml::Value; -use libimagerror::into::IntoError; - use store::Result; use store::Header; use error::StoreErrorKind as SEK; +use error::StoreError as SE; #[cfg(feature = "early-panic")] #[macro_export] @@ -54,12 +53,12 @@ pub fn entry_buffer_to_header_content(buf: &str) -> Result<(Value, String)> { } let matches = match RE.captures(buf) { - None => return Err(SEK::MalformedEntry.into_error()), + None => return Err(SE::from_kind(SEK::MalformedEntry)), Some(s) => s, }; let header = match matches.name("header") { - None => return Err(SEK::MalformedEntry.into_error()), + None => return Err(SE::from_kind(SEK::MalformedEntry)), Some(s) => s }; From b6909a2c8676d024a3ba0fbe94d7117339748a4f Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 3 Sep 2017 14:38:46 +0200 Subject: [PATCH 07/32] libimagrt: Rewrite error handling --- lib/core/libimagrt/src/configuration.rs | 11 ++++----- lib/core/libimagrt/src/error.rs | 33 +++++++++++++++---------- lib/core/libimagrt/src/lib.rs | 2 +- lib/core/libimagrt/src/runtime.rs | 17 ++++++------- 4 files changed, 34 insertions(+), 29 deletions(-) diff --git a/lib/core/libimagrt/src/configuration.rs b/lib/core/libimagrt/src/configuration.rs index ef2fe267..3274e5c4 100644 --- a/lib/core/libimagrt/src/configuration.rs +++ b/lib/core/libimagrt/src/configuration.rs @@ -18,12 +18,13 @@ // use std::path::PathBuf; -use std::result::Result as RResult; use std::ops::Deref; use toml::Value; use clap::App; +use std::error::Error; + error_chain! { types { ConfigError, ConfigErrorKind, ResultExt, Result; @@ -57,7 +58,6 @@ error_chain! { } } -pub use self::error::{ConfigError, ConfigErrorKind, MapErrInto}; use libimagerror::into::IntoError; impl IntoError for ConfigErrorKind { @@ -67,7 +67,7 @@ impl IntoError for ConfigErrorKind { ConfigError::from_kind(self) } - fn into_error_with_cause(self, cause: Box) -> Self::Target { + fn into_error_with_cause(self, _: Box) -> Self::Target { ConfigError::from_kind(self) } } @@ -160,8 +160,7 @@ impl Configuration { pub fn override_config(&mut self, v: Vec) -> Result<()> { use libimagutil::key_value_split::*; use libimagutil::iter::*; - use self::error::ConfigErrorKind as CEK; - use self::error::MapErrInto; + use self::ConfigErrorKind as CEK; use libimagerror::into::IntoError; use toml_query::read::TomlValueReadExt; @@ -178,7 +177,7 @@ impl Configuration { .map(|(k, v)| self .config .read(&k[..]) - .map_err_into(CEK::TOMLParserError) + .chain_err(|| CEK::TOMLParserError) .map(|toml| match toml { Some(value) => match into_value(value, v) { Some(v) => { diff --git a/lib/core/libimagrt/src/error.rs b/lib/core/libimagrt/src/error.rs index 388335af..69055197 100644 --- a/lib/core/libimagrt/src/error.rs +++ b/lib/core/libimagrt/src/error.rs @@ -17,20 +17,27 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -generate_error_imports!(); -use std::io::Error as IOError; - -generate_error_types!(RuntimeError, RuntimeErrorKind, - Instantiate => "Could not instantiate", - IOError => "IO Error", - ProcessExitFailure => "Process exited with failure" -); - -impl From for RuntimeError { - - fn from(ioe: IOError) -> RuntimeError { - RuntimeErrorKind::IOError.into_error_with_cause(Box::new(ioe)) +error_chain! { + types { + RuntimeError, RuntimeErrorKind, ResultExt, Result; } + errors { + Instantiate { + description("Could not instantiate") + display("Could not instantiate") + } + + IOError { + description("IO Error") + display("IO Error") + } + + ProcessExitFailure { + description("Process exited with failure") + display("Process exited with failure") + } + + } } diff --git a/lib/core/libimagrt/src/lib.rs b/lib/core/libimagrt/src/lib.rs index da098517..ed69f58d 100644 --- a/lib/core/libimagrt/src/lib.rs +++ b/lib/core/libimagrt/src/lib.rs @@ -49,7 +49,7 @@ extern crate toml_query; extern crate libimagstore; extern crate libimagutil; -#[macro_use] extern crate libimagerror; +extern crate libimagerror; pub mod error; pub mod configuration; diff --git a/lib/core/libimagrt/src/runtime.rs b/lib/core/libimagrt/src/runtime.rs index dcdd8e1b..d0bbdf94 100644 --- a/lib/core/libimagrt/src/runtime.rs +++ b/lib/core/libimagrt/src/runtime.rs @@ -61,9 +61,8 @@ impl<'a> Runtime<'a> { where C: Clone + CliSpec<'a> + InternalConfiguration { use libimagerror::trace::trace_error; - use libimagerror::into::IntoError; - use configuration::error::ConfigErrorKind; + use configuration::ConfigErrorKind; let matches = cli_app.clone().matches(); @@ -75,8 +74,8 @@ impl<'a> Runtime<'a> { debug!("Config path = {:?}", configpath); let config = match Configuration::new(&configpath) { - Err(e) => if e.err_type() != ConfigErrorKind::NoConfigFileFound { - return Err(RuntimeErrorKind::Instantiate.into_error_with_cause(Box::new(e))); + Err(e) => if !is_match!(e.kind(), &ConfigErrorKind::NoConfigFileFound) { + return Err(e).chain_err(|| RuntimeErrorKind::Instantiate); } else { warn!("No config file found."); warn!("Continuing without configuration file"); @@ -172,7 +171,7 @@ impl<'a> Runtime<'a> { store: store, } }) - .map_err_into(RuntimeErrorKind::Instantiate) + .chain_err(|| RuntimeErrorKind::Instantiate) } /// @@ -388,11 +387,11 @@ impl<'a> Runtime<'a> { let mapper = JsonMapper::new(); StdIoFileAbstraction::new(&mut input, output, mapper) - .map_err_into(RuntimeErrorKind::Instantiate) + .chain_err(|| RuntimeErrorKind::Instantiate) .and_then(|backend| { self.store .reset_backend(Box::new(backend)) - .map_err_into(RuntimeErrorKind::Instantiate) + .chain_err(|| RuntimeErrorKind::Instantiate) }) } @@ -407,11 +406,11 @@ impl<'a> Runtime<'a> { let mapper = JsonMapper::new(); StdoutFileAbstraction::new(output, mapper) - .map_err_into(RuntimeErrorKind::Instantiate) + .chain_err(|| RuntimeErrorKind::Instantiate) .and_then(|backend| { self.store .reset_backend(Box::new(backend)) - .map_err_into(RuntimeErrorKind::Instantiate) + .chain_err(|| RuntimeErrorKind::Instantiate) }) } From ac34b4ee66d130f187ef2fc603563cb7dc17a5f3 Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 3 Sep 2017 14:43:02 +0200 Subject: [PATCH 08/32] libimaginteraction: Rewrite error handling --- lib/etc/libimaginteraction/src/ask.rs | 4 ++-- lib/etc/libimaginteraction/src/error.rs | 10 +++++----- lib/etc/libimaginteraction/src/lib.rs | 2 +- lib/etc/libimaginteraction/src/ui.rs | 12 ++++++------ 4 files changed, 14 insertions(+), 14 deletions(-) diff --git a/lib/etc/libimaginteraction/src/ask.rs b/lib/etc/libimaginteraction/src/ask.rs index 2a393d0e..475a2f0d 100644 --- a/lib/etc/libimaginteraction/src/ask.rs +++ b/lib/etc/libimaginteraction/src/ask.rs @@ -24,8 +24,8 @@ use std::io::BufRead; use std::io::BufReader; use std::result::Result as RResult; -use error::InteractionError; use error::InteractionErrorKind; +use error::ResultExt; use result::Result; use regex::Regex; @@ -163,7 +163,7 @@ fn ask_string_(s: &str, pub fn ask_select_from_list(list: &[&str]) -> Result { pick_from_list(default_menu_cmd().as_mut(), list, "Selection: ") - .map_err(|e| InteractionError::new(InteractionErrorKind::Unknown, Some(Box::new(e)))) + .chain_err(|| InteractionErrorKind::Unknown) } /// Helper function to print a imag question string. The `question` argument may not contain a diff --git a/lib/etc/libimaginteraction/src/error.rs b/lib/etc/libimaginteraction/src/error.rs index 271bf832..e5daf160 100644 --- a/lib/etc/libimaginteraction/src/error.rs +++ b/lib/etc/libimaginteraction/src/error.rs @@ -17,6 +17,10 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +use std::error::Error; + +use libimagerror::into::IntoError; + error_chain! { types { InteractionError, InteractionErrorKind, ResultExt, Result; @@ -81,10 +85,6 @@ error_chain! { } } -pub use self::error::InteractionError; -pub use self::error::InteractionErrorKind; -pub use self::error::MapErrInto; - impl IntoError for InteractionErrorKind { type Target = InteractionError; @@ -92,7 +92,7 @@ impl IntoError for InteractionErrorKind { InteractionError::from_kind(self) } - fn into_error_with_cause(self, cause: Box) -> Self::Target { + fn into_error_with_cause(self, _: Box) -> Self::Target { InteractionError::from_kind(self) } } diff --git a/lib/etc/libimaginteraction/src/lib.rs b/lib/etc/libimaginteraction/src/lib.rs index ae78b8c8..36f9a04d 100644 --- a/lib/etc/libimaginteraction/src/lib.rs +++ b/lib/etc/libimaginteraction/src/lib.rs @@ -44,7 +44,7 @@ extern crate toml; #[macro_use] extern crate error_chain; extern crate libimagstore; -#[macro_use] extern crate libimagerror; +extern crate libimagerror; pub mod ask; pub mod error; diff --git a/lib/etc/libimaginteraction/src/ui.rs b/lib/etc/libimaginteraction/src/ui.rs index 49c4619d..0a5335b9 100644 --- a/lib/etc/libimaginteraction/src/ui.rs +++ b/lib/etc/libimaginteraction/src/ui.rs @@ -25,8 +25,8 @@ use libimagstore::storeid::StoreId; use libimagerror::into::IntoError; use result::Result; -use error::MapErrInto; use error::InteractionErrorKind as IEK; +use error::ResultExt; pub fn id_argument<'a, 'b>() -> Arg<'a, 'b> { Arg::with_name(id_argument_name()) @@ -53,13 +53,13 @@ pub fn get_id(matches: &ArgMatches) -> Result> { matches .values_of(id_argument_name()) .ok_or(IEK::IdMissingError.into_error()) - .map_err_into(IEK::CLIError) + .chain_err(|| IEK::CLIError) .and_then(|vals| { vals.into_iter() .fold(Ok(vec![]), |acc, elem| { acc.and_then(|mut v| { let elem = StoreId::new_baseless(PathBuf::from(String::from(elem))); - let elem = try!(elem.map_err_into(IEK::StoreIdParsingError)); + let elem = try!(elem.chain_err(|| IEK::StoreIdParsingError)); v.push(elem); Ok(v) }) @@ -70,12 +70,12 @@ pub fn get_id(matches: &ArgMatches) -> Result> { pub fn get_or_select_id(matches: &ArgMatches, store_path: &PathBuf) -> Result> { use interactor::{pick_file, default_menu_cmd}; - match get_id(matches).map_err_into(IEK::IdSelectingError) { + match get_id(matches).chain_err(|| IEK::IdSelectingError) { Ok(v) => Ok(v), Err(_) => { let path = store_path.clone(); - let p = try!(pick_file(default_menu_cmd, path).map_err_into(IEK::IdSelectingError)); - let id = try!(StoreId::new_baseless(p).map_err_into(IEK::StoreIdParsingError)); + let p = try!(pick_file(default_menu_cmd, path).chain_err(|| IEK::IdSelectingError)); + let id = try!(StoreId::new_baseless(p).chain_err(|| IEK::StoreIdParsingError)); Ok(vec![id]) }, } From ca0dd5906da87f9a049a6c3fd08035abfb4ded0b Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 3 Sep 2017 15:01:38 +0200 Subject: [PATCH 09/32] libimagentrylink: Rewrite error handling --- lib/entry/libimagentrylink/src/error.rs | 25 +++- lib/entry/libimagentrylink/src/external.rs | 26 ++-- lib/entry/libimagentrylink/src/internal.rs | 133 +++++---------------- lib/entry/libimagentrylink/src/lib.rs | 2 +- 4 files changed, 63 insertions(+), 123 deletions(-) diff --git a/lib/entry/libimagentrylink/src/error.rs b/lib/entry/libimagentrylink/src/error.rs index d9bf3db2..515ead11 100644 --- a/lib/entry/libimagentrylink/src/error.rs +++ b/lib/entry/libimagentrylink/src/error.rs @@ -17,6 +17,11 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +use std::error::Error; + +use libimagerror::into::IntoError; +use libimagstore::storeid::StoreId; + error_chain! { types { LinkError, LinkErrorKind, ResultExt, Result; @@ -83,13 +88,23 @@ error_chain! { display("StoreId handling error") } + DeadLink(from: StoreId, to: StoreId) { + description("Dead link") + display("Dead link from: {from} to: {to}", from = from, to = to) + } + + LinkHandlingError { + description("Error in link handling") + display("Error in link handling") + } + + StoreError { + description("Error while talking to the store") + display("Error while talking to the store") + } } } -pub use self::error::LinkError; -pub use self::error::LinkErrorKind; -pub use self::error::MapErrInto; - impl IntoError for LinkErrorKind { type Target = LinkError; @@ -97,7 +112,7 @@ impl IntoError for LinkErrorKind { LinkError::from_kind(self) } - fn into_error_with_cause(self, cause: Box) -> Self::Target { + fn into_error_with_cause(self, _: Box) -> Self::Target { LinkError::from_kind(self) } } diff --git a/lib/entry/libimagentrylink/src/external.rs b/lib/entry/libimagentrylink/src/external.rs index 75fb6451..642f3cdc 100644 --- a/lib/entry/libimagentrylink/src/external.rs +++ b/lib/entry/libimagentrylink/src/external.rs @@ -34,6 +34,7 @@ use std::ops::DerefMut; use std::collections::BTreeMap; use std::fmt::Debug; +use libimagerror::into::IntoError; use libimagstore::store::Entry; use libimagstore::store::FileLockEntry; use libimagstore::store::Store; @@ -44,12 +45,11 @@ use libimagutil::debug_result::*; use toml_query::read::TomlValueReadExt; use toml_query::set::TomlValueSetExt; -use error::LinkError as LE; use error::LinkErrorKind as LEK; -use error::MapErrInto; use result::Result; use internal::InternalLinker; use module_path::ModuleEntryPath; +use error::ResultExt; use self::iter::*; @@ -92,10 +92,10 @@ impl<'a> Link<'a> { Ok(Some(&Value::String(ref s))) => { Url::parse(&s[..]) .map(Some) - .map_err(|e| LE::new(LEK::EntryHeaderReadError, Some(Box::new(e)))) + .chain_err(|| LEK::EntryHeaderReadError) }, Ok(None) => Ok(None), - _ => Err(LE::new(LEK::EntryHeaderReadError, None)) + _ => Err(LEK::EntryHeaderReadError.into_error()) } } @@ -136,7 +136,7 @@ pub mod iter { use internal::Link; use internal::iter::LinkIter; use error::LinkErrorKind as LEK; - use error::MapErrInto; + use error::ResultExt; use result::Result; use url::Url; @@ -269,7 +269,7 @@ pub mod iter { debug!("Retrieving entry for id: '{:?}'", id); self.1 .retrieve(id.clone()) - .map_err_into(LEK::StoreReadError) + .chain_err(|| LEK::StoreReadError) .map_dbg_err(|_| format!("Retrieving entry for id: '{:?}' failed", id)) .and_then(|f| { debug!("Store::retrieve({:?}) succeeded", id); @@ -293,7 +293,7 @@ pub fn is_external_link_storeid + Debug>(id: A) -> bool { fn get_external_link_from_file(entry: &FileLockEntry) -> Result { Link::get_link_uri_from_filelockentry(entry) // TODO: Do not hide error by using this function - .ok_or(LE::new(LEK::StoreReadError, None)) + .ok_or(LEK::StoreReadError.into_error()) } /// Implement `ExternalLinker` for `Entry`, hiding the fact that there is no such thing as an external @@ -307,7 +307,7 @@ impl ExternalLinker for Entry { // /link/external/ -> load these files and get the external link from their headers, // put them into the return vector. self.get_internal_links() - .map_err(|e| LE::new(LEK::StoreReadError, Some(Box::new(e)))) + .chain_err(|| LEK::StoreReadError) .map(|iter| { debug!("Getting external links"); iter.only_external_links().urls(store) @@ -329,7 +329,7 @@ impl ExternalLinker for Entry { }; let file_id = try!( ModuleEntryPath::new(format!("external/{}", hash)).into_storeid() - .map_err_into(LEK::StoreWriteError) + .chain_err(|| LEK::StoreWriteError) .map_dbg_err(|_| { format!("Failed to build StoreId for this hash '{:?}'", hash) }) @@ -343,7 +343,7 @@ impl ExternalLinker for Entry { // exist let mut file = try!(store .retrieve(file_id.clone()) - .map_err_into(LEK::StoreWriteError) + .chain_err(|| LEK::StoreWriteError) .map_dbg_err(|_| { format!("Failed to create or retrieve an file for this link '{:?}'", link) })); @@ -360,7 +360,7 @@ impl ExternalLinker for Entry { BTreeMap::new() }, Ok(None) => BTreeMap::new(), - Err(e) => return Err(LE::new(LEK::StoreWriteError, Some(Box::new(e)))), + Err(e) => return Err(e).chain_err(|| LEK::StoreWriteError), }; let v = Value::String(link.into_string()); @@ -369,7 +369,7 @@ impl ExternalLinker for Entry { table.insert(String::from("url"), v); if let Err(e) = hdr.set("imag.content", Value::Table(table)) { - return Err(LE::new(LEK::StoreWriteError, Some(Box::new(e)))); + return Err(e).chain_err(|| LEK::StoreWriteError); } else { debug!("Setting URL worked"); } @@ -378,7 +378,7 @@ impl ExternalLinker for Entry { // then add an internal link to the new file or return an error if this fails if let Err(e) = self.add_internal_link(file.deref_mut()) { debug!("Error adding internal link"); - return Err(LE::new(LEK::StoreWriteError, Some(Box::new(e)))); + return Err(e).chain_err(|| LEK::StoreWriteError); } } debug!("Ready iterating"); diff --git a/lib/entry/libimagentrylink/src/internal.rs b/lib/entry/libimagentrylink/src/internal.rs index 8e33d8d8..77c1c088 100644 --- a/lib/entry/libimagentrylink/src/internal.rs +++ b/lib/entry/libimagentrylink/src/internal.rs @@ -31,7 +31,7 @@ use toml_query::read::TomlValueReadExt; use toml_query::set::TomlValueSetExt; use error::LinkErrorKind as LEK; -use error::MapErrInto; +use error::ResultExt; use result::Result; use self::iter::LinkIter; use self::iter::IntoValues; @@ -51,7 +51,7 @@ impl Link { Link::Id { ref link } => link.exists(), Link::Annotated { ref link, .. } => link.exists(), } - .map_err_into(LEK::StoreIdError) + .chain_err(|| LEK::StoreIdError) } pub fn to_str(&self) -> Result { @@ -59,7 +59,7 @@ impl Link { Link::Id { ref link } => link.to_str(), Link::Annotated { ref link, .. } => link.to_str(), } - .map_err_into(LEK::StoreReadError) + .chain_err(|| LEK::StoreReadError) } @@ -100,11 +100,11 @@ impl Link { fn to_value(&self) -> Result { match self { &Link::Id { link: ref s } => - s.to_str().map(Value::String).map_err_into(LEK::InternalConversionError), + s.to_str().map(Value::String).chain_err(|| LEK::InternalConversionError), &Link::Annotated { ref link, annotation: ref anno } => { link.to_str() .map(Value::String) - .map_err_into(LEK::InternalConversionError) + .chain_err(|| LEK::InternalConversionError) .map(|link| { let mut tab = BTreeMap::new(); @@ -187,7 +187,7 @@ pub mod iter { use super::Link; use error::LinkErrorKind as LEK; - use error::MapErrInto; + use error::ResultExt; use result::Result; use toml::Value; @@ -228,7 +228,7 @@ pub mod iter { .unique() .sorted() .into_iter() // Cannot sort toml::Value, hence uglyness here - .map(|link| link.to_value().map_err_into(LEK::InternalConversionError)) + .map(|link| link.to_value().chain_err(|| LEK::InternalConversionError)) .collect() } } @@ -288,7 +288,7 @@ pub mod iter { type Item = Result>; fn next(&mut self) -> Option { - self.0.next().and_then(|id| match self.1.get(id).map_err_into(LEK::StoreReadError) { + self.0.next().and_then(|id| match self.1.get(id).chain_err(|| LEK::StoreReadError) { Ok(None) => None, Ok(Some(x)) => Some(Ok(x)), Err(e) => Some(Err(e)), @@ -318,7 +318,7 @@ pub mod iter { loop { match self.0.next() { Some(Ok(fle)) => { - let links = match fle.get_internal_links().map_err_into(LEK::StoreReadError) + let links = match fle.get_internal_links().chain_err(|| LEK::StoreReadError) { Err(e) => return Some(Err(e)), Ok(links) => links.collect::>(), @@ -358,7 +358,7 @@ pub mod iter { loop { match self.0.next() { Some(Ok(fle)) => { - let links = match fle.get_internal_links().map_err_into(LEK::StoreReadError) + let links = match fle.get_internal_links().chain_err(|| LEK::StoreReadError) { Err(e) => return Some(Err(e)), Ok(links) => links, @@ -367,7 +367,7 @@ pub mod iter { match self.0 .store() .delete(fle.get_location().clone()) - .map_err_into(LEK::StoreWriteError) + .chain_err(|| LEK::StoreWriteError) { Ok(x) => x, Err(e) => return Some(Err(e)), @@ -393,7 +393,7 @@ impl InternalLinker for Entry { let res = self .get_header() .read("imag.links") - .map_err_into(LEK::EntryHeaderReadError) + .chain_err(|| LEK::EntryHeaderReadError) .map(|r| r.cloned()); process_rw_result(res) } @@ -417,7 +417,7 @@ impl InternalLinker for Entry { .into_iter() .fold(Ok(vec![]), |acc, elem| { acc.and_then(move |mut v| { - elem.map_err_into(LEK::InternalConversionError) + elem.chain_err(|| LEK::InternalConversionError) .map(|e| { v.push(e); v @@ -427,7 +427,7 @@ impl InternalLinker for Entry { let res = self .get_header_mut() .set("imag.links", Value::Array(new_links)) - .map_err_into(LEK::EntryHeaderReadError); + .chain_err(|| LEK::EntryHeaderReadError); process_rw_result(res) } @@ -487,7 +487,7 @@ fn rewrite_links>(header: &mut Value, links: I) -> Resu .into_iter() .fold(Ok(vec![]), |acc, elem| { acc.and_then(move |mut v| { - elem.map_err_into(LEK::InternalConversionError) + elem.chain_err(|| LEK::InternalConversionError) .map(|e| { v.push(e); v @@ -498,7 +498,7 @@ fn rewrite_links>(header: &mut Value, links: I) -> Resu debug!("Setting new link array: {:?}", links); let process = header .set("imag.links", Value::Array(links)) - .map_err_into(LEK::EntryHeaderReadError); + .chain_err(|| LEK::EntryHeaderReadError); process_rw_result(process).map(|_| ()) } @@ -514,7 +514,7 @@ fn add_foreign_link(target: &mut Entry, from: StoreId) -> Result<()> { .into_iter() .fold(Ok(vec![]), |acc, elem| { acc.and_then(move |mut v| { - elem.map_err_into(LEK::InternalConversionError) + elem.chain_err(|| LEK::InternalConversionError) .map(|e| { v.push(e); v @@ -526,7 +526,7 @@ fn add_foreign_link(target: &mut Entry, from: StoreId) -> Result<()> { let res = target .get_header_mut() .set("imag.links", Value::Array(links)) - .map_err_into(LEK::EntryHeaderReadError); + .chain_err(|| LEK::EntryHeaderReadError); process_rw_result(res).map(|_| ()) }) @@ -562,7 +562,7 @@ fn process_rw_result(links: Result>) -> Result { debug!("Matching the link: {:?}", link); match link { Value::String(s) => StoreId::new_baseless(PathBuf::from(s)) - .map_err_into(LEK::StoreIdError) + .chain_err(|| LEK::StoreIdError) .map(|s| Link::Id { link: s }) , Value::Table(mut tab) => { @@ -582,7 +582,7 @@ fn process_rw_result(links: Result>) -> Result { match (link, anno) { (Value::String(link), Value::String(anno)) => { StoreId::new_baseless(PathBuf::from(link)) - .map_err_into(LEK::StoreIdError) + .chain_err(|| LEK::StoreIdError) .map(|link| { Link::Annotated { link: link, @@ -605,68 +605,8 @@ fn process_rw_result(links: Result>) -> Result { pub mod store_check { use libimagstore::store::Store; - - pub mod error { - generate_error_imports!(); - - use libimagstore::storeid::StoreId; - - #[derive(Debug)] - pub enum StoreLinkConsistencyErrorCustomData { - DeadLink { - target: StoreId - }, - OneDirectionalLink { - source: StoreId, - target: StoreId - }, - } - - impl Display for StoreLinkConsistencyErrorCustomData { - - fn fmt(&self, fmt: &mut Formatter) -> Result<(), FmtError> { - use self::StoreLinkConsistencyErrorCustomData as SLCECD; - match self { - &SLCECD::DeadLink { ref target } => { - try!(write!(fmt, "Dead Link to '{}'", target)) - }, - - &SLCECD::OneDirectionalLink { ref source, ref target } => { - try!(write!(fmt, - "Link from '{}' to '{}' does exist, but not other way round", - source, target)) - } - }; - Ok(()) - } - - } - - generate_custom_error_types!( - StoreLinkConsistencyError, - StoreLinkConsistencyErrorKind, - StoreLinkConsistencyErrorCustomData, - StoreLinkConsistencyError => "Links in the store are not consistent", - LinkHandlingError => "Error in link handling", - StoreError => "Error while talking to the store" - ); - - generate_result_helper!(StoreLinkConsistencyError, StoreLinkConsistencyErrorKind); - generate_option_helper!(StoreLinkConsistencyError, StoreLinkConsistencyErrorKind); - } - - pub use self::error::StoreLinkConsistencyError; - pub use self::error::StoreLinkConsistencyErrorKind; - pub use self::error::MapErrInto; - - pub mod result { - use std::result::Result as RResult; - use internal::store_check::error::StoreLinkConsistencyError as SLCE; - - pub type Result = RResult; - } - - use self::result::Result; + use error::Result; + use error::ResultExt; pub trait StoreLinkConsistentExt { fn check_link_consistency(&self) -> Result<()>; @@ -676,10 +616,8 @@ pub mod store_check { fn check_link_consistency(&self) -> Result<()> { use std::collections::HashMap; - use self::error::StoreLinkConsistencyErrorKind as SLCEK; - use self::error::StoreLinkConsistencyError as SLCE; - use self::error::StoreLinkConsistencyErrorCustomData as SLCECD; use error::LinkErrorKind as LEK; + use error::LinkError as LE; use result::Result as LResult; use internal::InternalLinker; @@ -714,7 +652,7 @@ pub mod store_check { acc.and_then(|mut state| { debug!("Checking entry: '{}'", sid); - match try!(self.get(sid).map_err_into(SLCEK::StoreError)) { + match try!(self.get(sid).chain_err(|| LEK::StoreError)) { Some(fle) => { debug!("Found FileLockEntry"); @@ -722,7 +660,7 @@ pub mod store_check { let internal_links = fle .get_internal_links() - .map_err_into(SLCEK::StoreError)? + .chain_err(|| LEK::StoreError)? .into_getter(self) // get the FLEs from the Store .trace_unwrap(); // trace all Err(e)s and get the Ok(fle)s @@ -765,12 +703,7 @@ pub mod store_check { if is_match!(self.get(id.clone()), Ok(Some(_))) { debug!("Exists in store: {:?}", id); - let exists = { - use error::MapErrInto as MEI; - try!(MEI::map_err_into(id.exists(), LEK::StoreReadError)) - }; - - if !exists { + if !try!(id.exists().chain_err(|| LEK::StoreReadError)) { warn!("Does exist in store but not on FS: {:?}", id); Err(LEK::LinkTargetDoesNotExist.into_error()) } else { @@ -785,16 +718,8 @@ pub mod store_check { /// Helper function to create a SLCECD::OneDirectionalLink error object #[inline] - let mk_one_directional_link_err = |src: StoreId, target: StoreId| -> SLCE { - // construct the error - let custom = SLCECD::OneDirectionalLink { - source: src, - target: target, - }; - - SLCEK::StoreLinkConsistencyError - .into_error() - .with_custom_data(custom) + let mk_one_directional_link_err = |src: StoreId, target: StoreId| -> LE { + LEK::DeadLink(src, target).into_error() }; /// Helper lambda to check whether the _incoming_ links of each entry actually also @@ -847,7 +772,7 @@ pub mod store_check { .and_then(|nw| { all_collected_storeids_exist(&nw) .map(|_| nw) - .map_err_into(SLCEK::LinkHandlingError) + .chain_err(|| LEK::LinkHandlingError) }) .and_then(|nw| { nw.iter().fold_result(|(id, linking)| { diff --git a/lib/entry/libimagentrylink/src/lib.rs b/lib/entry/libimagentrylink/src/lib.rs index 170d5668..780cf351 100644 --- a/lib/entry/libimagentrylink/src/lib.rs +++ b/lib/entry/libimagentrylink/src/lib.rs @@ -48,7 +48,7 @@ extern crate crypto; extern crate env_logger; #[macro_use] extern crate libimagstore; -#[macro_use] extern crate libimagerror; +extern crate libimagerror; extern crate libimagutil; module_entry_path_mod!("links"); From 4b4b0b0804cabdd81d0a8341aa520bc4d5e2fa0f Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 3 Sep 2017 15:03:52 +0200 Subject: [PATCH 10/32] libimagentryedit: Rewrite error handling --- lib/entry/libimagentryedit/src/edit.rs | 4 ++-- lib/entry/libimagentryedit/src/error.rs | 10 +++++----- lib/entry/libimagentryedit/src/lib.rs | 2 +- 3 files changed, 8 insertions(+), 8 deletions(-) diff --git a/lib/entry/libimagentryedit/src/edit.rs b/lib/entry/libimagentryedit/src/edit.rs index cbd17733..0e5900a2 100644 --- a/lib/entry/libimagentryedit/src/edit.rs +++ b/lib/entry/libimagentryedit/src/edit.rs @@ -23,7 +23,7 @@ use libimagstore::store::Entry; use result::Result; use error::EditErrorKind; -use error::MapErrInto; +use error::ResultExt; pub trait Edit { fn edit_content(&mut self, rt: &Runtime) -> Result<()>; @@ -53,7 +53,7 @@ pub fn edit_in_tmpfile(rt: &Runtime, s: &mut String) -> Result<()> { .ok_or(EditErrorKind::NoEditor.into_error()) .and_then(|editor| { edit_in_tmpfile_with_command(editor, s) - .map_err_into(EditErrorKind::IOError) + .chain_err(|| EditErrorKind::IOError) .and_then(|worked| { if !worked { Err(EditErrorKind::ProcessExitFailure.into()) diff --git a/lib/entry/libimagentryedit/src/error.rs b/lib/entry/libimagentryedit/src/error.rs index a37c7e80..2bc81b19 100644 --- a/lib/entry/libimagentryedit/src/error.rs +++ b/lib/entry/libimagentryedit/src/error.rs @@ -17,6 +17,10 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +use std::error::Error; + +use libimagerror::into::IntoError; + error_chain! { types { EditError, EditErrorKind, ResultExt, Result; @@ -46,10 +50,6 @@ error_chain! { } } -pub use self::error::EditError; -pub use self::error::EditErrorKind; -pub use self::error::MapErrInto; - impl IntoError for EditErrorKind { type Target = EditError; @@ -57,7 +57,7 @@ impl IntoError for EditErrorKind { EditError::from_kind(self) } - fn into_error_with_cause(self, cause: Box) -> Self::Target { + fn into_error_with_cause(self, _: Box) -> Self::Target { EditError::from_kind(self) } } diff --git a/lib/entry/libimagentryedit/src/lib.rs b/lib/entry/libimagentryedit/src/lib.rs index ca054538..6776476f 100644 --- a/lib/entry/libimagentryedit/src/lib.rs +++ b/lib/entry/libimagentryedit/src/lib.rs @@ -35,7 +35,7 @@ while_true, )] -#[macro_use] extern crate libimagerror; +extern crate libimagerror; extern crate libimagstore; extern crate libimagrt; extern crate libimagutil; From 9aa5d7439d864aeeb9667f08f3d83eb60605cffa Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 3 Sep 2017 15:10:11 +0200 Subject: [PATCH 11/32] libimagentrylist: Rewrite error handling --- lib/entry/libimagentrylist/src/cli.rs | 5 +++-- lib/entry/libimagentrylist/src/error.rs | 10 +++++----- lib/entry/libimagentrylist/src/lib.rs | 2 +- .../libimagentrylist/src/listers/core.rs | 4 ++-- .../libimagentrylist/src/listers/line.rs | 4 ++-- .../libimagentrylist/src/listers/path.rs | 19 ++++--------------- .../libimagentrylist/src/listers/table.rs | 4 ++-- 7 files changed, 19 insertions(+), 29 deletions(-) diff --git a/lib/entry/libimagentrylist/src/cli.rs b/lib/entry/libimagentrylist/src/cli.rs index b52a92fd..4b94d3bb 100644 --- a/lib/entry/libimagentrylist/src/cli.rs +++ b/lib/entry/libimagentrylist/src/cli.rs @@ -20,12 +20,13 @@ use clap::{Arg, ArgMatches, App, SubCommand}; use libimagstore::store::FileLockEntry; +use libimagerror::into::IntoError; use result::Result; use listers::line::LineLister; use listers::path::PathLister; use lister::Lister; -use error::{ListError, ListErrorKind}; +use error::ListErrorKind; pub fn build_list_cli_component<'a, 'b>() -> App<'a, 'b> { SubCommand::with_name(list_subcommand_name()) @@ -96,6 +97,6 @@ pub fn list_entries_with_lister<'a, I>(m: &ArgMatches, entries: I) -> Result<()> Ok(()) } else { - Err(ListError::new(ListErrorKind::CLIError, None)) + Err(ListErrorKind::CLIError.into_error()) } } diff --git a/lib/entry/libimagentrylist/src/error.rs b/lib/entry/libimagentrylist/src/error.rs index fd5aea59..f45ad46d 100644 --- a/lib/entry/libimagentrylist/src/error.rs +++ b/lib/entry/libimagentrylist/src/error.rs @@ -17,6 +17,10 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +use std::error::Error; + +use libimagerror::into::IntoError; + error_chain! { types { ListError, ListErrorKind, ResultExt, Result; @@ -51,10 +55,6 @@ error_chain! { } } -pub use self::error::ListError; -pub use self::error::ListErrorKind; -pub use self::error::MapErrInto; - impl IntoError for ListErrorKind { type Target = ListError; @@ -62,7 +62,7 @@ impl IntoError for ListErrorKind { ListError::from_kind(self) } - fn into_error_with_cause(self, cause: Box) -> Self::Target { + fn into_error_with_cause(self, _: Box) -> Self::Target { ListError::from_kind(self) } } diff --git a/lib/entry/libimagentrylist/src/lib.rs b/lib/entry/libimagentrylist/src/lib.rs index de83b60b..7d779d73 100644 --- a/lib/entry/libimagentrylist/src/lib.rs +++ b/lib/entry/libimagentrylist/src/lib.rs @@ -42,7 +42,7 @@ extern crate prettytable; extern crate libimagstore; extern crate libimagutil; -#[macro_use] extern crate libimagerror; +extern crate libimagerror; pub mod cli; pub mod error; diff --git a/lib/entry/libimagentrylist/src/listers/core.rs b/lib/entry/libimagentrylist/src/listers/core.rs index 733ba719..74a99f47 100644 --- a/lib/entry/libimagentrylist/src/listers/core.rs +++ b/lib/entry/libimagentrylist/src/listers/core.rs @@ -22,6 +22,7 @@ use std::io::Write; use lister::Lister; use result::Result; +use error::ResultExt; use libimagstore::store::FileLockEntry; use libimagstore::store::Entry; @@ -43,7 +44,6 @@ impl String> CoreLister { impl String> Lister for CoreLister { fn list<'b, I: Iterator>>(&self, entries: I) -> Result<()> { - use error::ListError as LE; use error::ListErrorKind as LEK; debug!("Called list()"); @@ -53,7 +53,7 @@ impl String> Lister for CoreLister { let r = accu.and_then(|_| { debug!("Listing Entry: {:?}", entry); write!(stdout(), "{:?}\n", (self.lister)(&entry)) - .map_err(|e| LE::new(LEK::FormatError, Some(Box::new(e)))) + .chain_err(|| LEK::FormatError) }); (r, i + 1) }); diff --git a/lib/entry/libimagentrylist/src/listers/line.rs b/lib/entry/libimagentrylist/src/listers/line.rs index 8c439934..d61b8da3 100644 --- a/lib/entry/libimagentrylist/src/listers/line.rs +++ b/lib/entry/libimagentrylist/src/listers/line.rs @@ -22,6 +22,7 @@ use std::io::Write; use lister::Lister; use result::Result; +use error::ResultExt; use libimagstore::store::FileLockEntry; use libimagutil::iter::FoldResult; @@ -43,12 +44,11 @@ impl<'a> LineLister<'a> { impl<'a> Lister for LineLister<'a> { fn list<'b, I: Iterator>>(&self, entries: I) -> Result<()> { - use error::ListError as LE; use error::ListErrorKind as LEK; entries.fold_result(|entry| { let s = entry.get_location().to_str().unwrap_or(String::from(self.unknown_output)); - write!(stdout(), "{:?}\n", s).map_err(|e| LE::new(LEK::FormatError, Some(Box::new(e)))) + write!(stdout(), "{:?}\n", s).chain_err(| | LEK::FormatError) }) } diff --git a/lib/entry/libimagentrylist/src/listers/path.rs b/lib/entry/libimagentrylist/src/listers/path.rs index 15a2df5b..55a9afb0 100644 --- a/lib/entry/libimagentrylist/src/listers/path.rs +++ b/lib/entry/libimagentrylist/src/listers/path.rs @@ -22,7 +22,7 @@ use std::io::Write; use lister::Lister; use result::Result; -use error::MapErrInto; +use error::ResultExt; use libimagstore::store::FileLockEntry; use libimagutil::iter::FoldResult; @@ -44,30 +44,19 @@ impl PathLister { impl Lister for PathLister { fn list<'a, I: Iterator>>(&self, entries: I) -> Result<()> { - use error::ListError as LE; use error::ListErrorKind as LEK; entries.fold_result(|entry| { Ok(entry.get_location().clone()) - .and_then(|pb| pb.into_pathbuf().map_err_into(LEK::FormatError)) + .and_then(|pb| pb.into_pathbuf().chain_err(|| LEK::FormatError)) .and_then(|pb| { if self.absolute { - pb.canonicalize().map_err(|e| LE::new(LEK::FormatError, Some(Box::new(e)))) + pb.canonicalize().chain_err(|| LEK::FormatError) } else { Ok(pb.into()) } }) - .and_then(|pb| { - write!(stdout(), "{:?}\n", pb) - .map_err(|e| LE::new(LEK::FormatError, Some(Box::new(e)))) - }) - .map_err(|e| { - if e.err_type() == LEK::FormatError { - e - } else { - LE::new(LEK::FormatError, Some(Box::new(e))) - } - }) + .and_then(|pb| write!(stdout(), "{:?}\n", pb).chain_err(|| LEK::FormatError)) }) } diff --git a/lib/entry/libimagentrylist/src/listers/table.rs b/lib/entry/libimagentrylist/src/listers/table.rs index e9358ce3..040b27ad 100644 --- a/lib/entry/libimagentrylist/src/listers/table.rs +++ b/lib/entry/libimagentrylist/src/listers/table.rs @@ -21,7 +21,7 @@ use std::io::stdout; use lister::Lister; use result::Result; -use error::MapErrInto; +use error::ResultExt; use libimagstore::store::FileLockEntry; use libimagerror::into::IntoError; @@ -103,7 +103,7 @@ impl Vec> Lister for TableLister { }) .and_then(|tbl| { let mut io = stdout(); - tbl.print(&mut io).map_err_into(LEK::IOError) + tbl.print(&mut io).chain_err(|| LEK::IOError) }) } From bb6956740d8a063b84de96f5c462a782551e7740 Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 3 Sep 2017 15:10:58 +0200 Subject: [PATCH 12/32] libimagentrymarkdown: Rewrite error handling --- lib/entry/libimagentrymarkdown/src/error.rs | 9 +++++---- lib/entry/libimagentrymarkdown/src/lib.rs | 2 +- 2 files changed, 6 insertions(+), 5 deletions(-) diff --git a/lib/entry/libimagentrymarkdown/src/error.rs b/lib/entry/libimagentrymarkdown/src/error.rs index b3956d0e..60e9348e 100644 --- a/lib/entry/libimagentrymarkdown/src/error.rs +++ b/lib/entry/libimagentrymarkdown/src/error.rs @@ -17,6 +17,10 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +use std::error::Error; + +use libimagerror::into::IntoError; + error_chain! { types { MarkdownError, MarkdownErrorKind, ResultExt, Result; @@ -36,9 +40,6 @@ error_chain! { } } -pub use self::error::MarkdownError; -pub use self::error::MarkdownErrorKind; - impl IntoError for MarkdownErrorKind { type Target = MarkdownError; @@ -47,7 +48,7 @@ impl IntoError for MarkdownErrorKind { MarkdownError::from_kind(self) } - fn into_error_with_cause(self, cause: Box) -> Self::Target { + fn into_error_with_cause(self, _: Box) -> Self::Target { MarkdownError::from_kind(self) } } diff --git a/lib/entry/libimagentrymarkdown/src/lib.rs b/lib/entry/libimagentrymarkdown/src/lib.rs index 44bc6d35..fd00ee80 100644 --- a/lib/entry/libimagentrymarkdown/src/lib.rs +++ b/lib/entry/libimagentrymarkdown/src/lib.rs @@ -38,7 +38,7 @@ extern crate hoedown; extern crate url; extern crate libimagstore; -#[macro_use] extern crate libimagerror; +extern crate libimagerror; #[macro_use] extern crate error_chain; pub mod error; From 22be1627b72797833aa1703ec817c62c941d53ad Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 3 Sep 2017 15:28:13 +0200 Subject: [PATCH 13/32] libimagentryref: Rewrite error handling --- lib/entry/libimagentryref/src/error.rs | 18 +++-- lib/entry/libimagentryref/src/flags.rs | 4 +- lib/entry/libimagentryref/src/hasher.rs | 4 +- .../libimagentryref/src/hashers/nbytes.rs | 13 ++-- lib/entry/libimagentryref/src/lib.rs | 2 +- lib/entry/libimagentryref/src/lister.rs | 13 ++-- lib/entry/libimagentryref/src/reference.rs | 65 +++++++------------ 7 files changed, 50 insertions(+), 69 deletions(-) diff --git a/lib/entry/libimagentryref/src/error.rs b/lib/entry/libimagentryref/src/error.rs index 4f9f155c..c4152a14 100644 --- a/lib/entry/libimagentryref/src/error.rs +++ b/lib/entry/libimagentryref/src/error.rs @@ -17,11 +17,23 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +use std::error::Error; + +use libimagerror::into::IntoError; + error_chain! { types { RefError, RefErrorKind, ResultExt, Result; } + links { + ListError(::libimagentrylist::error::ListError, ::libimagentrylist::error::ListErrorKind); + } + + foreign_links { + Io(::std::io::Error); + } + errors { StoreReadError { description("Store read error") @@ -141,10 +153,6 @@ error_chain! { } } -pub use self::error::RefError; -pub use self::error::RefErrorKind; -pub use self::error::MapErrInto; - impl IntoError for RefErrorKind { type Target = RefError; @@ -152,7 +160,7 @@ impl IntoError for RefErrorKind { RefError::from_kind(self) } - fn into_error_with_cause(self, cause: Box) -> Self::Target { + fn into_error_with_cause(self, _: Box) -> Self::Target { RefError::from_kind(self) } } diff --git a/lib/entry/libimagentryref/src/flags.rs b/lib/entry/libimagentryref/src/flags.rs index b3b6851c..95873506 100644 --- a/lib/entry/libimagentryref/src/flags.rs +++ b/lib/entry/libimagentryref/src/flags.rs @@ -22,6 +22,7 @@ use std::collections::BTreeMap; use toml::Value; use error::RefErrorKind as REK; +use error::ResultExt; use result::Result; pub struct RefFlags { @@ -38,10 +39,9 @@ impl RefFlags { pub fn read(v: &Value) -> Result { fn get_field(v: &Value, key: &str) -> Result { use toml_query::read::TomlValueReadExt; - use error::MapErrInto; v.read(key) - .map_err_into(REK::HeaderTomlError) + .chain_err(|| REK::HeaderTomlError) .and_then(|toml| match toml { Some(&Value::Boolean(b)) => Ok(b), Some(_) => Err(REK::HeaderTypeError.into()), diff --git a/lib/entry/libimagentryref/src/hasher.rs b/lib/entry/libimagentryref/src/hasher.rs index d29502d2..7d2922f2 100644 --- a/lib/entry/libimagentryref/src/hasher.rs +++ b/lib/entry/libimagentryref/src/hasher.rs @@ -21,7 +21,7 @@ use std::path::PathBuf; use std::io::Read; use error::RefErrorKind as REK; -use error::MapErrInto; +use error::ResultExt; use crypto::sha1::Sha1; use crypto::digest::Digest; @@ -58,7 +58,7 @@ impl Hasher for DefaultHasher { fn create_hash(&mut self, _: &PathBuf, c: &mut R) -> Result { let mut s = String::new(); - try!(c.read_to_string(&mut s).map_err_into(REK::UTF8Error).map_err_into(REK::IOError)); + try!(c.read_to_string(&mut s).chain_err(|| REK::UTF8Error).chain_err(|| REK::IOError)); self.hasher.input_str(&s[..]); Ok(self.hasher.result_str()) } diff --git a/lib/entry/libimagentryref/src/hashers/nbytes.rs b/lib/entry/libimagentryref/src/hashers/nbytes.rs index 995e3dd8..e52ba813 100644 --- a/lib/entry/libimagentryref/src/hashers/nbytes.rs +++ b/lib/entry/libimagentryref/src/hashers/nbytes.rs @@ -24,12 +24,10 @@ use std::result::Result as RResult; use crypto::sha1::Sha1; use crypto::digest::Digest; -use libimagerror::into::IntoError; - use hasher::Hasher; use result::Result; use error::RefErrorKind as REK; -use error::MapErrInto; +use error::ResultExt; pub struct NBytesHasher { hasher: Sha1, @@ -58,11 +56,10 @@ impl Hasher for NBytesHasher { .bytes() .take(self.n) .collect::, _>>() - .map_err_into(REK::IOError) - .and_then(|v| String::from_utf8(v).map_err_into(REK::IOError)) - .map_err(Box::new) - .map_err(|e| REK::UTF8Error.into_error_with_cause(e)) - .map_err_into(REK::IOError); + .chain_err(|| REK::IOError) + .and_then(|v| String::from_utf8(v).chain_err(|| REK::IOError)) + .chain_err(|| REK::UTF8Error) + .chain_err(|| REK::IOError); self.hasher.input_str(&try!(s)[..]); Ok(self.hasher.result_str()) } diff --git a/lib/entry/libimagentryref/src/lib.rs b/lib/entry/libimagentryref/src/lib.rs index fd850447..beea98db 100644 --- a/lib/entry/libimagentryref/src/lib.rs +++ b/lib/entry/libimagentryref/src/lib.rs @@ -43,7 +43,7 @@ extern crate toml_query; extern crate walkdir; #[macro_use] extern crate libimagstore; -#[macro_use] extern crate libimagerror; +extern crate libimagerror; extern crate libimagentrylist; #[macro_use] extern crate error_chain; diff --git a/lib/entry/libimagentryref/src/lister.rs b/lib/entry/libimagentryref/src/lister.rs index 662ea9f6..f87bea31 100644 --- a/lib/entry/libimagentryref/src/lister.rs +++ b/lib/entry/libimagentryref/src/lister.rs @@ -23,14 +23,12 @@ use std::io::Write; use libimagentrylist::lister::Lister; use libimagentrylist::result::Result; +use libimagentrylist::error::ResultExt; use libimagerror::trace::trace_error; use libimagstore::store::FileLockEntry; -use libimagerror::into::IntoError; use libimagentrylist::error::ListErrorKind as LEK; use reference::Ref; -use error::MapErrInto; -use error::RefErrorKind as REK; pub struct RefLister { check_dead: bool, @@ -94,17 +92,14 @@ impl Lister for RefLister { self.check_changed_content, self.check_changed_permiss) .and_then(|s| { - write!(stdout(), "{}\n", s) - .map_err(Box::new) - .map_err(|e| LEK::FormatError.into_error_with_cause(e)) + write!(stdout(), "{}\n", s).chain_err(|| LEK::IOError) }) - .map_err_into(REK::RefToDisplayError) }) .map(|_| ()); (r, i + 1) }); debug!("Iterated over {} entries", n); - r.map_err(|e| LEK::FormatError.into_error_with_cause(Box::new(e))) + r } } @@ -149,7 +144,7 @@ fn lister_fn(fle: FileLockEntry, r.get_path_hash().unwrap_or_else(|_| String::from("Cannot get hash")), r.get_location()) }) - .map_err(|e| LEK::FormatError.into_error_with_cause(Box::new(e))) + .chain_err(|| LEK::FormatError) } fn check_dead(r: &Ref) -> bool { diff --git a/lib/entry/libimagentryref/src/reference.rs b/lib/entry/libimagentryref/src/reference.rs index 81e991ca..0ef1c934 100644 --- a/lib/entry/libimagentryref/src/reference.rs +++ b/lib/entry/libimagentryref/src/reference.rs @@ -41,7 +41,7 @@ use toml_query::set::TomlValueSetExt; use toml_query::insert::TomlValueInsertExt; use error::RefErrorKind as REK; -use error::MapErrInto; +use error::ResultExt; use flags::RefFlags; use result::Result; use hasher::*; @@ -74,8 +74,7 @@ impl<'a> Ref<'a> { .into_storeid() .and_then(|id| store.get(id)) .map(|opt_fle| opt_fle.map(|fle| Ref(fle))) - .map_err(Box::new) - .map_err(|e| REK::StoreReadError.into_error_with_cause(e)) + .chain_err(|| REK::StoreReadError) } /// Delete a ref by hash @@ -85,8 +84,7 @@ impl<'a> Ref<'a> { ModuleEntryPath::new(hash) .into_storeid() .and_then(|id| store.delete(id)) - .map_err(Box::new) - .map_err(|e| REK::StoreWriteError.into_error_with_cause(e)) + .chain_err(|| REK::StoreWriteError) } fn read_reference(fle: &FileLockEntry<'a>) -> Result { @@ -110,8 +108,7 @@ impl<'a> Ref<'a> { let (mut fle, content_hash, permissions, canonical_path) = { // scope to be able to fold try!(File::open(pb.clone()) - .map_err(Box::new) - .map_err(|e| REK::RefTargetFileCannotBeOpened.into_error_with_cause(e)) + .chain_err(|| REK::RefTargetFileCannotBeOpened) // If we were able to open this file, // we hash the contents of the file and return (file, hash) @@ -132,8 +129,7 @@ impl<'a> Ref<'a> { Some(try!(file .metadata() .map(|md| md.permissions()) - .map_err(Box::new) - .map_err(|e| REK::RefTargetCannotReadPermissions.into_error_with_cause(e)) + .chain_err(|| REK::RefTargetCannotReadPermissions) )) } else { None @@ -149,15 +145,14 @@ impl<'a> Ref<'a> { pb.canonicalize() .map(|can| (opt_contenthash, opt_permissions, can)) // if PathBuf::canonicalize() failed, build an error from the return value - .map_err(|e| REK::PathCanonicalizationError.into_error_with_cause(Box::new(e))) + .chain_err(|| REK::PathCanonicalizationError) }) // and then we hash the canonicalized path // and return (file, content hash, permissions, canonicalized path, path hash) .and_then(|(opt_contenthash, opt_permissions, can)| { let path_hash = try!(Ref::hash_path(&can) - .map_err(Box::new) - .map_err(|e| REK::PathHashingError.into_error_with_cause(e)) + .chain_err(|| REK::PathHashingError) ); Ok((opt_contenthash, opt_permissions, can, path_hash)) @@ -180,8 +175,7 @@ impl<'a> Ref<'a> { .and_then(|(opt_conhash, opt_perm, can, path_hash)| { let fle = try!(store .create(ModuleEntryPath::new(path_hash)) - .map_err(Box::new) - .map_err(|e| REK::StoreWriteError.into_error_with_cause(e)) + .chain_err(|| REK::StoreWriteError) ); Ok((fle, opt_conhash, opt_perm, can)) @@ -255,7 +249,7 @@ impl<'a> Ref<'a> { .get_location() .clone() .into_pathbuf() - .map_err_into(REK::StoreIdError) + .chain_err(|| REK::StoreIdError) .and_then(|pb| { pb.file_name() .and_then(|osstr| osstr.to_str()) @@ -300,8 +294,7 @@ impl<'a> Ref<'a> { .and_then(|pb| { File::open(pb.clone()) .map(|f| (pb, f)) - .map_err(Box::new) - .map_err(|e| REK::IOError.into_error_with_cause(e)) + .chain_err(|| REK::IOError) }) .and_then(|(path, mut file)| h.create_hash(&path, &mut file)) } @@ -311,15 +304,13 @@ impl<'a> Ref<'a> { self.fs_file() .and_then(|pb| { File::open(pb) - .map_err(Box::new) - .map_err(|e| REK::HeaderFieldReadError.into_error_with_cause(e)) + .chain_err(|| REK::HeaderFieldReadError) }) .and_then(|file| { file .metadata() .map(|md| md.permissions()) - .map_err(Box::new) - .map_err(|e| REK::RefTargetCannotReadPermissions.into_error_with_cause(e)) + .chain_err(|| REK::RefTargetCannotReadPermissions) }) } @@ -362,8 +353,7 @@ impl<'a> Ref<'a> { self.0 .get_header() .read("ref.permissions.ro") - .map_err(Box::new) - .map_err(|e| REK::HeaderFieldReadError.into_error_with_cause(e)) + .chain_err(|| REK::HeaderFieldReadError) .and_then(|ro| { match ro { Some(&Value::Boolean(b)) => Ok(b), @@ -372,8 +362,7 @@ impl<'a> Ref<'a> { } }) .and_then(|ro| self.get_current_permissions().map(|perm| ro == perm.readonly())) - .map_err(Box::new) - .map_err(|e| REK::RefTargetCannotReadPermissions.into_error_with_cause(e)) + .chain_err(|| REK::RefTargetCannotReadPermissions) } /// Check whether the Hashsum of the referenced file is equal to the stored hashsum @@ -398,15 +387,13 @@ impl<'a> Ref<'a> { try!(self.0 .get_header_mut() .set("ref.permissions.ro", Value::Boolean(current_perm.readonly())) - .map_err(Box::new) - .map_err(|e| REK::StoreWriteError.into_error_with_cause(e)) + .chain_err(|| REK::StoreWriteError) ); try!(self.0 .get_header_mut() .set(&format!("ref.content_hash.{}", h.hash_name())[..], Value::String(current_hash)) - .map_err(Box::new) - .map_err(|e| REK::StoreWriteError.into_error_with_cause(e)) + .chain_err(|| REK::StoreWriteError) ); Ok(()) @@ -425,17 +412,14 @@ impl<'a> Ref<'a> { /// Check whether there is a reference to the file at `pb` pub fn exists(store: &Store, pb: PathBuf) -> Result { pb.canonicalize() - .map_err(Box::new) - .map_err(|e| REK::PathCanonicalizationError.into_error_with_cause(e)) + .chain_err(|| REK::PathCanonicalizationError) .and_then(|can| { Ref::hash_path(&can) - .map_err(Box::new) - .map_err(|e| REK::PathHashingError.into_error_with_cause(e)) + .chain_err(|| REK::PathHashingError) }) .and_then(|hash| { store.retrieve_for_module("ref").map(|iter| (hash, iter)) - .map_err(Box::new) - .map_err(|e| REK::StoreReadError.into_error_with_cause(e)) + .chain_err(|| REK::StoreReadError) }) .and_then(|(hash, possible_refs)| { // This is kind of a manual Iterator::filter() call what we do here, but with the @@ -444,7 +428,7 @@ impl<'a> Ref<'a> { // take this note as a todo. for r in possible_refs { let contains_hash = try!(r.to_str() - .map_err_into(REK::TypeConversionError) + .chain_err(|| REK::TypeConversionError) .map(|s| s.contains(&hash[..]))); if !contains_hash { @@ -505,13 +489,11 @@ impl<'a> Ref<'a> { .into_iter() .map(|entry| { entry - .map_err(Box::new) - .map_err(|e| REK::IOError.into_error_with_cause(e)) + .chain_err(|| REK::IOError) .and_then(|entry| { let pb = PathBuf::from(entry.path()); File::open(entry.path()) - .map_err(Box::new) - .map_err(|e| REK::IOError.into_error_with_cause(e)) + .chain_err(|| REK::IOError) .map(|f| (pb, f)) }) .and_then(|(p, mut f)| h.create_hash(&p, &mut f).map(|h| (p, h))) @@ -522,8 +504,7 @@ impl<'a> Ref<'a> { None } }) - .map_err(Box::new) - .map_err(|e| REK::IOError.into_error_with_cause(e)) + .chain_err(|| REK::IOError) }) .filter_map(|e| e.ok()) .filter_map(|e| e) From 0b068df84e3063b24ece69d50d39c30c25e85a40 Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 3 Sep 2017 15:34:58 +0200 Subject: [PATCH 14/32] libimagnotes: Rewrite error handling --- lib/domain/libimagnotes/src/error.rs | 10 +++---- lib/domain/libimagnotes/src/lib.rs | 2 +- lib/domain/libimagnotes/src/note.rs | 41 ++++++++++++---------------- 3 files changed, 24 insertions(+), 29 deletions(-) diff --git a/lib/domain/libimagnotes/src/error.rs b/lib/domain/libimagnotes/src/error.rs index 8b7e6186..df84ef85 100644 --- a/lib/domain/libimagnotes/src/error.rs +++ b/lib/domain/libimagnotes/src/error.rs @@ -17,6 +17,10 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +use std::error::Error; + +use libimagerror::into::IntoError; + error_chain! { types { NoteError, NoteErrorKind, ResultExt, Result; @@ -46,10 +50,6 @@ error_chain! { } } -pub use self::error::NoteError; -pub use self::error::NoteErrorKind; -pub use self::error::MapErrInto; - impl IntoError for NoteErrorKind { type Target = NoteError; @@ -57,7 +57,7 @@ impl IntoError for NoteErrorKind { NoteError::from_kind(self) } - fn into_error_with_cause(self, cause: Box) -> Self::Target { + fn into_error_with_cause(self, _: Box) -> Self::Target { NoteError::from_kind(self) } } diff --git a/lib/domain/libimagnotes/src/lib.rs b/lib/domain/libimagnotes/src/lib.rs index fd646913..54315538 100644 --- a/lib/domain/libimagnotes/src/lib.rs +++ b/lib/domain/libimagnotes/src/lib.rs @@ -42,7 +42,7 @@ extern crate toml_query; extern crate libimagrt; #[macro_use] extern crate libimagstore; -#[macro_use] extern crate libimagerror; +extern crate libimagerror; extern crate libimagentryedit; module_entry_path_mod!("notes"); diff --git a/lib/domain/libimagnotes/src/note.rs b/lib/domain/libimagnotes/src/note.rs index feaa8818..9030ce9d 100644 --- a/lib/domain/libimagnotes/src/note.rs +++ b/lib/domain/libimagnotes/src/note.rs @@ -25,6 +25,7 @@ use toml::Value; use libimagrt::runtime::Runtime; use libimagentryedit::edit::Edit; use libimagentryedit::result::Result as EditResult; +use libimagerror::into::IntoError; use libimagstore::storeid::IntoStoreId; use libimagstore::storeid::StoreId; use libimagstore::storeid::StoreIdIterator; @@ -36,9 +37,8 @@ use toml_query::set::TomlValueSetExt; use module_path::ModuleEntryPath; use result::Result; -use error::NoteError as NE; use error::NoteErrorKind as NEK; -use error::MapErrInto; +use error::ResultExt; #[derive(Debug)] pub struct Note<'a> { @@ -55,24 +55,20 @@ impl<'a> Note<'a> { let mut lockentry = try!(ModuleEntryPath::new(name.clone()) .into_storeid() .and_then(|id| store.create(id)) - .map_err_into(NEK::StoreWriteError)); + .chain_err(|| NEK::StoreWriteError)); { let entry = lockentry.deref_mut(); { let header = entry.get_header_mut(); - let setres = header.set("note", Value::Table(BTreeMap::new())); - if setres.is_err() { - let kind = NEK::StoreWriteError; - return Err(NE::new(kind, Some(Box::new(setres.unwrap_err())))); - } + let _ = header + .set("note", Value::Table(BTreeMap::new())) + .chain_err(|| NEK::StoreWriteError); - let setres = header.set("note.name", Value::String(name)); - if setres.is_err() { - let kind = NEK::StoreWriteError; - return Err(NE::new(kind, Some(Box::new(setres.unwrap_err())))); - } + let _ = header + .set("note.name", Value::String(name)) + .chain_err(|| NEK::StoreWriteError); } *entry.get_content_mut() = text; @@ -88,7 +84,7 @@ impl<'a> Note<'a> { self.entry .get_header_mut() .set("note.name", Value::String(n)) - .map_err(|e| NE::new(NEK::StoreWriteError, Some(Box::new(e)))) + .chain_err(|| NEK::StoreWriteError) .map(|_| ()) } @@ -96,11 +92,10 @@ impl<'a> Note<'a> { let header = self.entry.get_header(); match header.read("note.name") { Ok(Some(&Value::String(ref s))) => Ok(s.clone()), - Ok(_) => { - let e = NE::new(NEK::HeaderTypeError, None); - Err(NE::new(NEK::StoreReadError, Some(Box::new(e)))) + Ok(_) => { + Err(NEK::HeaderTypeError.into_error()).chain_err(|| NEK::StoreReadError) }, - Err(e) => Err(NE::new(NEK::StoreReadError, Some(Box::new(e)))) + Err(e) => Err(e).chain_err(|| NEK::StoreReadError) } } @@ -116,14 +111,14 @@ impl<'a> Note<'a> { ModuleEntryPath::new(name) .into_storeid() .and_then(|id| store.delete(id)) - .map_err_into(NEK::StoreWriteError) + .chain_err(|| NEK::StoreWriteError) } pub fn retrieve(store: &Store, name: String) -> Result { ModuleEntryPath::new(name) .into_storeid() .and_then(|id| store.retrieve(id)) - .map_err_into(NEK::StoreWriteError) + .chain_err(|| NEK::StoreWriteError) .map(|entry| Note { entry: entry }) } @@ -131,14 +126,14 @@ impl<'a> Note<'a> { ModuleEntryPath::new(name) .into_storeid() .and_then(|id| store.get(id)) - .map_err_into(NEK::StoreWriteError) + .chain_err(|| NEK::StoreWriteError) .map(|o| o.map(|entry| Note { entry: entry })) } pub fn all_notes(store: &Store) -> Result { store.retrieve_for_module("notes") .map(|iter| NoteIterator::new(store, iter)) - .map_err(|e| NE::new(NEK::StoreReadError, Some(Box::new(e)))) + .chain_err(|| NEK::StoreReadError) } } @@ -160,7 +155,7 @@ impl<'a> FromStoreId for Note<'a> { fn from_storeid(store: &Store, id: StoreId) -> Result { debug!("Loading note from storeid: '{:?}'", id); match store.retrieve(id) { - Err(e) => Err(NE::new(NEK::StoreReadError, Some(Box::new(e)))), + Err(e) => Err(e).chain_err(|| NEK::StoreReadError), Ok(entry) => Ok(Note { entry: entry }), } } From d443b83b520b340586e77d831747231cf5942170 Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 3 Sep 2017 15:41:25 +0200 Subject: [PATCH 15/32] libimagentrydatetime: Rewrite error handling --- .../src/datepath/compiler.rs | 4 +- .../src/datepath/error.rs | 8 ++-- .../libimagentrydatetime/src/datetime.rs | 34 ++++++++--------- lib/entry/libimagentrydatetime/src/error.rs | 14 ++++--- lib/entry/libimagentrydatetime/src/lib.rs | 2 +- lib/entry/libimagentrydatetime/src/range.rs | 38 +++---------------- 6 files changed, 39 insertions(+), 61 deletions(-) diff --git a/lib/entry/libimagentrydatetime/src/datepath/compiler.rs b/lib/entry/libimagentrydatetime/src/datepath/compiler.rs index 742b594a..12537e8e 100644 --- a/lib/entry/libimagentrydatetime/src/datepath/compiler.rs +++ b/lib/entry/libimagentrydatetime/src/datepath/compiler.rs @@ -29,7 +29,7 @@ use datepath::accuracy::Accuracy; use datepath::format::Format; use datepath::result::Result; use datepath::error::DatePathCompilerErrorKind as DPCEK; -use datepath::error::MapErrInto; +use datepath::error::ResultExt; pub struct DatePathCompiler { accuracy : Accuracy, @@ -122,7 +122,7 @@ impl DatePathCompiler { } StoreId::new_baseless(PathBuf::from(s)) - .map_err_into(DPCEK::StoreIdBuildFailed) + .chain_err(|| DPCEK::StoreIdBuildFailed) } } diff --git a/lib/entry/libimagentrydatetime/src/datepath/error.rs b/lib/entry/libimagentrydatetime/src/datepath/error.rs index f080e5ac..b0b02494 100644 --- a/lib/entry/libimagentrydatetime/src/datepath/error.rs +++ b/lib/entry/libimagentrydatetime/src/datepath/error.rs @@ -17,6 +17,10 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +use std::error::Error; + +use libimagerror::into::IntoError; + error_chain! { types { DatePathCompilerError, DatePathCompilerErrorKind, ResultExt, Result; @@ -36,8 +40,6 @@ error_chain! { } } -pub use self::error::DatePathCompilerError; - impl IntoError for DatePathCompilerErrorKind { type Target = DatePathCompilerError; @@ -45,7 +47,7 @@ impl IntoError for DatePathCompilerErrorKind { DatePathCompilerError::from_kind(self) } - fn into_error_with_cause(self, cause: Box) -> Self::Target { + fn into_error_with_cause(self, _: Box) -> Self::Target { DatePathCompilerError::from_kind(self) } } diff --git a/lib/entry/libimagentrydatetime/src/datetime.rs b/lib/entry/libimagentrydatetime/src/datetime.rs index 73c29622..6b137897 100644 --- a/lib/entry/libimagentrydatetime/src/datetime.rs +++ b/lib/entry/libimagentrydatetime/src/datetime.rs @@ -56,17 +56,17 @@ impl EntryDate for Entry { self.get_header_mut() .delete(&DATE_HEADER_LOCATION) .map(|_| ()) - .map_err_into(DEK::DeleteDateError) + .chain_err(|| DEK::DeleteDateError) } fn read_date(&self) -> Result { self.get_header() .read(&DATE_HEADER_LOCATION) - .map_err_into(DEK::ReadDateError) + .chain_err(|| DEK::ReadDateError) .and_then(|v| { match v { Some(&Value::String(ref s)) => s.parse::() - .map_err_into(DEK::DateTimeParsingError), + .chain_err(|| DEK::DateTimeParsingError), Some(_) => Err(DEK::DateHeaderFieldTypeError.into_error()), _ => Err(DEK::ReadDateError.into_error()), } @@ -97,11 +97,11 @@ impl EntryDate for Entry { .map(|opt| opt.map(|stri| { match stri { Value::String(ref s) => s.parse::() - .map_err_into(DEK::DateTimeParsingError), + .chain_err(|| DEK::DateTimeParsingError), _ => Err(DEK::DateHeaderFieldTypeError.into_error()), } })) - .map_err_into(DEK::SetDateError) + .chain_err(|| DEK::SetDateError) } @@ -117,23 +117,23 @@ impl EntryDate for Entry { .get_header_mut() .delete(&DATE_RANGE_START_HEADER_LOCATION) .map(|_| ()) - .map_err_into(DEK::DeleteDateTimeRangeError)); + .chain_err(|| DEK::DeleteDateTimeRangeError)); self.get_header_mut() .delete(&DATE_RANGE_END_HEADER_LOCATION) .map(|_| ()) - .map_err_into(DEK::DeleteDateTimeRangeError) + .chain_err(|| DEK::DeleteDateTimeRangeError) } fn read_date_range(&self) -> Result { let start = try!(self .get_header() .read(&DATE_RANGE_START_HEADER_LOCATION) - .map_err_into(DEK::ReadDateTimeRangeError) + .chain_err(|| DEK::ReadDateTimeRangeError) .and_then(|v| { match v { Some(&Value::String(ref s)) => s.parse::() - .map_err_into(DEK::DateTimeParsingError), + .chain_err(|| DEK::DateTimeParsingError), Some(_) => Err(DEK::DateHeaderFieldTypeError.into_error()), _ => Err(DEK::ReadDateError.into_error()), } @@ -142,18 +142,18 @@ impl EntryDate for Entry { let end = try!(self .get_header() .read(&DATE_RANGE_START_HEADER_LOCATION) - .map_err_into(DEK::ReadDateTimeRangeError) + .chain_err(|| DEK::ReadDateTimeRangeError) .and_then(|v| { match v { Some(&Value::String(ref s)) => s.parse::() - .map_err_into(DEK::DateTimeParsingError), + .chain_err(|| DEK::DateTimeParsingError), Some(_) => Err(DEK::DateHeaderFieldTypeError.into_error()), _ => Err(DEK::ReadDateError.into_error()), } })); DateTimeRange::new(start, end) - .map_err_into(DEK::DateTimeRangeError) + .chain_err(|| DEK::DateTimeRangeError) } /// Set the date range @@ -175,11 +175,11 @@ impl EntryDate for Entry { .map(|opt| opt.map(|stri| { match stri { Value::String(ref s) => s.parse::() - .map_err_into(DEK::DateTimeParsingError), + .chain_err(|| DEK::DateTimeParsingError), _ => Err(DEK::DateHeaderFieldTypeError.into_error()), } })) - .map_err_into(DEK::SetDateTimeRangeError)); + .chain_err(|| DEK::SetDateTimeRangeError)); let opt_old_end = try!(self .get_header_mut() @@ -187,16 +187,16 @@ impl EntryDate for Entry { .map(|opt| opt.map(|stri| { match stri { Value::String(ref s) => s.parse::() - .map_err_into(DEK::DateTimeParsingError), + .chain_err(|| DEK::DateTimeParsingError), _ => Err(DEK::DateHeaderFieldTypeError.into_error()), } })) - .map_err_into(DEK::SetDateTimeRangeError)); + .chain_err(|| DEK::SetDateTimeRangeError)); match (opt_old_start, opt_old_end) { (Some(Ok(old_start)), Some(Ok(old_end))) => { let dr = DateTimeRange::new(old_start, old_end) - .map_err_into(DEK::DateTimeRangeError); + .chain_err(|| DEK::DateTimeRangeError); Ok(Some(dr)) }, diff --git a/lib/entry/libimagentrydatetime/src/error.rs b/lib/entry/libimagentrydatetime/src/error.rs index c49bb8c4..dbf9c322 100644 --- a/lib/entry/libimagentrydatetime/src/error.rs +++ b/lib/entry/libimagentrydatetime/src/error.rs @@ -17,6 +17,10 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +use std::error::Error; + +use libimagerror::into::IntoError; + error_chain! { types { DateError, DateErrorKind, ResultExt, Result; @@ -68,13 +72,13 @@ error_chain! { display("Error parsing DateTime") } + EndDateTimeBeforeStartDateTime { + description("End datetime is before start datetime") + display("End datetime is before start datetime") + } } } -pub use self::error::DateError; -pub use self::error::DateErrorKind; -pub use self::error::MapErrInto; - impl IntoError for DateErrorKind { type Target = DateError; @@ -82,7 +86,7 @@ impl IntoError for DateErrorKind { DateError::from_kind(self) } - fn into_error_with_cause(self, cause: Box) -> Self::Target { + fn into_error_with_cause(self, _: Box) -> Self::Target { DateError::from_kind(self) } } diff --git a/lib/entry/libimagentrydatetime/src/lib.rs b/lib/entry/libimagentrydatetime/src/lib.rs index 7359093c..3a231814 100644 --- a/lib/entry/libimagentrydatetime/src/lib.rs +++ b/lib/entry/libimagentrydatetime/src/lib.rs @@ -41,7 +41,7 @@ extern crate toml_query; extern crate toml; #[macro_use] extern crate error_chain; -#[macro_use] extern crate libimagerror; +extern crate libimagerror; extern crate libimagstore; pub mod datepath; diff --git a/lib/entry/libimagentrydatetime/src/range.rs b/lib/entry/libimagentrydatetime/src/range.rs index f729dfde..59cd0ccf 100644 --- a/lib/entry/libimagentrydatetime/src/range.rs +++ b/lib/entry/libimagentrydatetime/src/range.rs @@ -17,39 +17,12 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -/// Error types for range module -error_chain! { - types { - DateTimeRangeError, DateTimeRangeErrorKind, ResultExt, Result; - } - - errors { - EndDateTimeBeforeStartDateTime { - description("End datetime is before start datetime") - display("End datetime is before start datetime") - } - } -} - -pub use self::error::DateTimeRangeError; -pub use self::error::DateTimeRangeErrorKind; -pub use self::error::MapErrInto; - -impl IntoError for DateTimeRangeErrorKind { - type Target = DateTimeRangeError; - - fn into_error(self) -> Self::Target { - DateTimeRangeError::from_kind(self) - } - - fn into_error_with_cause(self, cause: Box) -> Self::Target { - DateTimeRangeError::from_kind(self) - } -} - use chrono::naive::NaiveDateTime; + +use error::DateErrorKind as DEK; +use error::Result; + use libimagerror::into::IntoError; -use self::result::Result; /// A Range between two dates #[derive(Debug, Clone, PartialEq, Eq, PartialOrd, Ord, Hash)] @@ -65,11 +38,10 @@ impl DateTimeRange { /// else Err(DateTimeRangeError) /// pub fn new(start: NaiveDateTime, end: NaiveDateTime) -> Result { - use self::error::DateTimeRangeErrorKind as DTREK; if start < end { Ok(DateTimeRange(start, end)) } else { - Err(DTREK::EndDateTimeBeforeStartDateTime.into_error()) + Err(DEK::EndDateTimeBeforeStartDateTime.into_error()) } } From 262aae39f446b21ad25e7bbdfbda38e7d4c6c26b Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 3 Sep 2017 15:50:54 +0200 Subject: [PATCH 16/32] libimagentryannotation: Rewrite error handling --- lib/entry/libimagentryannotation/src/annotateable.rs | 10 +++++----- .../libimagentryannotation/src/annotation_fetcher.rs | 12 ++++++------ lib/entry/libimagentryannotation/src/error.rs | 10 +++++----- lib/entry/libimagentryannotation/src/lib.rs | 2 +- 4 files changed, 17 insertions(+), 17 deletions(-) diff --git a/lib/entry/libimagentryannotation/src/annotateable.rs b/lib/entry/libimagentryannotation/src/annotateable.rs index 4fb3589a..85f5f89a 100644 --- a/lib/entry/libimagentryannotation/src/annotateable.rs +++ b/lib/entry/libimagentryannotation/src/annotateable.rs @@ -32,7 +32,7 @@ use toml_query::insert::TomlValueInsertExt; use result::Result; use error::AnnotationErrorKind as AEK; -use error::MapErrInto; +use error::ResultExt; pub trait Annotateable { @@ -51,16 +51,16 @@ impl Annotateable for Entry { fn annotate<'a>(&mut self, store: &'a Store, ann_name: &str) -> Result> { store.retrieve(PathBuf::from(ann_name)) - .map_err_into(AEK::StoreWriteError) + .chain_err(|| AEK::StoreWriteError) .and_then(|mut anno| { anno.get_header_mut() .insert("annotation.is_annotation", Value::Boolean(true)) - .map_err_into(AEK::HeaderWriteError) + .chain_err(|| AEK::HeaderWriteError) .map(|_| anno) }) .and_then(|mut anno| { anno.add_internal_link(self) - .map_err_into(AEK::LinkingError) + .chain_err(|| AEK::LinkingError) .map(|_| anno) }) } @@ -68,7 +68,7 @@ impl Annotateable for Entry { fn is_annotation(&self) -> Result { self.get_header() .read("annotation.is_annotation") - .map_err_into(AEK::StoreReadError) + .chain_err(|| AEK::StoreReadError) .and_then(|res| match res { Some(&Value::Boolean(b)) => Ok(b), None => Ok(false), diff --git a/lib/entry/libimagentryannotation/src/annotation_fetcher.rs b/lib/entry/libimagentryannotation/src/annotation_fetcher.rs index 58b27170..c49ce865 100644 --- a/lib/entry/libimagentryannotation/src/annotation_fetcher.rs +++ b/lib/entry/libimagentryannotation/src/annotation_fetcher.rs @@ -26,7 +26,7 @@ use libimagstore::storeid::StoreIdIterator; use result::Result; use error::AnnotationErrorKind as AEK; -use error::MapErrInto; +use error::ResultExt; use self::iter::*; @@ -45,7 +45,7 @@ impl<'a> AnnotationFetcher<'a> for Store { fn all_annotations(&'a self) -> Result> { Note::all_notes(self) .map(|iter| AnnotationIter::new(iter)) - .map_err_into(AEK::StoreReadError) + .chain_err(|| AEK::StoreReadError) } /// Get all annotations (in an iterator) for an entry @@ -57,7 +57,7 @@ impl<'a> AnnotationFetcher<'a> for Store { /// entry, but should normally be not that heavy. fn annotations_for_entry(&'a self, entry: &Entry) -> Result> { entry.get_internal_links() - .map_err_into(AEK::StoreReadError) + .chain_err(|| AEK::StoreReadError) .map(|iter| StoreIdIterator::new(Box::new(iter.map(|e| e.get_store_id().clone())))) .map(|iter| NoteIterator::new(self, iter)) .map(|iter| AnnotationIter::new(iter)) @@ -76,7 +76,7 @@ pub mod iter { use result::Result; use error::AnnotationErrorKind as AEK; - use error::MapErrInto; + use error::ResultExt; #[derive(Debug)] pub struct AnnotationIter<'a>(NoteIterator<'a>); @@ -100,10 +100,10 @@ pub mod iter { Ok(None) => continue, // not an annotation Ok(Some(&Value::Boolean(true))) => return Some(Ok(note)), Ok(Some(_)) => return Some(Err(AEK::HeaderTypeError.into_error())), - Err(e) => return Some(Err(e).map_err_into(AEK::HeaderReadError)), + Err(e) => return Some(Err(e).chain_err(|| AEK::HeaderReadError)), } }, - Some(Err(e)) => return Some(Err(e).map_err_into(AEK::StoreReadError)), + Some(Err(e)) => return Some(Err(e).chain_err(|| AEK::StoreReadError)), None => return None, // iterator consumed } } diff --git a/lib/entry/libimagentryannotation/src/error.rs b/lib/entry/libimagentryannotation/src/error.rs index 6355048e..7543b85a 100644 --- a/lib/entry/libimagentryannotation/src/error.rs +++ b/lib/entry/libimagentryannotation/src/error.rs @@ -17,6 +17,10 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +use std::error::Error; + +use libimagerror::into::IntoError; + error_chain! { types { AnnotationError, AnnotationErrorKind, ResultExt, Result; @@ -56,10 +60,6 @@ error_chain! { } } -pub use self::error::AnnotationError; -pub use self::error::AnnotationErrorKind; -pub use self::error::MapErrInto; - impl IntoError for AnnotationErrorKind { type Target = AnnotationError; @@ -67,7 +67,7 @@ impl IntoError for AnnotationErrorKind { AnnotationError::from_kind(self) } - fn into_error_with_cause(self, cause: Box) -> Self::Target { + fn into_error_with_cause(self, _: Box) -> Self::Target { AnnotationError::from_kind(self) } } diff --git a/lib/entry/libimagentryannotation/src/lib.rs b/lib/entry/libimagentryannotation/src/lib.rs index e2f9fb51..204e67b3 100644 --- a/lib/entry/libimagentryannotation/src/lib.rs +++ b/lib/entry/libimagentryannotation/src/lib.rs @@ -39,7 +39,7 @@ extern crate toml; extern crate toml_query; #[macro_use] extern crate error_chain; -#[macro_use] extern crate libimagerror; +extern crate libimagerror; extern crate libimagstore; extern crate libimagentrylink; extern crate libimagnotes; From 8d8a91e7c5697b0a2459bbf5a77a733f946aaab1 Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 3 Sep 2017 15:55:20 +0200 Subject: [PATCH 17/32] libimagentrycategory: Rewrite error handling --- .../libimagentrycategory/src/category.rs | 12 ++++---- lib/entry/libimagentrycategory/src/error.rs | 20 +++++++++---- lib/entry/libimagentrycategory/src/lib.rs | 1 - .../libimagentrycategory/src/register.rs | 30 +++++++++---------- 4 files changed, 36 insertions(+), 27 deletions(-) diff --git a/lib/entry/libimagentrycategory/src/category.rs b/lib/entry/libimagentrycategory/src/category.rs index 1e77495e..9b75223e 100644 --- a/lib/entry/libimagentrycategory/src/category.rs +++ b/lib/entry/libimagentrycategory/src/category.rs @@ -26,7 +26,7 @@ use libimagstore::store::Entry; use libimagerror::into::IntoError; use error::CategoryErrorKind as CEK; -use error::MapErrInto; +use error::ResultExt; use result::Result; use register::CategoryRegister; @@ -64,7 +64,7 @@ impl EntryCategory for Entry { fn set_category(&mut self, s: Category) -> Result<()> { self.get_header_mut() .insert(&String::from("category.value"), Value::String(s.into())) - .map_err_into(CEK::HeaderWriteError) + .chain_err(|| CEK::HeaderWriteError) .map(|_| ()) } @@ -86,17 +86,17 @@ impl EntryCategory for Entry { &TQEK::IdentifierNotFoundInDocument(_) => Ok(None), _ => Err(res), } - .map_err_into(CEK::HeaderReadError), + .chain_err(|| CEK::HeaderReadError), Ok(Some(&Value::String(ref s))) => Ok(Some(s.clone().into())), - Ok(None) => Err(CEK::StoreReadError.into_error()).map_err_into(CEK::HeaderReadError), - Ok(_) => Err(CEK::TypeError.into_error()).map_err_into(CEK::HeaderReadError), + Ok(None) => Err(CEK::StoreReadError.into_error()).chain_err(|| CEK::HeaderReadError), + Ok(_) => Err(CEK::TypeError.into_error()).chain_err(|| CEK::HeaderReadError), } } fn has_category(&self) -> Result { self.get_header().read(&String::from("category.value")) - .map_err_into(CEK::HeaderReadError) + .chain_err(|| CEK::HeaderReadError) .map(|e| e.is_some()) } diff --git a/lib/entry/libimagentrycategory/src/error.rs b/lib/entry/libimagentrycategory/src/error.rs index ceb114cb..f4fc8e60 100644 --- a/lib/entry/libimagentrycategory/src/error.rs +++ b/lib/entry/libimagentrycategory/src/error.rs @@ -17,6 +17,10 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +use std::error::Error; + +use libimagerror::into::IntoError; + error_chain! { types { CategoryError, CategoryErrorKind, ResultExt, Result; @@ -43,17 +47,23 @@ error_chain! { display("Header read error") } + HeaderWriteError { + description("Header write error") + display("Header write error") + } + CategoryDoesNotExist { description("Category does not exist") display("Category does not exist") } + + TypeError { + description("Type Error") + display("Type Error") + } } } -pub use self::error::CategoryError; -pub use self::error::CategoryErrorKind; -pub use self::error::MapErrInto; - impl IntoError for CategoryErrorKind { type Target = CategoryError; @@ -61,7 +71,7 @@ impl IntoError for CategoryErrorKind { CategoryError::from_kind(self) } - fn into_error_with_cause(self, cause: Box) -> Self::Target { + fn into_error_with_cause(self, _: Box) -> Self::Target { CategoryError::from_kind(self) } } diff --git a/lib/entry/libimagentrycategory/src/lib.rs b/lib/entry/libimagentrycategory/src/lib.rs index bfe9d6f7..1ea7d05b 100644 --- a/lib/entry/libimagentrycategory/src/lib.rs +++ b/lib/entry/libimagentrycategory/src/lib.rs @@ -43,7 +43,6 @@ extern crate is_match; extern crate log; #[macro_use] extern crate error_chain; -#[macro_use] extern crate libimagerror; #[macro_use] extern crate libimagstore; diff --git a/lib/entry/libimagentrycategory/src/register.rs b/lib/entry/libimagentrycategory/src/register.rs index e8853631..8e2830fa 100644 --- a/lib/entry/libimagentrycategory/src/register.rs +++ b/lib/entry/libimagentrycategory/src/register.rs @@ -31,7 +31,7 @@ use libimagerror::into::IntoError; use category::Category; use error::CategoryErrorKind as CEK; -use error::MapErrInto; +use error::ResultExt; use result::Result; pub const CATEGORY_REGISTER_NAME_FIELD_PATH : &'static str = "category.register.name"; @@ -81,13 +81,13 @@ impl CategoryRegister for Store { warn!("Setting category header replaced existing value: {:?}", opt); }) .map(|_| true) - .map_err_into(CEK::HeaderWriteError) - .map_err_into(CEK::StoreWriteError) + .chain_err(|| CEK::HeaderWriteError) + .chain_err(|| CEK::StoreWriteError) } - Err(store_error) => if is_match!(store_error.err_type(), SEK::EntryAlreadyExists) { + Err(store_error) => if is_match!(store_error.kind(), &SEK::EntryAlreadyExists) { Ok(false) } else { - Err(store_error).map_err_into(CEK::StoreWriteError) + Err(store_error).chain_err(|| CEK::StoreWriteError) } } } @@ -96,13 +96,13 @@ impl CategoryRegister for Store { fn delete_category(&self, name: &str) -> Result<()> { let sid = try!(mk_category_storeid(self.path().clone(), name)); - self.delete(sid).map_err_into(CEK::StoreWriteError) + self.delete(sid).chain_err(|| CEK::StoreWriteError) } /// Get all category names fn all_category_names(&self) -> Result { self.retrieve_for_module("category") - .map_err_into(CEK::StoreReadError) + .chain_err(|| CEK::StoreReadError) .map(|iter| CategoryNameIter::new(self, iter)) } @@ -114,7 +114,7 @@ impl CategoryRegister for Store { let sid = try!(mk_category_storeid(self.path().clone(), name)); self.get(sid) - .map_err_into(CEK::StoreWriteError) + .chain_err(|| CEK::StoreWriteError) } } @@ -212,26 +212,26 @@ fn mk_category_storeid(base: PathBuf, s: &str) -> Result { ::module_path::ModuleEntryPath::new(s) .into_storeid() .map(|id| id.with_base(base)) - .map_err_into(CEK::StoreIdHandlingError) + .chain_err(|| CEK::StoreIdHandlingError) } #[inline] fn represents_category(store: &Store, sid: StoreId, name: &str) -> Result { sid.exists() - .map_err_into(CEK::StoreIdHandlingError) + .chain_err(|| CEK::StoreIdHandlingError) .and_then(|bl| { if bl { store.get(sid) - .map_err_into(CEK::StoreReadError) + .chain_err(|| CEK::StoreReadError) .and_then(|fle| { if let Some(fle) = fle { match fle.get_header() .read(&String::from(CATEGORY_REGISTER_NAME_FIELD_PATH)) - .map_err_into(CEK::HeaderReadError) + .chain_err(|| CEK::HeaderReadError) { Ok(Some(&Value::String(ref s))) => Ok(s == name), Ok(_) => Err(CEK::TypeError.into_error()), - Err(e) => Err(e).map_err_into(CEK::HeaderReadError), + Err(e) => Err(e).chain_err(|| CEK::HeaderReadError), } } else { Ok(false) @@ -277,12 +277,12 @@ impl<'a> Iterator for CategoryNameIter<'a> { .map(|sid| { self.0 .get(sid) - .map_err_into(CEK::StoreReadError) + .chain_err(|| CEK::StoreReadError) .and_then(|fle| fle.ok_or(CEK::StoreReadError.into_error())) .and_then(|fle| match fle.get_header().read(&query) { Ok(Some(&Value::String(ref s))) => Ok(Category::from(s.clone())), Ok(_) => Err(CEK::TypeError.into_error()), - Err(e) => Err(e).map_err_into(CEK::HeaderReadError), + Err(e) => Err(e).chain_err(|| CEK::HeaderReadError), }) }) } From 0ede39a99115be507966e5e4e48150c167e91771 Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 3 Sep 2017 15:57:47 +0200 Subject: [PATCH 18/32] libimagentrytag: Rewrite error handling --- lib/entry/libimagentrytag/src/error.rs | 10 +++++----- lib/entry/libimagentrytag/src/lib.rs | 2 +- lib/entry/libimagentrytag/src/tagable.rs | 9 ++++----- 3 files changed, 10 insertions(+), 11 deletions(-) diff --git a/lib/entry/libimagentrytag/src/error.rs b/lib/entry/libimagentrytag/src/error.rs index 0c2e8204..fe02b26e 100644 --- a/lib/entry/libimagentrytag/src/error.rs +++ b/lib/entry/libimagentrytag/src/error.rs @@ -17,6 +17,10 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +use std::error::Error; + +use libimagerror::into::IntoError; + error_chain! { types { TagError, TagErrorKind, ResultExt, Result; @@ -46,10 +50,6 @@ error_chain! { } } -pub use self::error::TagError; -pub use self::error::TagErrorKind; -pub use self::error::MapErrInto; - impl IntoError for TagErrorKind { type Target = TagError; @@ -57,7 +57,7 @@ impl IntoError for TagErrorKind { TagError::from_kind(self) } - fn into_error_with_cause(self, cause: Box) -> Self::Target { + fn into_error_with_cause(self, _: Box) -> Self::Target { TagError::from_kind(self) } } diff --git a/lib/entry/libimagentrytag/src/lib.rs b/lib/entry/libimagentrytag/src/lib.rs index 705293df..821f75b3 100644 --- a/lib/entry/libimagentrytag/src/lib.rs +++ b/lib/entry/libimagentrytag/src/lib.rs @@ -46,7 +46,7 @@ extern crate filters; #[macro_use] extern crate error_chain; extern crate libimagstore; -#[macro_use] extern crate libimagerror; +extern crate libimagerror; pub mod error; pub mod exec; diff --git a/lib/entry/libimagentrytag/src/tagable.rs b/lib/entry/libimagentrytag/src/tagable.rs index 1a182e57..7019905f 100644 --- a/lib/entry/libimagentrytag/src/tagable.rs +++ b/lib/entry/libimagentrytag/src/tagable.rs @@ -26,7 +26,7 @@ use toml_query::read::TomlValueReadExt; use toml_query::set::TomlValueSetExt; use error::TagErrorKind; -use error::MapErrInto; +use error::ResultExt; use result::Result; use tag::{Tag, TagSlice}; use tag::is_tag_str; @@ -49,7 +49,7 @@ pub trait Tagable { impl Tagable for Value { fn get_tags(&self) -> Result> { - let tags = try!(self.read("imag.tags").map_err_into(TagErrorKind::HeaderReadError)); + let tags = try!(self.read("imag.tags").chain_err(|| TagErrorKind::HeaderReadError)); match tags { Some(&Value::Array(ref tags)) => { @@ -87,8 +87,7 @@ impl Tagable for Value { let a = ts.iter().unique().map(|t| Value::String(t.clone())).collect(); self.set("imag.tags", Value::Array(a)) .map(|_| ()) - .map_err(Box::new) - .map_err(|e| TagErrorKind::HeaderWriteError.into_error_with_cause(e)) + .chain_err(|| TagErrorKind::HeaderWriteError) } fn add_tag(&mut self, t: Tag) -> Result<()> { @@ -120,7 +119,7 @@ impl Tagable for Value { } fn has_tag(&self, t: TagSlice) -> Result { - let tags = try!(self.read("imag.tags").map_err_into(TagErrorKind::HeaderReadError)); + let tags = try!(self.read("imag.tags").chain_err(|| TagErrorKind::HeaderReadError)); if !tags.iter().all(|t| is_match!(*t, &Value::String(_))) { return Err(TagErrorKind::TagTypeError.into()); From 5b781702cc8f93888bd68a3ee46d93955952e916 Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 3 Sep 2017 16:00:08 +0200 Subject: [PATCH 19/32] libimagentryview: Rewrite error handling --- lib/entry/libimagentryview/src/builtin/editor.rs | 5 ++--- lib/entry/libimagentryview/src/error.rs | 10 +++++----- lib/entry/libimagentryview/src/lib.rs | 2 +- 3 files changed, 8 insertions(+), 9 deletions(-) diff --git a/lib/entry/libimagentryview/src/builtin/editor.rs b/lib/entry/libimagentryview/src/builtin/editor.rs index 259d4986..be268acc 100644 --- a/lib/entry/libimagentryview/src/builtin/editor.rs +++ b/lib/entry/libimagentryview/src/builtin/editor.rs @@ -23,8 +23,8 @@ use libimagentryedit::edit::edit_in_tmpfile; use viewer::Viewer; use result::Result; +use error::ResultExt; use error::ViewErrorKind as VEK; -use error::ViewError as VE; pub struct EditorView<'a>(&'a Runtime<'a>); @@ -37,8 +37,7 @@ impl<'a> EditorView<'a> { impl<'a> Viewer for EditorView<'a> { fn view_entry(&self, e: &Entry) -> Result<()> { let mut entry = e.to_str().clone().to_string(); - edit_in_tmpfile(self.0, &mut entry) - .map_err(|e| VE::new(VEK::ViewError, Some(Box::new(e)))) + edit_in_tmpfile(self.0, &mut entry).chain_err(|| VEK::ViewError) } } diff --git a/lib/entry/libimagentryview/src/error.rs b/lib/entry/libimagentryview/src/error.rs index a7d29d52..f3d9a040 100644 --- a/lib/entry/libimagentryview/src/error.rs +++ b/lib/entry/libimagentryview/src/error.rs @@ -17,6 +17,10 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +use std::error::Error; + +use libimagerror::into::IntoError; + error_chain! { types { ViewError, ViewErrorKind, ResultExt, Result; @@ -51,10 +55,6 @@ error_chain! { } } -pub use self::error::ViewError; -pub use self::error::ViewErrorKind; -pub use self::error::MapErrInto; - impl IntoError for ViewErrorKind { type Target = ViewError; @@ -62,7 +62,7 @@ impl IntoError for ViewErrorKind { ViewError::from_kind(self) } - fn into_error_with_cause(self, cause: Box) -> Self::Target { + fn into_error_with_cause(self, _: Box) -> Self::Target { ViewError::from_kind(self) } } diff --git a/lib/entry/libimagentryview/src/lib.rs b/lib/entry/libimagentryview/src/lib.rs index 0cef0542..c7870970 100644 --- a/lib/entry/libimagentryview/src/lib.rs +++ b/lib/entry/libimagentryview/src/lib.rs @@ -40,7 +40,7 @@ extern crate toml; extern crate libimagstore; extern crate libimagrt; -#[macro_use] extern crate libimagerror; +extern crate libimagerror; extern crate libimagentryedit; pub mod error; From c9dbf76395067b5a8e8f54ec4987bf6bdfe94cf5 Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 3 Sep 2017 16:07:31 +0200 Subject: [PATCH 20/32] libimagbookmark: Rewrite error handling --- lib/domain/libimagbookmark/src/collection.rs | 26 ++++++++++---------- lib/domain/libimagbookmark/src/error.rs | 10 ++++---- lib/domain/libimagbookmark/src/lib.rs | 2 +- lib/domain/libimagbookmark/src/link.rs | 4 +-- 4 files changed, 21 insertions(+), 21 deletions(-) diff --git a/lib/domain/libimagbookmark/src/collection.rs b/lib/domain/libimagbookmark/src/collection.rs index 206e31cd..6a8e9367 100644 --- a/lib/domain/libimagbookmark/src/collection.rs +++ b/lib/domain/libimagbookmark/src/collection.rs @@ -29,7 +29,7 @@ use std::ops::DerefMut; use regex::Regex; use error::BookmarkErrorKind as BEK; -use error::MapErrInto; +use error::ResultExt; use result::Result; use module_path::ModuleEntryPath; @@ -81,14 +81,14 @@ impl<'a> BookmarkCollection<'a> { store: store, } }) - .map_err_into(BEK::StoreReadError) + .chain_err(|| BEK::StoreReadError) } pub fn get(store: &'a Store, name: &str) -> Result> { ModuleEntryPath::new(name) .into_storeid() .and_then(|id| store.get(id)) - .map_err_into(BEK::StoreReadError) + .chain_err(|| BEK::StoreReadError) .and_then(|fle| { match fle { None => Err(BEK::CollectionNotFound.into_error()), @@ -104,11 +104,11 @@ impl<'a> BookmarkCollection<'a> { ModuleEntryPath::new(name) .into_storeid() .and_then(|id| store.delete(id)) - .map_err_into(BEK::StoreReadError) + .chain_err(|| BEK::StoreReadError) } pub fn links(&self) -> Result { - self.fle.get_external_links(&self.store).map_err_into(BEK::LinkError) + self.fle.get_external_links(&self.store).chain_err(|| BEK::LinkError) } pub fn link_entries(&self) -> Result> { @@ -117,22 +117,22 @@ impl<'a> BookmarkCollection<'a> { self.fle .get_internal_links() .map(|v| v.filter(|id| is_external_link_storeid(id)).collect()) - .map_err_into(BEK::StoreReadError) + .chain_err(|| BEK::StoreReadError) } pub fn add_link(&mut self, l: Link) -> Result<()> { use link::IntoUrl; l.into_url() - .and_then(|url| self.add_external_link(self.store, url).map_err_into(BEK::LinkingError)) - .map_err_into(BEK::LinkError) + .and_then(|url| self.add_external_link(self.store, url).chain_err(|| BEK::LinkingError)) + .chain_err(|| BEK::LinkError) } pub fn get_links_matching(&self, r: Regex) -> Result> { use self::iter::IntoLinksMatchingRegexIter; self.get_external_links(self.store) - .map_err_into(BEK::LinkError) + .chain_err(|| BEK::LinkError) .map(|iter| iter.matching_regex(r)) } @@ -141,9 +141,9 @@ impl<'a> BookmarkCollection<'a> { l.into_url() .and_then(|url| { - self.remove_external_link(self.store, url).map_err_into(BEK::LinkingError) + self.remove_external_link(self.store, url).chain_err(|| BEK::LinkingError) }) - .map_err_into(BEK::LinkError) + .chain_err(|| BEK::LinkError) } } @@ -151,7 +151,7 @@ impl<'a> BookmarkCollection<'a> { pub mod iter { use link::Link; use result::Result; - use error::{MapErrInto, BookmarkErrorKind as BEK}; + use error::{ResultExt, BookmarkErrorKind as BEK}; pub struct LinkIter(I) where I: Iterator; @@ -194,7 +194,7 @@ pub mod iter { loop { let n = match self.0.next() { Some(Ok(n)) => n, - Some(Err(e)) => return Some(Err(e).map_err_into(BEK::LinkError)), + Some(Err(e)) => return Some(Err(e).chain_err(|| BEK::LinkError)), None => return None, }; diff --git a/lib/domain/libimagbookmark/src/error.rs b/lib/domain/libimagbookmark/src/error.rs index 671c0ead..34b5735d 100644 --- a/lib/domain/libimagbookmark/src/error.rs +++ b/lib/domain/libimagbookmark/src/error.rs @@ -17,6 +17,10 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +use std::error::Error; + +use libimagerror::into::IntoError; + error_chain! { types { BookmarkError, BookmarkErrorKind, ResultExt, Result; @@ -51,10 +55,6 @@ error_chain! { } } -pub use self::error::BookmarkError; -pub use self::error::BookmarkErrorKind; -pub use self::error::MapErrInto; - impl IntoError for BookmarkErrorKind { type Target = BookmarkError; @@ -62,7 +62,7 @@ impl IntoError for BookmarkErrorKind { BookmarkError::from_kind(self) } - fn into_error_with_cause(self, cause: Box) -> Self::Target { + fn into_error_with_cause(self, _: Box) -> Self::Target { BookmarkError::from_kind(self) } } diff --git a/lib/domain/libimagbookmark/src/lib.rs b/lib/domain/libimagbookmark/src/lib.rs index 7176bfcf..00d94f61 100644 --- a/lib/domain/libimagbookmark/src/lib.rs +++ b/lib/domain/libimagbookmark/src/lib.rs @@ -40,7 +40,7 @@ extern crate regex; #[macro_use] extern crate error_chain; #[macro_use] extern crate libimagstore; -#[macro_use] extern crate libimagerror; +extern crate libimagerror; extern crate libimagentrylink; module_entry_path_mod!("bookmark"); diff --git a/lib/domain/libimagbookmark/src/link.rs b/lib/domain/libimagbookmark/src/link.rs index 1da91c8a..acc68e60 100644 --- a/lib/domain/libimagbookmark/src/link.rs +++ b/lib/domain/libimagbookmark/src/link.rs @@ -67,9 +67,9 @@ impl IntoUrl for Link { fn into_url(self) -> Result { use error::BookmarkErrorKind as BEK; - use error::MapErrInto; + use error::ResultExt; - Url::parse(&self[..]).map_err_into(BEK::LinkParsingError) + Url::parse(&self[..]).chain_err(|| BEK::LinkParsingError) } } From 31dc0eebc28b0ef2d5f44107e79ead846591e59f Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 3 Sep 2017 16:09:55 +0200 Subject: [PATCH 21/32] libimagcounter: Rewrite error handling --- lib/domain/libimagcounter/src/counter.rs | 34 ++++++++++++------------ lib/domain/libimagcounter/src/error.rs | 9 ++++--- lib/domain/libimagcounter/src/lib.rs | 2 +- 3 files changed, 23 insertions(+), 22 deletions(-) diff --git a/lib/domain/libimagcounter/src/counter.rs b/lib/domain/libimagcounter/src/counter.rs index b34219a0..e23a18df 100644 --- a/lib/domain/libimagcounter/src/counter.rs +++ b/lib/domain/libimagcounter/src/counter.rs @@ -38,7 +38,7 @@ use module_path::ModuleEntryPath; use result::Result; use error::CounterError as CE; use error::CounterErrorKind as CEK; -use error::error::MapErrInto; +use error::ResultExt; pub type CounterName = String; @@ -71,8 +71,8 @@ impl<'a> Counter<'a> { let fle = { let id = try!(ModuleEntryPath::new(name.clone()) .into_storeid() - .map_err_into(CEK::StoreWriteError)); - let mut lockentry = try!(store.create(id).map_err_into(CEK::StoreWriteError)); + .chain_err(|| CEK::StoreWriteError)); + let mut lockentry = try!(store.create(id).chain_err(|| CEK::StoreWriteError)); { let entry = lockentry.deref_mut(); @@ -116,26 +116,26 @@ impl<'a> Counter<'a> { pub fn inc(&mut self) -> Result<()> { let header = self.fle.deref_mut().get_header_mut(); let query = String::from("counter.value"); - match try!(header.read(&query).map_err_into(CEK::StoreReadError)) { + match try!(header.read(&query).chain_err(|| CEK::StoreReadError)) { Some(&Value::Integer(i)) => { header.set(&query, Value::Integer(i + 1)) - .map_err_into(CEK::StoreWriteError) + .chain_err(|| CEK::StoreWriteError) .map(|_| ()) }, - _ => Err(CE::new(CEK::StoreReadError, None)), + _ => Err(CE::from_kind(CEK::StoreReadError)), } } pub fn dec(&mut self) -> Result<()> { let header = self.fle.deref_mut().get_header_mut(); let query = String::from("counter.value"); - match try!(header.read(&query).map_err_into(CEK::StoreReadError)) { + match try!(header.read(&query).chain_err(|| CEK::StoreReadError)) { Some(&Value::Integer(i)) => { header.set(&query, Value::Integer(i - 1)) - .map_err_into(CEK::StoreWriteError) + .chain_err(|| CEK::StoreWriteError) .map(|_| ()) }, - _ => Err(CE::new(CEK::StoreReadError, None)), + _ => Err(CE::from_kind(CEK::StoreReadError)), } } @@ -148,7 +148,7 @@ impl<'a> Counter<'a> { .deref_mut() .get_header_mut() .set(&String::from("counter.value"), Value::Integer(v)) - .map_err_into(CEK::StoreWriteError) + .chain_err(|| CEK::StoreWriteError) .map(|_| ()) } @@ -187,7 +187,7 @@ impl<'a> Counter<'a> { self.fle .get_header() .read(&String::from(name)) - .map_err_into(CEK::StoreWriteError) + .chain_err(|| CEK::StoreWriteError) .and_then(f) } @@ -195,7 +195,7 @@ impl<'a> Counter<'a> { debug!("Loading counter: '{}'", name); let id = try!(ModuleEntryPath::new(name) .into_storeid() - .map_err_into(CEK::StoreWriteError)); + .chain_err(|| CEK::StoreWriteError)); Counter::from_storeid(store, id) } @@ -203,14 +203,14 @@ impl<'a> Counter<'a> { debug!("Deleting counter: '{}'", name); let id = try!(ModuleEntryPath::new(name) .into_storeid() - .map_err_into(CEK::StoreWriteError)); - store.delete(id).map_err_into(CEK::StoreWriteError) + .chain_err(|| CEK::StoreWriteError)); + store.delete(id).chain_err(|| CEK::StoreWriteError) } pub fn all_counters(store: &Store) -> Result { store.retrieve_for_module("counter") .map(|iter| CounterIterator::new(store, iter)) - .map_err_into(CEK::StoreReadError) + .chain_err(|| CEK::StoreReadError) } } @@ -224,11 +224,11 @@ impl<'a> FromStoreId for Counter<'a> { fn from_storeid(store: &Store, id: StoreId) -> Result { debug!("Loading counter from storeid: '{:?}'", id); match store.retrieve(id) { - Err(e) => Err(CE::new(CEK::StoreReadError, Some(Box::new(e)))), + Err(e) => Err(e).chain_err(|| CEK::StoreReadError), Ok(c) => { let mut counter = Counter { fle: c, unit: None }; counter.read_unit() - .map_err_into(CEK::StoreReadError) + .chain_err(|| CEK::StoreReadError) .and_then(|u| { counter.unit = u; Ok(counter) diff --git a/lib/domain/libimagcounter/src/error.rs b/lib/domain/libimagcounter/src/error.rs index 7bf42d16..bca5a0b1 100644 --- a/lib/domain/libimagcounter/src/error.rs +++ b/lib/domain/libimagcounter/src/error.rs @@ -17,6 +17,10 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +use std::error::Error; + +use libimagerror::into::IntoError; + error_chain! { types { CounterError, CounterErrorKind, ResultExt, Result; @@ -51,9 +55,6 @@ error_chain! { } } -pub use self::error::CounterError; -pub use self::error::CounterErrorKind; - impl IntoError for CounterErrorKind { type Target = CounterError; @@ -61,7 +62,7 @@ impl IntoError for CounterErrorKind { CounterError::from_kind(self) } - fn into_error_with_cause(self, cause: Box) -> Self::Target { + fn into_error_with_cause(self, _: Box) -> Self::Target { CounterError::from_kind(self) } } diff --git a/lib/domain/libimagcounter/src/lib.rs b/lib/domain/libimagcounter/src/lib.rs index a023437e..6aa28b71 100644 --- a/lib/domain/libimagcounter/src/lib.rs +++ b/lib/domain/libimagcounter/src/lib.rs @@ -41,7 +41,7 @@ extern crate toml_query; #[macro_use] extern crate error_chain; #[macro_use] extern crate libimagstore; -#[macro_use] extern crate libimagerror; +extern crate libimagerror; module_entry_path_mod!("counter"); From 677a5e88864698125264f635982a5b19351fe918 Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 3 Sep 2017 16:13:08 +0200 Subject: [PATCH 22/32] libimagdiary: Rewrite error handling --- lib/domain/libimagdiary/src/diary.rs | 10 +++++----- lib/domain/libimagdiary/src/diaryid.rs | 10 +++++----- lib/domain/libimagdiary/src/error.rs | 10 +++++----- lib/domain/libimagdiary/src/iter.rs | 4 ++-- lib/domain/libimagdiary/src/lib.rs | 2 +- lib/domain/libimagdiary/src/viewer.rs | 6 +++--- 6 files changed, 21 insertions(+), 21 deletions(-) diff --git a/lib/domain/libimagdiary/src/diary.rs b/lib/domain/libimagdiary/src/diary.rs index 431b6320..6617f392 100644 --- a/lib/domain/libimagdiary/src/diary.rs +++ b/lib/domain/libimagdiary/src/diary.rs @@ -32,6 +32,7 @@ use entry::Entry; use diaryid::DiaryId; use error::DiaryError as DE; use error::DiaryErrorKind as DEK; +use error::ResultExt; use result::Result; use iter::DiaryEntryIterator; use is_in_diary::IsInDiary; @@ -67,7 +68,7 @@ impl<'a> Diary<'a> { id.into_storeid() .and_then(|id| self.store.retrieve(id)) .map(|fle| Entry::new(fle)) - .map_err(|e| DE::new(DEK::StoreWriteError, Some(Box::new(e)))) + .chain_err(|| DEK::StoreWriteError) } // Get an iterator for iterating over all entries @@ -75,18 +76,17 @@ impl<'a> Diary<'a> { self.store .retrieve_for_module("diary") .map(|iter| DiaryEntryIterator::new(self.name, self.store, iter)) - .map_err(|e| DE::new(DEK::StoreReadError, Some(Box::new(e)))) + .chain_err(|| DEK::StoreReadError) } pub fn delete_entry(&self, entry: Entry) -> Result<()> { if !entry.is_in_diary(self.name) { - return Err(DE::new(DEK::EntryNotInDiary, None)); + return Err(DE::from_kind(DEK::EntryNotInDiary)); } let id = entry.get_location().clone(); drop(entry); - self.store.delete(id) - .map_err(|e| DE::new(DEK::StoreWriteError, Some(Box::new(e)))) + self.store.delete(id).chain_err(|| DEK::StoreWriteError) } pub fn get_youngest_entry(&self) -> Option> { diff --git a/lib/domain/libimagdiary/src/diaryid.rs b/lib/domain/libimagdiary/src/diaryid.rs index da1afc42..a08f51c0 100644 --- a/lib/domain/libimagdiary/src/diaryid.rs +++ b/lib/domain/libimagdiary/src/diaryid.rs @@ -32,7 +32,7 @@ use libimagstore::store::Result as StoreResult; use error::DiaryError as DE; use error::DiaryErrorKind as DEK; -use error::MapErrInto; +use error::ResultExt; use libimagerror::into::IntoError; use module_path::ModuleEntryPath; @@ -222,21 +222,21 @@ impl FromStoreId for DiaryId { match (hour, minute) { (Some(h), Some(m)) => Ok((h, m)), - _ => return Err(DE::new(DEK::IdParseError, None)), + _ => return Err(DE::from_kind(DEK::IdParseError)), } })); let day: Result = next_component(&mut cmps) .and_then(|s| s.parse::() - .map_err_into(DEK::IdParseError)); + .chain_err(|| DEK::IdParseError)); let month: Result = next_component(&mut cmps) .and_then(|s| s.parse::() - .map_err_into(DEK::IdParseError)); + .chain_err(|| DEK::IdParseError)); let year: Result = next_component(&mut cmps) .and_then(|s| s.parse::() - .map_err_into(DEK::IdParseError)); + .chain_err(|| DEK::IdParseError)); let name = next_component(&mut cmps).map(String::from); diff --git a/lib/domain/libimagdiary/src/error.rs b/lib/domain/libimagdiary/src/error.rs index 5eb12274..fbea9795 100644 --- a/lib/domain/libimagdiary/src/error.rs +++ b/lib/domain/libimagdiary/src/error.rs @@ -17,6 +17,10 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +use std::error::Error; + +use libimagerror::into::IntoError; + error_chain! { types { DiaryError, DiaryErrorKind, ResultExt, Result; @@ -76,10 +80,6 @@ error_chain! { } } -pub use self::error::DiaryError; -pub use self::error::DiaryErrorKind; -pub use self::error::MapErrInto; - impl IntoError for DiaryErrorKind { type Target = DiaryError; @@ -87,7 +87,7 @@ impl IntoError for DiaryErrorKind { DiaryError::from_kind(self) } - fn into_error_with_cause(self, cause: Box) -> Self::Target { + fn into_error_with_cause(self, _: Box) -> Self::Target { DiaryError::from_kind(self) } } diff --git a/lib/domain/libimagdiary/src/iter.rs b/lib/domain/libimagdiary/src/iter.rs index de849872..285dc34e 100644 --- a/lib/domain/libimagdiary/src/iter.rs +++ b/lib/domain/libimagdiary/src/iter.rs @@ -27,8 +27,8 @@ use diaryid::DiaryId; use diaryid::FromStoreId; use is_in_diary::IsInDiary; use entry::Entry as DiaryEntry; -use error::DiaryError as DE; use error::DiaryErrorKind as DEK; +use error::ResultExt; use result::Result; use libimagerror::trace::trace_error; @@ -119,7 +119,7 @@ impl<'a> Iterator for DiaryEntryIterator<'a> { .store .retrieve(next) .map(|fle| DiaryEntry::new(fle)) - .map_err(|e| DE::new(DEK::StoreReadError, Some(Box::new(e)))) + .chain_err(|| DEK::StoreReadError) ); } } else { diff --git a/lib/domain/libimagdiary/src/lib.rs b/lib/domain/libimagdiary/src/lib.rs index 0ef328c5..90c14679 100644 --- a/lib/domain/libimagdiary/src/lib.rs +++ b/lib/domain/libimagdiary/src/lib.rs @@ -43,7 +43,7 @@ extern crate itertools; #[macro_use] extern crate error_chain; #[macro_use] extern crate libimagstore; -#[macro_use] extern crate libimagerror; +extern crate libimagerror; extern crate libimagentryedit; extern crate libimagentryview; extern crate libimagrt; diff --git a/lib/domain/libimagdiary/src/viewer.rs b/lib/domain/libimagdiary/src/viewer.rs index 93b155a7..9efd293f 100644 --- a/lib/domain/libimagdiary/src/viewer.rs +++ b/lib/domain/libimagdiary/src/viewer.rs @@ -21,7 +21,7 @@ use entry::Entry; use error::DiaryErrorKind as DEK; -use error::MapErrInto; +use error::ResultExt; use result::Result; use libimagentryview::viewer::Viewer; @@ -52,8 +52,8 @@ impl DiaryViewer { println!("{} :\n", id); let _ = try!(self.0 .view_entry(&entry) - .map_err_into(DEK::ViewError) - .map_err_into(DEK::IOError)); + .chain_err(|| DEK::ViewError) + .chain_err(|| DEK::IOError)); println!("\n---\n"); } From 22cff9165334bf56766f4953312426344fd0661b Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 3 Sep 2017 16:19:44 +0200 Subject: [PATCH 23/32] libimagmail: Rewrite error handling --- lib/domain/libimagmail/src/error.rs | 25 ++++++++++++++++++++----- lib/domain/libimagmail/src/hasher.rs | 14 ++++---------- lib/domain/libimagmail/src/lib.rs | 2 +- lib/domain/libimagmail/src/mail.rs | 22 +++++++++++----------- 4 files changed, 36 insertions(+), 27 deletions(-) diff --git a/lib/domain/libimagmail/src/error.rs b/lib/domain/libimagmail/src/error.rs index 65eb2b31..b3a1568c 100644 --- a/lib/domain/libimagmail/src/error.rs +++ b/lib/domain/libimagmail/src/error.rs @@ -17,17 +17,36 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +use std::error::Error; + +use libimagerror::into::IntoError; + error_chain! { types { MailError, MailErrorKind, ResultExt, Result; } + links { + RefError(::libimagentryref::error::RefError, ::libimagentryref::error::RefErrorKind); + } + + errors { RefCreationError { description("Error creating a reference to a file/directory") display("Error creating a reference to a file/directory") } + RefHandlingError { + description("Error handling a reference") + display("Error handling a reference") + } + + MailParsingError { + description("Failed to parse mail") + display("Failed to parse mail") + } + FetchByHashError { description("Error fetching mail from Store by hash") display("Error fetching mail from Store by hash") @@ -43,10 +62,6 @@ error_chain! { } } -pub use self::error::MailError; -pub use self::error::MailErrorKind; -pub use self::error::MapErrInto; - impl IntoError for MailErrorKind { type Target = MailError; @@ -54,7 +69,7 @@ impl IntoError for MailErrorKind { MailError::from_kind(self) } - fn into_error_with_cause(self, cause: Box) -> Self::Target { + fn into_error_with_cause(self, _: Box) -> Self::Target { MailError::from_kind(self) } } diff --git a/lib/domain/libimagmail/src/hasher.rs b/lib/domain/libimagmail/src/hasher.rs index cc68d9a8..d650bedd 100644 --- a/lib/domain/libimagmail/src/hasher.rs +++ b/lib/domain/libimagmail/src/hasher.rs @@ -25,11 +25,8 @@ use email::MimeMessage; use libimagentryref::hasher::Hasher; use libimagentryref::hasher::DefaultHasher; use libimagentryref::error::RefErrorKind as REK; -use libimagentryref::error::MapErrInto; +use libimagentryref::error::ResultExt; use libimagentryref::result::Result as RResult; -use libimagerror::into::IntoError; - -use error::MailErrorKind as MEK; pub struct MailHasher { defaulthasher: DefaultHasher, @@ -54,12 +51,10 @@ impl Hasher for MailHasher { use email::Header; let mut s = String::new(); - try!(c.read_to_string(&mut s).map_err_into(REK::UTF8Error).map_err_into(REK::IOError)); + try!(c.read_to_string(&mut s).chain_err(|| REK::UTF8Error).chain_err(|| REK::IOError)); MimeMessage::parse(&s) - .map_err(Box::new) - .map_err(|e| MEK::MailParsingError.into_error_with_cause(e)) - .map_err_into(REK::RefHashingError) + .chain_err(|| REK::RefHashingError) .and_then(|mail| { let has_key = |hdr: &Header, exp: &str| hdr.name == exp; @@ -73,8 +68,7 @@ impl Hasher for MailHasher { for hdr in mail.headers.iter().filter(|item| filter.filter(item)) { let s = try!(hdr .get_value() - .map_err(Box::new) - .map_err(|e| REK::RefHashingError.into_error_with_cause(e))); + .chain_err(|| REK::RefHashingError)); v.push(s); } diff --git a/lib/domain/libimagmail/src/lib.rs b/lib/domain/libimagmail/src/lib.rs index 5fd42347..09e74a5f 100644 --- a/lib/domain/libimagmail/src/lib.rs +++ b/lib/domain/libimagmail/src/lib.rs @@ -40,7 +40,7 @@ extern crate email; extern crate filters; #[macro_use] extern crate error_chain; -#[macro_use] extern crate libimagerror; +extern crate libimagerror; extern crate libimagstore; extern crate libimagentryref; diff --git a/lib/domain/libimagmail/src/mail.rs b/lib/domain/libimagmail/src/mail.rs index ede27704..17129c90 100644 --- a/lib/domain/libimagmail/src/mail.rs +++ b/lib/domain/libimagmail/src/mail.rs @@ -31,7 +31,7 @@ use email::results::ParsingResult as EmailParsingResult; use hasher::MailHasher; use result::Result; -use error::{MapErrInto, MailErrorKind as MEK}; +use error::{ResultExt, MailErrorKind as MEK}; struct Buffer(String); @@ -59,17 +59,17 @@ impl<'a> Mail<'a> { let p = PathBuf::from(p.as_ref()); Ref::create_with_hasher(store, p, f, h) - .map_err_into(MEK::RefCreationError) + .chain_err(|| MEK::RefCreationError) .and_then(|reference| { debug!("Build reference file: {:?}", reference); reference.fs_file() - .map_err_into(MEK::RefHandlingError) - .and_then(|path| File::open(path).map_err_into(MEK::IOError)) + .chain_err(|| MEK::RefHandlingError) + .and_then(|path| File::open(path).chain_err(|| MEK::IOError)) .and_then(|mut file| { let mut s = String::new(); file.read_to_string(&mut s) .map(|_| s) - .map_err_into(MEK::IOError) + .chain_err(|| MEK::IOError) }) .map(Buffer::from) .map(|buffer| Mail(reference, buffer)) @@ -80,8 +80,8 @@ impl<'a> Mail<'a> { pub fn open>(store: &Store, hash: S) -> Result> { debug!("Opening Mail by Hash"); Ref::get_by_hash(store, String::from(hash.as_ref())) - .map_err_into(MEK::FetchByHashError) - .map_err_into(MEK::FetchError) + .chain_err(|| MEK::FetchByHashError) + .chain_err(|| MEK::FetchError) .and_then(|o| match o { Some(r) => Mail::from_ref(r).map(Some), None => Ok(None), @@ -93,13 +93,13 @@ impl<'a> Mail<'a> { pub fn from_ref(r: Ref<'a>) -> Result { debug!("Building Mail object from Ref: {:?}", r); r.fs_file() - .map_err_into(MEK::RefHandlingError) - .and_then(|path| File::open(path).map_err_into(MEK::IOError)) + .chain_err(|| MEK::RefHandlingError) + .and_then(|path| File::open(path).chain_err(|| MEK::IOError)) .and_then(|mut file| { let mut s = String::new(); file.read_to_string(&mut s) .map(|_| s) - .map_err_into(MEK::IOError) + .chain_err(|| MEK::IOError) }) .map(Buffer::from) .map(|buffer| Mail(r, buffer)) @@ -109,7 +109,7 @@ impl<'a> Mail<'a> { debug!("Getting field in mail: {:?}", field); self.1 .parsed() - .map_err_into(MEK::MailParsingError) + .chain_err(|| MEK::MailParsingError) .map(|parsed| { parsed.headers .iter() From a5bb7a9becb2483839397afb8f22e15ec0a6c23e Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 3 Sep 2017 16:23:45 +0200 Subject: [PATCH 24/32] libimagtimetrack: Rewrite error handling --- lib/domain/libimagtimetrack/src/error.rs | 20 ++++++++++++++----- .../libimagtimetrack/src/iter/create.rs | 6 +++--- lib/domain/libimagtimetrack/src/iter/get.rs | 4 ++-- .../libimagtimetrack/src/iter/setendtime.rs | 4 ++-- .../libimagtimetrack/src/iter/storeid.rs | 4 ++-- lib/domain/libimagtimetrack/src/lib.rs | 3 +-- .../libimagtimetrack/src/timetracking.rs | 18 ++++++++--------- .../libimagtimetrack/src/timetrackingstore.rs | 14 ++++++------- 8 files changed, 41 insertions(+), 32 deletions(-) diff --git a/lib/domain/libimagtimetrack/src/error.rs b/lib/domain/libimagtimetrack/src/error.rs index 008074a7..3eacdc22 100644 --- a/lib/domain/libimagtimetrack/src/error.rs +++ b/lib/domain/libimagtimetrack/src/error.rs @@ -17,12 +17,26 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +use std::error::Error; + +use libimagerror::into::IntoError; + error_chain! { types { TimeTrackError, TimeTrackErrorKind, ResultExt, Result; } errors { + StoreReadError { + description("Error while writing Store") + display("Error while writing Store") + } + + StoreWriteError { + description("Error while reading Store") + display("Error while reading Store") + } + StoreIdError { description("Error while handling StoreId") display("Error while handling StoreId") @@ -52,10 +66,6 @@ error_chain! { } } -pub use self::error::TimeTrackError; -pub use self::error::TimeTrackErrorKind; -pub use self::error::MapErrInto; - impl IntoError for TimeTrackErrorKind { type Target = TimeTrackError; @@ -63,7 +73,7 @@ impl IntoError for TimeTrackErrorKind { TimeTrackError::from_kind(self) } - fn into_error_with_cause(self, cause: Box) -> Self::Target { + fn into_error_with_cause(self, _: Box) -> Self::Target { TimeTrackError::from_kind(self) } } diff --git a/lib/domain/libimagtimetrack/src/iter/create.rs b/lib/domain/libimagtimetrack/src/iter/create.rs index 0c471aa8..03047c76 100644 --- a/lib/domain/libimagtimetrack/src/iter/create.rs +++ b/lib/domain/libimagtimetrack/src/iter/create.rs @@ -24,7 +24,7 @@ use chrono::naive::NaiveDateTime as NDT; use constants::*; use error::TimeTrackError as TTE; use error::TimeTrackErrorKind as TTEK; -use error::MapErrInto; +use error::ResultExt; use iter::storeid::TagStoreIdIter; use iter::setendtime::SetEndTimeIter; @@ -61,12 +61,12 @@ impl<'a> Iterator for CreateTimeTrackIter<'a> res.and_then(|(id, starttime)| { self.store .create(id) - .map_err_into(TTEK::StoreWriteError) + .chain_err(|| TTEK::StoreWriteError) .and_then(|mut entry| { let v = Value::String(starttime.format(DATE_TIME_FORMAT).to_string()); entry.get_header_mut() .insert(DATE_TIME_START_HEADER_PATH, v) - .map_err_into(TTEK::HeaderWriteError) + .chain_err(|| TTEK::HeaderWriteError) .map(|_| entry) }) }) diff --git a/lib/domain/libimagtimetrack/src/iter/get.rs b/lib/domain/libimagtimetrack/src/iter/get.rs index 62e0a85d..a7927ff2 100644 --- a/lib/domain/libimagtimetrack/src/iter/get.rs +++ b/lib/domain/libimagtimetrack/src/iter/get.rs @@ -19,7 +19,7 @@ use error::TimeTrackError as TTE; use error::TimeTrackErrorKind as TTEK; -use error::MapErrInto; +use error::ResultExt; use libimagstore::store::FileLockEntry; use libimagstore::store::Store; @@ -46,7 +46,7 @@ impl<'a> Iterator for GetTimeTrackIter<'a> { fn next(&mut self) -> Option { self.inner.next().map(|sid| { - match self.store.get(sid).map_err_into(TTEK::StoreReadError) { + match self.store.get(sid).chain_err(|| TTEK::StoreReadError) { Ok(None) => Err(TTEK::StoreReadError.into_error()), Ok(Some(s)) => Ok(s), Err(e) => Err(e) diff --git a/lib/domain/libimagtimetrack/src/iter/setendtime.rs b/lib/domain/libimagtimetrack/src/iter/setendtime.rs index 89eb382b..778877b0 100644 --- a/lib/domain/libimagtimetrack/src/iter/setendtime.rs +++ b/lib/domain/libimagtimetrack/src/iter/setendtime.rs @@ -24,7 +24,7 @@ use chrono::naive::NaiveDateTime as NDT; use constants::*; use error::TimeTrackError as TTE; use error::TimeTrackErrorKind as TTEK; -use error::MapErrInto; +use error::ResultExt; use iter::create::CreateTimeTrackIter; use libimagstore::store::FileLockEntry; @@ -55,7 +55,7 @@ impl<'a> Iterator for SetEndTimeIter<'a> { let v = Value::String(self.datetime.format(DATE_TIME_FORMAT).to_string()); fle.get_header_mut() .insert(DATE_TIME_END_HEADER_PATH, v) - .map_err_into(TTEK::HeaderWriteError) + .chain_err(|| TTEK::HeaderWriteError) .map(|_| fle) }) }) diff --git a/lib/domain/libimagtimetrack/src/iter/storeid.rs b/lib/domain/libimagtimetrack/src/iter/storeid.rs index a3071908..0a68e92c 100644 --- a/lib/domain/libimagtimetrack/src/iter/storeid.rs +++ b/lib/domain/libimagtimetrack/src/iter/storeid.rs @@ -22,7 +22,7 @@ use chrono::naive::NaiveDateTime as NDT; use constants::*; use error::TimeTrackError; use error::TimeTrackErrorKind as TTEK; -use error::MapErrInto; +use error::ResultExt; use iter::tag::TagIter; use iter::create::CreateTimeTrackIter; @@ -64,7 +64,7 @@ impl Iterator for TagStoreIdIter { let id_str = format!("{}-{}", dt, tag.as_str()); ModuleEntryPath::new(id_str) .into_storeid() - .map_err_into(TTEK::StoreIdError) + .chain_err(|| TTEK::StoreIdError) .map(|id| (id, self.datetime.clone())) }) }) diff --git a/lib/domain/libimagtimetrack/src/lib.rs b/lib/domain/libimagtimetrack/src/lib.rs index 69e5a086..0a14a664 100644 --- a/lib/domain/libimagtimetrack/src/lib.rs +++ b/lib/domain/libimagtimetrack/src/lib.rs @@ -45,12 +45,11 @@ extern crate lazy_static; extern crate is_match; #[macro_use] extern crate error_chain; -#[macro_use] -extern crate libimagerror; #[macro_use] extern crate libimagstore; extern crate libimagentrydatetime; extern crate libimagentrytag; +extern crate libimagerror; mod constants; pub mod error; diff --git a/lib/domain/libimagtimetrack/src/timetracking.rs b/lib/domain/libimagtimetrack/src/timetracking.rs index ba40ac65..481d93a2 100644 --- a/lib/domain/libimagtimetrack/src/timetracking.rs +++ b/lib/domain/libimagtimetrack/src/timetracking.rs @@ -31,7 +31,7 @@ use libimagerror::into::IntoError; use tag::TimeTrackingTag as TTT; use error::TimeTrackErrorKind as TTEK; -use error::MapErrInto; +use error::ResultExt; use result::Result; use constants::*; @@ -65,7 +65,7 @@ impl TimeTracking for Entry { fn get_timetrack_tag(&self) -> Result { self.get_header() .read(DATE_TIME_TAG_HEADER_PATH) - .map_err_into(TTEK::HeaderReadError) + .chain_err(|| TTEK::HeaderReadError) .and_then(|value| match value { Some(&Value::String(ref s)) => Ok(s.clone().into()), Some(_) => Err(TTEK::HeaderFieldTypeError.into_error()), @@ -78,21 +78,21 @@ impl TimeTracking for Entry { self.get_header_mut() .insert(DATE_TIME_START_HEADER_PATH, Value::String(s)) - .map_err_into(TTEK::HeaderWriteError) + .chain_err(|| TTEK::HeaderWriteError) .map(|_| ()) } fn get_start_datetime(&self) -> Result> { self.get_header() .read(DATE_TIME_START_HEADER_PATH) - .map_err_into(TTEK::HeaderReadError) + .chain_err(|| TTEK::HeaderReadError) .and_then(header_value_to_dt) } fn delete_start_datetime(&mut self) -> Result<()> { self.get_header_mut() .delete(DATE_TIME_START_HEADER_PATH) - .map_err_into(TTEK::HeaderWriteError) + .chain_err(|| TTEK::HeaderWriteError) .map(|_| ()) } @@ -101,21 +101,21 @@ impl TimeTracking for Entry { self.get_header_mut() .insert(DATE_TIME_END_HEADER_PATH, Value::String(s)) - .map_err_into(TTEK::HeaderWriteError) + .chain_err(|| TTEK::HeaderWriteError) .map(|_| ()) } fn get_end_datetime(&self) -> Result> { self.get_header() .read(DATE_TIME_END_HEADER_PATH) - .map_err_into(TTEK::HeaderReadError) + .chain_err(|| TTEK::HeaderReadError) .and_then(header_value_to_dt) } fn delete_end_datetime(&mut self) -> Result<()> { self.get_header_mut() .delete(DATE_TIME_END_HEADER_PATH) - .map_err_into(TTEK::HeaderWriteError) + .chain_err(|| TTEK::HeaderWriteError) .map(|_| ()) } @@ -141,7 +141,7 @@ fn header_value_to_dt(val: Option<&Value>) -> Result> { match val { Some(&Value::String(ref s)) => { NaiveDateTime::parse_from_str(s, DATE_TIME_FORMAT) - .map_err_into(TTEK::DateTimeParserError) + .chain_err(|| TTEK::DateTimeParserError) .map(Some) }, diff --git a/lib/domain/libimagtimetrack/src/timetrackingstore.rs b/lib/domain/libimagtimetrack/src/timetrackingstore.rs index 94e993ac..ccd03fd5 100644 --- a/lib/domain/libimagtimetrack/src/timetrackingstore.rs +++ b/lib/domain/libimagtimetrack/src/timetrackingstore.rs @@ -33,7 +33,7 @@ use libimagentrydatetime::datepath::compiler::DatePathCompiler; use result::Result; use constants::*; use error::TimeTrackErrorKind as TTEK; -use error::MapErrInto; +use error::ResultExt; use iter::get::GetTimeTrackIter; use tag::TimeTrackingTag as TTT; @@ -71,24 +71,24 @@ impl<'a> TimeTrackStore<'a> for Store { use std::path::PathBuf; COMPILER.compile(CRATE_NAME, start) - .map_err_into(TTEK::StoreIdError) + .chain_err(|| TTEK::StoreIdError) .map(|mut id| { id.local_push(PathBuf::from(ts.as_str())); id }) - .and_then(|id| self.create(id).map_err_into(TTEK::StoreWriteError)) + .and_then(|id| self.create(id).chain_err(|| TTEK::StoreWriteError)) .and_then(|mut fle| { let v = Value::String(ts.as_str().to_owned()); fle.get_header_mut() .insert(DATE_TIME_TAG_HEADER_PATH, v) - .map_err_into(TTEK::HeaderWriteError) + .chain_err(|| TTEK::HeaderWriteError) .map(|_| fle) }) .and_then(|mut fle| { let v = Value::String(start.format(DATE_TIME_FORMAT).to_string()); fle.get_header_mut() .insert(DATE_TIME_START_HEADER_PATH, v) - .map_err_into(TTEK::HeaderWriteError) + .chain_err(|| TTEK::HeaderWriteError) .map(|_| fle) }) } @@ -99,14 +99,14 @@ impl<'a> TimeTrackStore<'a> for Store { let v = Value::String(end.format(DATE_TIME_FORMAT).to_string()); fle.get_header_mut() .insert(DATE_TIME_END_HEADER_PATH, v) - .map_err_into(TTEK::HeaderWriteError) + .chain_err(|| TTEK::HeaderWriteError) .map(|_| fle) }) } fn get_timetrackings(&'a self) -> Result> { self.retrieve_for_module(CRATE_NAME) - .map_err_into(TTEK::StoreReadError) + .chain_err(|| TTEK::StoreReadError) .map(|iter| GetTimeTrackIter::new(iter, self)) } From 936a314efa25225c5f3c36e5732edb308de08479 Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 3 Sep 2017 16:31:59 +0200 Subject: [PATCH 25/32] libimagtodo: Rewrite error handling --- lib/domain/libimagtodo/src/error.rs | 18 +++++++------- lib/domain/libimagtodo/src/lib.rs | 2 +- lib/domain/libimagtodo/src/task.rs | 37 +++++++++++++++-------------- 3 files changed, 29 insertions(+), 28 deletions(-) diff --git a/lib/domain/libimagtodo/src/error.rs b/lib/domain/libimagtodo/src/error.rs index bfb508d2..dffe9bb1 100644 --- a/lib/domain/libimagtodo/src/error.rs +++ b/lib/domain/libimagtodo/src/error.rs @@ -17,6 +17,10 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +use std::error::Error; + +use libimagerror::into::IntoError; + error_chain! { types { TodoError, TodoErrorKind, ResultExt, Result; @@ -24,7 +28,7 @@ error_chain! { errors { ConversionError { - description("Conversion Error"") + description("Conversion Error") display("Conversion Error") } @@ -44,17 +48,13 @@ error_chain! { } UTF8Error { - description("Encountered non-UTF8 characters while reading input) - display("Encountered non-UTF8 characters while reading input) + description("Encountered non-UTF8 characters while reading input") + display("Encountered non-UTF8 characters while reading input") } } } -pub use self::error::TodoError; -pub use self::error::TodoErrorKind; -pub use self::error::MapErrInto; - impl IntoError for TodoErrorKind { type Target = TodoError; @@ -62,7 +62,7 @@ impl IntoError for TodoErrorKind { TodoError::from_kind(self) } - fn into_error_with_cause(self, cause: Box) -> Self::Target { + fn into_error_with_cause(self, _: Box) -> Self::Target { TodoError::from_kind(self) } - } +} diff --git a/lib/domain/libimagtodo/src/lib.rs b/lib/domain/libimagtodo/src/lib.rs index 7c1da19e..78e4bab4 100644 --- a/lib/domain/libimagtodo/src/lib.rs +++ b/lib/domain/libimagtodo/src/lib.rs @@ -43,7 +43,7 @@ extern crate serde_json; #[macro_use] extern crate error_chain; #[macro_use] extern crate libimagstore; -#[macro_use] extern crate libimagerror; +extern crate libimagerror; extern crate task_hookrs; module_entry_path_mod!("todo"); diff --git a/lib/domain/libimagtodo/src/task.rs b/lib/domain/libimagtodo/src/task.rs index 3dbbd04c..3dc5c780 100644 --- a/lib/domain/libimagtodo/src/task.rs +++ b/lib/domain/libimagtodo/src/task.rs @@ -32,7 +32,8 @@ use libimagstore::store::{FileLockEntry, Store}; use libimagstore::storeid::{IntoStoreId, StoreIdIterator, StoreId}; use module_path::ModuleEntryPath; -use error::{TodoErrorKind as TEK, MapErrInto}; +use error::{TodoErrorKind as TEK, ResultExt}; +use error::TodoError as TE; use result::Result; /// Task struct containing a `FileLockEntry` @@ -48,9 +49,9 @@ impl<'a> Task<'a> { pub fn import(store: &'a Store, mut r: R) -> Result<(Task<'a>, String, Uuid)> { let mut line = String::new(); - try!(r.read_line(&mut line).map_err_into(TEK::UTF8Error)); + try!(r.read_line(&mut line).chain_err(|| TEK::UTF8Error)); import_task(&line.as_str()) - .map_err_into(TEK::ImportError) + .map_err(|_| TE::from_kind(TEK::ImportError)) .and_then(|t| { let uuid = t.uuid().clone(); t.into_task(store).map(|t| (t, line, uuid)) @@ -70,7 +71,7 @@ impl<'a> Task<'a> { where R: BufRead { let mut line = String::new(); - try!(r.read_line(&mut line).map_err_into(TEK::UTF8Error)); + try!(r.read_line(&mut line).chain_err(|| TEK::UTF8Error)); Task::get_from_string(store, line) } @@ -80,7 +81,7 @@ impl<'a> Task<'a> { /// For an explanation on the return values see `Task::get_from_import()`. pub fn get_from_string(store: &'a Store, s: String) -> Result, String>> { import_task(s.as_str()) - .map_err_into(TEK::ImportError) + .map_err(|_| TE::from_kind(TEK::ImportError)) .map(|t| t.uuid().clone()) .and_then(|uuid| Task::get_from_uuid(store, uuid)) .and_then(|o| match o { @@ -97,14 +98,14 @@ impl<'a> Task<'a> { .into_storeid() .and_then(|store_id| store.get(store_id)) .map(|o| o.map(Task::new)) - .map_err_into(TEK::StoreError) + .chain_err(|| TEK::StoreError) } /// Same as Task::get_from_import() but uses Store::retrieve() rather than Store::get(), to /// implicitely create the task if it does not exist. pub fn retrieve_from_import(store: &'a Store, mut r: R) -> Result> { let mut line = String::new(); - try!(r.read_line(&mut line).map_err_into(TEK::UTF8Error)); + try!(r.read_line(&mut line).chain_err(|| TEK::UTF8Error)); Task::retrieve_from_string(store, line) } @@ -115,7 +116,7 @@ impl<'a> Task<'a> { .and_then(|opt| match opt { Ok(task) => Ok(task), Err(string) => import_task(string.as_str()) - .map_err_into(TEK::ImportError) + .map_err(|_| TE::from_kind(TEK::ImportError)) .and_then(|t| t.into_task(store)), }) } @@ -132,7 +133,7 @@ impl<'a> Task<'a> { // task before the change, and the second one after // the change. The (maybe modified) second one is // expected by taskwarrior. - match serde_to_string(&ttask).map_err_into(TEK::ImportError) { + match serde_to_string(&ttask).chain_err(|| TEK::ImportError) { // use println!() here, as we talk with TW Ok(val) => println!("{}", val), Err(e) => return Err(e), @@ -151,7 +152,7 @@ impl<'a> Task<'a> { } } // end if c % 2 }, - Err(e) => return Err(e).map_err_into(TEK::ImportError), + Err(e) => return Err(e).map_err(|_| TE::from_kind(TEK::ImportError)), } } Ok(()) @@ -161,12 +162,12 @@ impl<'a> Task<'a> { ModuleEntryPath::new(format!("taskwarrior/{}", uuid)) .into_storeid() .and_then(|id| store.delete(id)) - .map_err_into(TEK::StoreError) + .chain_err(|| TEK::StoreError) } pub fn all_as_ids(store: &Store) -> Result { store.retrieve_for_module("todo/taskwarrior") - .map_err_into(TEK::StoreError) + .chain_err(|| TEK::StoreError) } pub fn all(store: &Store) -> Result { @@ -223,21 +224,21 @@ impl<'a> IntoTask<'a> for TTask { let uuid = self.uuid(); ModuleEntryPath::new(format!("taskwarrior/{}", uuid)) .into_storeid() - .map_err_into(TEK::StoreIdError) + .chain_err(|| TEK::StoreIdError) .and_then(|id| { store.retrieve(id) - .map_err_into(TEK::StoreError) + .chain_err(|| TEK::StoreError) .and_then(|mut fle| { { let hdr = fle.get_header_mut(); - if try!(hdr.read("todo").map_err_into(TEK::StoreError)).is_none() { + if try!(hdr.read("todo").chain_err(|| TEK::StoreError)).is_none() { try!(hdr .set("todo", Value::Table(BTreeMap::new())) - .map_err_into(TEK::StoreError)); + .chain_err(|| TEK::StoreError)); } try!(hdr.set("todo.uuid", Value::String(format!("{}",uuid))) - .map_err_into(TEK::StoreError)); + .chain_err(|| TEK::StoreError)); } // If none of the errors above have returned the function, everything is fine @@ -256,7 +257,7 @@ impl<'a> FromStoreId for Task<'a> { fn from_storeid<'b>(store: &'b Store, id: StoreId) -> Result> { store.retrieve(id) - .map_err_into(TEK::StoreError) + .chain_err(|| TEK::StoreError) .map(Task::new) } } From 54219cb6fab458ee43e84eeb25ba4ba1c73b37ea Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 3 Sep 2017 20:41:43 +0200 Subject: [PATCH 26/32] imag-store: Rewrite error handling --- bin/core/imag-store/src/create.rs | 7 ++++--- bin/core/imag-store/src/error.rs | 9 +++++---- bin/core/imag-store/src/main.rs | 2 +- 3 files changed, 10 insertions(+), 8 deletions(-) diff --git a/bin/core/imag-store/src/create.rs b/bin/core/imag-store/src/create.rs index f434ba75..d4fb9421 100644 --- a/bin/core/imag-store/src/create.rs +++ b/bin/core/imag-store/src/create.rs @@ -38,6 +38,7 @@ use libimagutil::debug_result::*; use error::StoreError; use error::StoreErrorKind; +use error::ResultExt; use util::build_toml_header; type Result = RResult; @@ -110,7 +111,7 @@ fn create_from_cli_spec(rt: &Runtime, matches: &ArgMatches, path: &StoreId) -> R fn create_from_source(rt: &Runtime, matches: &ArgMatches, path: &StoreId) -> Result<()> { let content = matches .value_of("from-raw") - .ok_or(StoreError::new(StoreErrorKind::NoCommandlineCall, None)) + .ok_or(StoreError::from_kind(StoreErrorKind::NoCommandlineCall)) .map(string_from_raw_src); if content.is_err() { @@ -133,7 +134,7 @@ fn create_from_source(rt: &Runtime, matches: &ArgMatches, path: &StoreId) -> Res r }) .map_dbg_err(|e| format!("Error storing entry: {:?}", e)) - .map_err(|serr| StoreError::new(StoreErrorKind::BackendError, Some(Box::new(serr)))) + .chain_err(|| StoreErrorKind::BackendError) } fn create_with_content_and_header(rt: &Runtime, @@ -157,7 +158,7 @@ fn create_with_content_and_header(rt: &Runtime, debug!("New header set"); } }) - .map_err(|e| StoreError::new(StoreErrorKind::BackendError, Some(Box::new(e)))) + .chain_err(|| StoreErrorKind::BackendError) } fn string_from_raw_src(raw_src: &str) -> String { diff --git a/bin/core/imag-store/src/error.rs b/bin/core/imag-store/src/error.rs index 163ae344..3e4f5d02 100644 --- a/bin/core/imag-store/src/error.rs +++ b/bin/core/imag-store/src/error.rs @@ -17,6 +17,10 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +use std::error::Error; + +use libimagerror::into::IntoError; + error_chain! { types { StoreError, StoreErrorKind, ResultExt, Result; @@ -36,9 +40,6 @@ error_chain! { } } -pub use self::error::StoreError; -pub use self::error::StoreErrorKind; - impl IntoError for StoreErrorKind { type Target = StoreError; @@ -46,7 +47,7 @@ impl IntoError for StoreErrorKind { StoreError::from_kind(self) } - fn into_error_with_cause(self, cause: Box) -> Self::Target { + fn into_error_with_cause(self, _: Box) -> Self::Target { StoreError::from_kind(self) } } diff --git a/bin/core/imag-store/src/main.rs b/bin/core/imag-store/src/main.rs index 45212628..434c84a8 100644 --- a/bin/core/imag-store/src/main.rs +++ b/bin/core/imag-store/src/main.rs @@ -41,7 +41,7 @@ extern crate toml; extern crate libimagrt; extern crate libimagstore; extern crate libimagutil; -#[macro_use] extern crate libimagerror; +extern crate libimagerror; use libimagrt::setup::generate_runtime_setup; From 69b3fe52c624613bdc87703341ef516078977982 Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 3 Sep 2017 20:45:23 +0200 Subject: [PATCH 27/32] imag-diary: Rewrite error handling --- bin/domain/imag-diary/src/create.rs | 4 ++-- bin/domain/imag-diary/src/edit.rs | 4 ++-- bin/domain/imag-diary/src/list.rs | 4 ++-- 3 files changed, 6 insertions(+), 6 deletions(-) diff --git a/bin/domain/imag-diary/src/create.rs b/bin/domain/imag-diary/src/create.rs index 78f679a7..e49cae25 100644 --- a/bin/domain/imag-diary/src/create.rs +++ b/bin/domain/imag-diary/src/create.rs @@ -22,7 +22,7 @@ use std::process::exit; use libimagdiary::diary::Diary; use libimagdiary::diaryid::DiaryId; use libimagdiary::error::DiaryErrorKind as DEK; -use libimagdiary::error::MapErrInto; +use libimagdiary::error::ResultExt; use libimagentryedit::edit::Edit; use libimagrt::runtime::Runtime; use libimagerror::trace::trace_error; @@ -110,7 +110,7 @@ pub fn create(rt: &Runtime) { Ok(()) } else { debug!("Editing new diary entry"); - entry.edit_content(rt).map_err_into(DEK::DiaryEditError) + entry.edit_content(rt).chain_err(|| DEK::DiaryEditError) } }); diff --git a/bin/domain/imag-diary/src/edit.rs b/bin/domain/imag-diary/src/edit.rs index 1cd5f9e5..a5f5e616 100644 --- a/bin/domain/imag-diary/src/edit.rs +++ b/bin/domain/imag-diary/src/edit.rs @@ -22,7 +22,7 @@ use chrono::naive::NaiveDateTime; use libimagdiary::diary::Diary; use libimagdiary::diaryid::DiaryId; use libimagdiary::error::DiaryErrorKind as DEK; -use libimagdiary::error::MapErrInto; +use libimagdiary::error::ResultExt; use libimagentryedit::edit::Edit; use libimagrt::runtime::Runtime; use libimagerror::trace::MapErrTrace; @@ -51,7 +51,7 @@ pub fn edit(rt: &Runtime) { }; match to_edit { - Some(Ok(mut e)) => e.edit_content(rt).map_err_into(DEK::IOError), + Some(Ok(mut e)) => e.edit_content(rt).chain_err(|| DEK::IOError), Some(Err(e)) => Err(e), None => Err(DEK::EntryNotInDiary.into_error()), diff --git a/bin/domain/imag-diary/src/list.rs b/bin/domain/imag-diary/src/list.rs index 4ed3123c..f915712f 100644 --- a/bin/domain/imag-diary/src/list.rs +++ b/bin/domain/imag-diary/src/list.rs @@ -19,7 +19,7 @@ use libimagdiary::diary::Diary; use libimagdiary::error::DiaryErrorKind as DEK; -use libimagdiary::error::MapErrInto; +use libimagdiary::error::ResultExt; use libimagentrylist::listers::core::CoreLister; use libimagentrylist::lister::Lister; use libimagrt::runtime::Runtime; @@ -59,7 +59,7 @@ pub fn list(rt: &Runtime) { CoreLister::new(&entry_to_location_listing_string) .list(es) - .map_err_into(DEK::IOError) + .chain_err(|| DEK::IOError) }) .map_dbg_str("Ok") .map_err_trace() From 2b845c773b4524769a86a418c26c658fea3e5162 Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 3 Sep 2017 20:46:32 +0200 Subject: [PATCH 28/32] imag-mail: Rewrite error handling --- bin/domain/imag-mail/src/main.rs | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/bin/domain/imag-mail/src/main.rs b/bin/domain/imag-mail/src/main.rs index 5fd6d1d4..02c107c5 100644 --- a/bin/domain/imag-mail/src/main.rs +++ b/bin/domain/imag-mail/src/main.rs @@ -68,14 +68,14 @@ fn import_mail(rt: &Runtime) { fn list(rt: &Runtime) { use libimagmail::error::MailErrorKind as MEK; - use libimagmail::error::MapErrInto; + use libimagmail::error::ResultExt; let store = rt.store(); let iter = match store.retrieve_for_module("ref") { Ok(iter) => iter.filter_map(|id| { Ref::get(store, id) - .map_err_into(MEK::RefHandlingError) + .chain_err(|| MEK::RefHandlingError) .and_then(|rf| Mail::from_ref(rf)) .map_err_trace() .ok() From 28d7085b2dbef61b95e41f05a276b256d66918dc Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 3 Sep 2017 20:48:51 +0200 Subject: [PATCH 29/32] Remove error_chain dependency, not needed --- lib/core/libimagerror/Cargo.toml | 1 - lib/core/libimagerror/src/lib.rs | 3 --- 2 files changed, 4 deletions(-) diff --git a/lib/core/libimagerror/Cargo.toml b/lib/core/libimagerror/Cargo.toml index fbfd1bbb..5f490746 100644 --- a/lib/core/libimagerror/Cargo.toml +++ b/lib/core/libimagerror/Cargo.toml @@ -16,4 +16,3 @@ homepage = "http://imag-pim.org" [dependencies] log = "0.3" ansi_term = "0.9" -error-chain = "0.10" diff --git a/lib/core/libimagerror/src/lib.rs b/lib/core/libimagerror/src/lib.rs index e66b6b06..df0534ba 100644 --- a/lib/core/libimagerror/src/lib.rs +++ b/lib/core/libimagerror/src/lib.rs @@ -36,9 +36,6 @@ #[macro_use] extern crate log; extern crate ansi_term; -#[cfg(test)] -#[macro_use] extern crate error_chain; - pub mod into; pub mod trace; pub mod iter; From 7ce44e80905cc60c656e385c7d1a4bb769f2c115 Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 3 Sep 2017 21:28:36 +0200 Subject: [PATCH 30/32] Remove "IntoError" trait, use error_chain functionality --- bin/core/imag-store/src/error.rs | 15 ------ bin/domain/imag-diary/src/edit.rs | 4 +- lib/core/libimagerror/src/into.rs | 33 ------------- lib/core/libimagerror/src/iter.rs | 4 +- lib/core/libimagerror/src/lib.rs | 1 - lib/core/libimagrt/src/configuration.rs | 31 +++--------- lib/core/libimagstore/src/error.rs | 14 ------ .../src/file_abstraction/inmemory.rs | 14 +++--- .../src/file_abstraction/stdio/mod.rs | 4 +- .../src/file_abstraction/stdio/out.rs | 5 +- lib/core/libimagstore/src/store.rs | 15 +++--- lib/core/libimagstore/src/storeid.rs | 4 +- lib/domain/libimagbookmark/src/collection.rs | 4 +- lib/domain/libimagbookmark/src/error.rs | 15 ------ lib/domain/libimagcounter/src/counter.rs | 21 ++++---- lib/domain/libimagcounter/src/error.rs | 15 ------ lib/domain/libimagdiary/src/diaryid.rs | 5 +- lib/domain/libimagdiary/src/error.rs | 15 ------ lib/domain/libimagmail/src/error.rs | 15 ------ lib/domain/libimagnotes/src/error.rs | 15 ------ lib/domain/libimagnotes/src/note.rs | 4 +- lib/domain/libimagtimetrack/src/error.rs | 15 ------ lib/domain/libimagtimetrack/src/iter/get.rs | 3 +- lib/domain/libimagtimetrack/src/iter/tag.rs | 4 +- .../libimagtimetrack/src/timetracking.rs | 8 ++-- lib/domain/libimagtodo/src/error.rs | 15 ------ .../src/annotateable.rs | 4 +- .../src/annotation_fetcher.rs | 4 +- lib/entry/libimagentryannotation/src/error.rs | 15 ------ .../libimagentrycategory/src/category.rs | 8 ++-- lib/entry/libimagentrycategory/src/error.rs | 15 ------ .../libimagentrycategory/src/register.rs | 8 ++-- .../src/datepath/error.rs | 15 ------ .../libimagentrydatetime/src/datetime.rs | 20 ++++---- lib/entry/libimagentrydatetime/src/error.rs | 15 ------ lib/entry/libimagentrydatetime/src/range.rs | 5 +- lib/entry/libimagentryedit/src/edit.rs | 4 +- lib/entry/libimagentryedit/src/error.rs | 16 ------- lib/entry/libimagentrylink/src/error.rs | 14 ------ lib/entry/libimagentrylink/src/external.rs | 6 +-- lib/entry/libimagentrylink/src/internal.rs | 19 ++++---- lib/entry/libimagentrylist/src/cli.rs | 4 +- lib/entry/libimagentrylist/src/error.rs | 15 ------ .../libimagentrylist/src/listers/table.rs | 4 +- lib/entry/libimagentrymarkdown/src/error.rs | 16 ------- lib/entry/libimagentrymarkdown/src/html.rs | 5 +- lib/entry/libimagentrymarkdown/src/link.rs | 6 +-- lib/entry/libimagentryref/src/error.rs | 15 ------ lib/entry/libimagentryref/src/reference.rs | 48 +++++++++---------- lib/entry/libimagentrytag/src/error.rs | 15 ------ lib/entry/libimagentrytag/src/tagable.rs | 6 +-- lib/entry/libimagentryview/src/error.rs | 15 ------ lib/etc/libimaginteraction/src/error.rs | 15 ------ lib/etc/libimaginteraction/src/readline.rs | 11 +++-- lib/etc/libimaginteraction/src/ui.rs | 4 +- 55 files changed, 131 insertions(+), 514 deletions(-) delete mode 100644 lib/core/libimagerror/src/into.rs diff --git a/bin/core/imag-store/src/error.rs b/bin/core/imag-store/src/error.rs index 3e4f5d02..59f9dc78 100644 --- a/bin/core/imag-store/src/error.rs +++ b/bin/core/imag-store/src/error.rs @@ -17,10 +17,6 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -use std::error::Error; - -use libimagerror::into::IntoError; - error_chain! { types { StoreError, StoreErrorKind, ResultExt, Result; @@ -40,14 +36,3 @@ error_chain! { } } -impl IntoError for StoreErrorKind { - type Target = StoreError; - - fn into_error(self) -> Self::Target { - StoreError::from_kind(self) - } - - fn into_error_with_cause(self, _: Box) -> Self::Target { - StoreError::from_kind(self) - } -} diff --git a/bin/domain/imag-diary/src/edit.rs b/bin/domain/imag-diary/src/edit.rs index a5f5e616..b83e916b 100644 --- a/bin/domain/imag-diary/src/edit.rs +++ b/bin/domain/imag-diary/src/edit.rs @@ -22,11 +22,11 @@ use chrono::naive::NaiveDateTime; use libimagdiary::diary::Diary; use libimagdiary::diaryid::DiaryId; use libimagdiary::error::DiaryErrorKind as DEK; +use libimagdiary::error::DiaryError as DE; use libimagdiary::error::ResultExt; use libimagentryedit::edit::Edit; use libimagrt::runtime::Runtime; use libimagerror::trace::MapErrTrace; -use libimagerror::into::IntoError; use libimagtimeui::datetime::DateTime; use libimagtimeui::parse::Parse; use libimagutil::warn_exit::warn_exit; @@ -54,7 +54,7 @@ pub fn edit(rt: &Runtime) { Some(Ok(mut e)) => e.edit_content(rt).chain_err(|| DEK::IOError), Some(Err(e)) => Err(e), - None => Err(DEK::EntryNotInDiary.into_error()), + None => Err(DE::from_kind(DEK::EntryNotInDiary)), } .map_err_trace().ok(); } diff --git a/lib/core/libimagerror/src/into.rs b/lib/core/libimagerror/src/into.rs deleted file mode 100644 index bc3cfb41..00000000 --- a/lib/core/libimagerror/src/into.rs +++ /dev/null @@ -1,33 +0,0 @@ -// -// imag - the personal information management suite for the commandline -// Copyright (C) 2015, 2016 Matthias Beyer and contributors -// -// This library is free software; you can redistribute it and/or -// modify it under the terms of the GNU Lesser General Public -// License as published by the Free Software Foundation; version -// 2.1 of the License. -// -// This library is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Lesser General Public License for more details. -// -// You should have received a copy of the GNU Lesser General Public -// License along with this library; if not, write to the Free Software -// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA -// - -use std::error::Error; - -/// Trait to help converting Error kinds into Error instances -pub trait IntoError { - type Target: Error; - - /// Convert the type into an error with no cause - fn into_error(self) -> Self::Target; - - /// Convert the type into an error with cause - fn into_error_with_cause(self, cause: Box) -> Self::Target; - -} - diff --git a/lib/core/libimagerror/src/iter.rs b/lib/core/libimagerror/src/iter.rs index 0297bc6a..3de78922 100644 --- a/lib/core/libimagerror/src/iter.rs +++ b/lib/core/libimagerror/src/iter.rs @@ -168,10 +168,10 @@ impl TraceIterator for I where #[cfg(test)] mod test { use super::TraceIterator; - + #[derive(Copy, Clone, Eq, PartialEq, Debug)] struct TestError(i32); - + #[test] fn test_unwrap_with() { let original = vec![Ok(1), Err(TestError(2)), Ok(3), Err(TestError(4))]; diff --git a/lib/core/libimagerror/src/lib.rs b/lib/core/libimagerror/src/lib.rs index df0534ba..73d6ed70 100644 --- a/lib/core/libimagerror/src/lib.rs +++ b/lib/core/libimagerror/src/lib.rs @@ -36,6 +36,5 @@ #[macro_use] extern crate log; extern crate ansi_term; -pub mod into; pub mod trace; pub mod iter; diff --git a/lib/core/libimagrt/src/configuration.rs b/lib/core/libimagrt/src/configuration.rs index 3274e5c4..87eb86c8 100644 --- a/lib/core/libimagrt/src/configuration.rs +++ b/lib/core/libimagrt/src/configuration.rs @@ -23,8 +23,6 @@ use std::ops::Deref; use toml::Value; use clap::App; -use std::error::Error; - error_chain! { types { ConfigError, ConfigErrorKind, ResultExt, Result; @@ -57,20 +55,8 @@ error_chain! { } } } - -use libimagerror::into::IntoError; - -impl IntoError for ConfigErrorKind { - type Target = ConfigError; - - fn into_error(self) -> Self::Target { - ConfigError::from_kind(self) - } - - fn into_error_with_cause(self, _: Box) -> Self::Target { - ConfigError::from_kind(self) - } -} +use self::ConfigErrorKind as CEK; +use self::ConfigError as CE; /// `Configuration` object /// @@ -160,8 +146,6 @@ impl Configuration { pub fn override_config(&mut self, v: Vec) -> Result<()> { use libimagutil::key_value_split::*; use libimagutil::iter::*; - use self::ConfigErrorKind as CEK; - use libimagerror::into::IntoError; use toml_query::read::TomlValueReadExt; @@ -184,14 +168,13 @@ impl Configuration { info!("Successfully overridden: {} = {}", k, v); Ok(v) }, - None => Err(CEK::ConfigOverrideTypeNotMatching.into_error()), + None => Err(CE::from_kind(CEK::ConfigOverrideTypeNotMatching)), }, - None => Err(CEK::ConfigOverrideKeyNotAvailable.into_error()), + None => Err(CE::from_kind(CEK::ConfigOverrideKeyNotAvailable)), }) ) .fold_result(|i| i) - .map_err(Box::new) - .map_err(|e| CEK::ConfigOverrideError.into_error_with_cause(e)) + .chain_err(|| CEK::ConfigOverrideError) } } @@ -311,13 +294,13 @@ fn fetch_config(searchpath: &PathBuf) -> Result { .unwrap_or_else(|| String::from("Line unknown, Column unknown")); let _ = write!(stderr(), "Config file parser error at {}", line_col); - trace_error(&ConfigErrorKind::TOMLParserError.into_error_with_cause(Box::new(e))); + trace_error(&e); None } } }) .nth(0) - .ok_or(ConfigErrorKind::NoConfigFileFound.into()) + .ok_or(CE::from_kind(ConfigErrorKind::NoConfigFileFound)) } pub trait InternalConfiguration { diff --git a/lib/core/libimagstore/src/error.rs b/lib/core/libimagstore/src/error.rs index df20ac53..2f172e34 100644 --- a/lib/core/libimagstore/src/error.rs +++ b/lib/core/libimagstore/src/error.rs @@ -17,9 +17,6 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -use std::error::Error; -use libimagerror::into::IntoError; - error_chain! { types { StoreError, StoreErrorKind, ResultExt, Result; @@ -301,14 +298,3 @@ error_chain! { } } -impl IntoError for StoreErrorKind { - type Target = StoreError; - - fn into_error(self) -> Self::Target { - StoreError::from_kind(self) - } - - fn into_error_with_cause(self, _: Box) -> Self::Target { - StoreError::from_kind(self) - } -} diff --git a/lib/core/libimagstore/src/file_abstraction/inmemory.rs b/lib/core/libimagstore/src/file_abstraction/inmemory.rs index c1333aca..42ebf319 100644 --- a/lib/core/libimagstore/src/file_abstraction/inmemory.rs +++ b/lib/core/libimagstore/src/file_abstraction/inmemory.rs @@ -33,8 +33,6 @@ use super::Drain; use store::Entry; use storeid::StoreId; -use libimagerror::into::IntoError; - type Backend = Arc>>>; /// `FileAbstraction` type, this is the Test version! @@ -67,12 +65,12 @@ impl FileAbstractionInstance for InMemoryFileAbstractionInstance { self.fs_abstraction .lock() - .map_err(|_| SEK::LockError.into_error()) + .map_err(|_| SE::from_kind(SEK::LockError)) .and_then(|mut mtx| { mtx.get_mut() .get(&self.absent_path) .cloned() - .ok_or(SEK::FileNotFound.into_error()) + .ok_or(SE::from_kind(SEK::FileNotFound)) }) } @@ -108,7 +106,7 @@ impl InMemoryFileAbstraction { fn backend_cloned<'a>(&'a self) -> Result, SE> { self.virtual_filesystem .lock() - .map_err(|_| SEK::LockError.into_error()) + .map_err(|_| SE::from_kind(SEK::LockError)) .map(|mtx| mtx.deref().borrow().clone()) } @@ -124,7 +122,7 @@ impl FileAbstraction for InMemoryFileAbstraction { .get_mut() .remove(path) .map(|_| ()) - .ok_or(SEK::FileNotFound.into_error()) + .ok_or(SE::from_kind(SEK::FileNotFound)) } fn copy(&self, from: &PathBuf, to: &PathBuf) -> Result<(), SE> { @@ -132,7 +130,7 @@ impl FileAbstraction for InMemoryFileAbstraction { let mut mtx = self.backend().lock().expect("Locking Mutex failed"); let backend = mtx.get_mut(); - let a = try!(backend.get(from).cloned().ok_or(SEK::FileNotFound.into_error())); + let a = try!(backend.get(from).cloned().ok_or(SE::from_kind(SEK::FileNotFound))); backend.insert(to.clone(), a); debug!("Copying: {:?} -> {:?} worked", from, to); Ok(()) @@ -143,7 +141,7 @@ impl FileAbstraction for InMemoryFileAbstraction { let mut mtx = self.backend().lock().expect("Locking Mutex failed"); let backend = mtx.get_mut(); - let a = try!(backend.get(from).cloned().ok_or(SEK::FileNotFound.into_error())); + let a = try!(backend.get(from).cloned().ok_or(SE::from_kind(SEK::FileNotFound))); backend.insert(to.clone(), a); debug!("Renaming: {:?} -> {:?} worked", from, to); Ok(()) diff --git a/lib/core/libimagstore/src/file_abstraction/stdio/mod.rs b/lib/core/libimagstore/src/file_abstraction/stdio/mod.rs index 9fbb8413..4ed0b067 100644 --- a/lib/core/libimagstore/src/file_abstraction/stdio/mod.rs +++ b/lib/core/libimagstore/src/file_abstraction/stdio/mod.rs @@ -37,8 +37,6 @@ use super::Drain; use super::InMemoryFileAbstraction; use store::Entry; -use libimagerror::into::IntoError; - pub mod mapper; pub mod out; use self::mapper::Mapper; @@ -60,7 +58,7 @@ impl StdIoFileAbstraction let _ = try!(out .backend() .lock() - .map_err(|_| SEK::LockError.into_error()) + .map_err(|_| SE::from_kind(SEK::LockError)) .map(|mut mtx| out.mapper().read_to_fs(in_stream, mtx.get_mut()))); Ok(StdIoFileAbstraction(out)) diff --git a/lib/core/libimagstore/src/file_abstraction/stdio/out.rs b/lib/core/libimagstore/src/file_abstraction/stdio/out.rs index 48f2ff72..950947f2 100644 --- a/lib/core/libimagstore/src/file_abstraction/stdio/out.rs +++ b/lib/core/libimagstore/src/file_abstraction/stdio/out.rs @@ -32,7 +32,6 @@ use std::sync::Mutex; use std::ops::Deref; use libimagerror::trace::*; -use libimagerror::into::IntoError; use error::StoreErrorKind as SEK; use error::StoreError as SE; @@ -74,7 +73,7 @@ impl StdoutFileAbstraction self.mem .backend() .lock() - .map_err(|_| SEK::LockError.into_error()) + .map_err(|_| SE::from_kind(SEK::LockError)) .map(|mtx| mtx.deref().borrow().clone()) } @@ -142,7 +141,7 @@ impl FileAbstraction for StdoutFileAbstraction { fn fill(&mut self, mut d: Drain) -> Result<(), SE> { debug!("Draining into : {:?}", self); - let mut mtx = try!(self.backend().lock().map_err(|_| SEK::IoError.into_error())); + let mut mtx = try!(self.backend().lock().map_err(|_| SE::from_kind(SEK::IoError))); let backend = mtx.get_mut(); for (path, element) in d.iter() { diff --git a/lib/core/libimagstore/src/store.rs b/lib/core/libimagstore/src/store.rs index abcdbcd5..fed4ca0b 100644 --- a/lib/core/libimagstore/src/store.rs +++ b/lib/core/libimagstore/src/store.rs @@ -49,7 +49,6 @@ pub use file_abstraction::FSFileAbstraction; pub use file_abstraction::InMemoryFileAbstraction; use libimagerror::trace::trace_error; -use libimagerror::into::IntoError; use libimagutil::debug_result::*; use self::glob_store_iter::*; @@ -274,7 +273,7 @@ impl Store { warn!("Implicitely creating store directory is denied"); warn!(" -> Either because configuration does not allow it"); warn!(" -> or because there is no configuration"); - return Err(SEK::CreateStoreDirDenied.into_error()) + return Err(SE::from_kind(SEK::CreateStoreDirDenied)) .chain_err(|| SEK::FileError) .chain_err(|| SEK::IoError); } @@ -284,7 +283,7 @@ impl Store { .map_dbg_err_str("Failed")); } else if location.is_file() { debug!("Store path exists as file"); - return Err(SEK::StorePathExists.into_error()); + return Err(SE::from_kind(SEK::StorePathExists)); } let store = Store { @@ -408,13 +407,13 @@ impl Store { { let mut hsmap = match self.entries.write() { - Err(_) => return Err(SEK::LockPoisoned.into_error()).chain_err(|| SEK::CreateCallError), + Err(_) => return Err(SE::from_kind(SEK::LockPoisoned)).chain_err(|| SEK::CreateCallError), Ok(s) => s, }; if hsmap.contains_key(&id) { debug!("Cannot create, internal cache already contains: '{}'", id); - return Err(SEK::EntryAlreadyExists.into_error()).chain_err(|| SEK::CreateCallError); + return Err(SE::from_kind(SEK::EntryAlreadyExists)).chain_err(|| SEK::CreateCallError); } hsmap.insert(id.clone(), { debug!("Creating: '{}'", id); @@ -637,7 +636,7 @@ impl Store { // if the entry is currently modified by the user, we cannot drop it match entries.get(&id) { None => { - return Err(SEK::FileNotFound.into_error()).chain_err(|| SEK::DeleteCallError) + return Err(SE::from_kind(SEK::FileNotFound)).chain_err(|| SEK::DeleteCallError) }, Some(e) => if e.is_borrowed() { return Err(SE::from_kind(SEK::IdLocked)).chain_err(|| SEK::DeleteCallError) @@ -678,12 +677,12 @@ impl Store { let hsmap = try!( self.entries .write() - .map_err(|_| SEK::LockPoisoned.into_error()) + .map_err(|_| SE::from_kind(SEK::LockPoisoned)) .chain_err(|| SEK::MoveCallError) ); if hsmap.contains_key(&new_id) { - return Err(SEK::EntryAlreadyExists.into_error()).chain_err(|| SEK::MoveCallError) + return Err(SE::from_kind(SEK::EntryAlreadyExists)).chain_err(|| SEK::MoveCallError) } let old_id = entry.get_location().clone(); diff --git a/lib/core/libimagstore/src/storeid.rs b/lib/core/libimagstore/src/storeid.rs index b26eb4ac..50dd0bc7 100644 --- a/lib/core/libimagstore/src/storeid.rs +++ b/lib/core/libimagstore/src/storeid.rs @@ -31,8 +31,6 @@ use error::StoreError as SE; use error::ResultExt; use store::Result; -use libimagerror::into::IntoError; - /// The Index into the Store #[derive(Debug, Clone, Hash, Eq, PartialOrd, Ord)] pub struct StoreId { @@ -109,7 +107,7 @@ impl StoreId { .unwrap_or_else(|| self.id.clone()) .to_str() .map(String::from) - .ok_or(SEK::StoreIdHandlingError.into_error()) + .ok_or(SE::from_kind(SEK::StoreIdHandlingError)) } /// Returns the components of the `id` part of the StoreId object. diff --git a/lib/domain/libimagbookmark/src/collection.rs b/lib/domain/libimagbookmark/src/collection.rs index 6a8e9367..525500ff 100644 --- a/lib/domain/libimagbookmark/src/collection.rs +++ b/lib/domain/libimagbookmark/src/collection.rs @@ -29,6 +29,7 @@ use std::ops::DerefMut; use regex::Regex; use error::BookmarkErrorKind as BEK; +use error::BookmarkError as BE; use error::ResultExt; use result::Result; use module_path::ModuleEntryPath; @@ -40,7 +41,6 @@ use libimagentrylink::external::ExternalLinker; use libimagentrylink::external::iter::UrlIter; use libimagentrylink::internal::InternalLinker; use libimagentrylink::internal::Link as StoreLink; -use libimagerror::into::IntoError; use link::Link; @@ -91,7 +91,7 @@ impl<'a> BookmarkCollection<'a> { .chain_err(|| BEK::StoreReadError) .and_then(|fle| { match fle { - None => Err(BEK::CollectionNotFound.into_error()), + None => Err(BE::from_kind(BEK::CollectionNotFound)), Some(e) => Ok(BookmarkCollection { fle: e, store: store, diff --git a/lib/domain/libimagbookmark/src/error.rs b/lib/domain/libimagbookmark/src/error.rs index 34b5735d..0001e76a 100644 --- a/lib/domain/libimagbookmark/src/error.rs +++ b/lib/domain/libimagbookmark/src/error.rs @@ -17,10 +17,6 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -use std::error::Error; - -use libimagerror::into::IntoError; - error_chain! { types { BookmarkError, BookmarkErrorKind, ResultExt, Result; @@ -55,14 +51,3 @@ error_chain! { } } -impl IntoError for BookmarkErrorKind { - type Target = BookmarkError; - - fn into_error(self) -> Self::Target { - BookmarkError::from_kind(self) - } - - fn into_error_with_cause(self, _: Box) -> Self::Target { - BookmarkError::from_kind(self) - } -} diff --git a/lib/domain/libimagcounter/src/counter.rs b/lib/domain/libimagcounter/src/counter.rs index e23a18df..f58e5bb5 100644 --- a/lib/domain/libimagcounter/src/counter.rs +++ b/lib/domain/libimagcounter/src/counter.rs @@ -32,7 +32,6 @@ use libimagstore::storeid::StoreIdIterator; use libimagstore::store::FileLockEntry; use libimagstore::storeid::StoreId; use libimagstore::storeid::IntoStoreId; -use libimagerror::into::IntoError; use module_path::ModuleEntryPath; use result::Result; @@ -79,17 +78,17 @@ impl<'a> Counter<'a> { let header = entry.get_header_mut(); let setres = header.set(&String::from("counter"), Value::Table(BTreeMap::new())); if setres.is_err() { - return Err(CEK::StoreWriteError.into_error()); + return Err(CE::from_kind(CEK::StoreWriteError)); } let setres = header.set(&String::from("counter.name"), Value::String(name)); if setres.is_err() { - return Err(CEK::StoreWriteError.into_error()) + return Err(CE::from_kind(CEK::StoreWriteError)) } let setres = header.set(&String::from("counter.value"), Value::Integer(init)); if setres.is_err() { - return Err(CEK::StoreWriteError.into_error()) + return Err(CE::from_kind(CEK::StoreWriteError)) } } @@ -107,7 +106,7 @@ impl<'a> Counter<'a> { let setres = header.set(&String::from("counter.unit"), Value::String(u.0)); if setres.is_err() { self.unit = None; - return Err(CEK::StoreWriteError.into_error()) + return Err(CE::from_kind(CEK::StoreWriteError)) } }; Ok(self) @@ -155,16 +154,16 @@ impl<'a> Counter<'a> { pub fn name(&self) -> Result { self.read_header_at("counter.name", |v| match v { Some(&Value::String(ref s)) => Ok(s.clone()), - Some(_) => Err(CEK::HeaderTypeError.into_error()), - _ => Err(CEK::StoreReadError.into_error()), + Some(_) => Err(CE::from_kind(CEK::HeaderTypeError)), + _ => Err(CE::from_kind(CEK::StoreReadError)), }) } pub fn value(&self) -> Result { self.read_header_at("counter.value", |v| match v { Some(&Value::Integer(i)) => Ok(i), - Some(_) => Err(CEK::HeaderTypeError.into_error()), - _ => Err(CEK::StoreReadError.into_error()), + Some(_) => Err(CE::from_kind(CEK::HeaderTypeError)), + _ => Err(CE::from_kind(CEK::StoreReadError)), }) } @@ -175,8 +174,8 @@ impl<'a> Counter<'a> { pub fn read_unit(&self) -> Result> { self.read_header_at("counter.unit", |s| match s { Some(&Value::String(ref s)) => Ok(Some(CounterUnit::new(s.clone()))), - Some(_) => Err(CEK::HeaderTypeError.into_error()), - _ => Err(CEK::StoreReadError.into_error()), + Some(_) => Err(CE::from_kind(CEK::HeaderTypeError)), + _ => Err(CE::from_kind(CEK::StoreReadError)), }) } diff --git a/lib/domain/libimagcounter/src/error.rs b/lib/domain/libimagcounter/src/error.rs index bca5a0b1..c16c3f4d 100644 --- a/lib/domain/libimagcounter/src/error.rs +++ b/lib/domain/libimagcounter/src/error.rs @@ -17,10 +17,6 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -use std::error::Error; - -use libimagerror::into::IntoError; - error_chain! { types { CounterError, CounterErrorKind, ResultExt, Result; @@ -55,14 +51,3 @@ error_chain! { } } -impl IntoError for CounterErrorKind { - type Target = CounterError; - - fn into_error(self) -> Self::Target { - CounterError::from_kind(self) - } - - fn into_error_with_cause(self, _: Box) -> Self::Target { - CounterError::from_kind(self) - } -} diff --git a/lib/domain/libimagdiary/src/diaryid.rs b/lib/domain/libimagdiary/src/diaryid.rs index a08f51c0..0d47002e 100644 --- a/lib/domain/libimagdiary/src/diaryid.rs +++ b/lib/domain/libimagdiary/src/diaryid.rs @@ -33,7 +33,6 @@ use libimagstore::store::Result as StoreResult; use error::DiaryError as DE; use error::DiaryErrorKind as DEK; use error::ResultExt; -use libimagerror::into::IntoError; use module_path::ModuleEntryPath; @@ -191,7 +190,7 @@ fn component_to_str<'a>(com: Component<'a>) -> Result<&'a str, DE> { Component::Normal(s) => Some(s), _ => None, }.and_then(|s| s.to_str()) - .ok_or(DEK::IdParseError.into_error()) + .ok_or(DE::from_kind(DEK::IdParseError)) } impl FromStoreId for DiaryId { @@ -204,7 +203,7 @@ impl FromStoreId for DiaryId { fn next_component<'a>(components: &'a mut Rev) -> Result<&'a str, DE> { components.next() - .ok_or(DEK::IdParseError.into_error()) + .ok_or(DE::from_kind(DEK::IdParseError)) .and_then(component_to_str) } diff --git a/lib/domain/libimagdiary/src/error.rs b/lib/domain/libimagdiary/src/error.rs index fbea9795..5418d05c 100644 --- a/lib/domain/libimagdiary/src/error.rs +++ b/lib/domain/libimagdiary/src/error.rs @@ -17,10 +17,6 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -use std::error::Error; - -use libimagerror::into::IntoError; - error_chain! { types { DiaryError, DiaryErrorKind, ResultExt, Result; @@ -80,14 +76,3 @@ error_chain! { } } -impl IntoError for DiaryErrorKind { - type Target = DiaryError; - - fn into_error(self) -> Self::Target { - DiaryError::from_kind(self) - } - - fn into_error_with_cause(self, _: Box) -> Self::Target { - DiaryError::from_kind(self) - } -} diff --git a/lib/domain/libimagmail/src/error.rs b/lib/domain/libimagmail/src/error.rs index b3a1568c..1a986e0b 100644 --- a/lib/domain/libimagmail/src/error.rs +++ b/lib/domain/libimagmail/src/error.rs @@ -17,10 +17,6 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -use std::error::Error; - -use libimagerror::into::IntoError; - error_chain! { types { MailError, MailErrorKind, ResultExt, Result; @@ -62,14 +58,3 @@ error_chain! { } } -impl IntoError for MailErrorKind { - type Target = MailError; - - fn into_error(self) -> Self::Target { - MailError::from_kind(self) - } - - fn into_error_with_cause(self, _: Box) -> Self::Target { - MailError::from_kind(self) - } -} diff --git a/lib/domain/libimagnotes/src/error.rs b/lib/domain/libimagnotes/src/error.rs index df84ef85..6359edb2 100644 --- a/lib/domain/libimagnotes/src/error.rs +++ b/lib/domain/libimagnotes/src/error.rs @@ -17,10 +17,6 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -use std::error::Error; - -use libimagerror::into::IntoError; - error_chain! { types { NoteError, NoteErrorKind, ResultExt, Result; @@ -50,14 +46,3 @@ error_chain! { } } -impl IntoError for NoteErrorKind { - type Target = NoteError; - - fn into_error(self) -> Self::Target { - NoteError::from_kind(self) - } - - fn into_error_with_cause(self, _: Box) -> Self::Target { - NoteError::from_kind(self) - } -} diff --git a/lib/domain/libimagnotes/src/note.rs b/lib/domain/libimagnotes/src/note.rs index 9030ce9d..a235e64d 100644 --- a/lib/domain/libimagnotes/src/note.rs +++ b/lib/domain/libimagnotes/src/note.rs @@ -25,7 +25,6 @@ use toml::Value; use libimagrt::runtime::Runtime; use libimagentryedit::edit::Edit; use libimagentryedit::result::Result as EditResult; -use libimagerror::into::IntoError; use libimagstore::storeid::IntoStoreId; use libimagstore::storeid::StoreId; use libimagstore::storeid::StoreIdIterator; @@ -38,6 +37,7 @@ use toml_query::set::TomlValueSetExt; use module_path::ModuleEntryPath; use result::Result; use error::NoteErrorKind as NEK; +use error::NoteError as NE; use error::ResultExt; #[derive(Debug)] @@ -93,7 +93,7 @@ impl<'a> Note<'a> { match header.read("note.name") { Ok(Some(&Value::String(ref s))) => Ok(s.clone()), Ok(_) => { - Err(NEK::HeaderTypeError.into_error()).chain_err(|| NEK::StoreReadError) + Err(NE::from_kind(NEK::HeaderTypeError)).chain_err(|| NEK::StoreReadError) }, Err(e) => Err(e).chain_err(|| NEK::StoreReadError) } diff --git a/lib/domain/libimagtimetrack/src/error.rs b/lib/domain/libimagtimetrack/src/error.rs index 3eacdc22..bb5885ae 100644 --- a/lib/domain/libimagtimetrack/src/error.rs +++ b/lib/domain/libimagtimetrack/src/error.rs @@ -17,10 +17,6 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -use std::error::Error; - -use libimagerror::into::IntoError; - error_chain! { types { TimeTrackError, TimeTrackErrorKind, ResultExt, Result; @@ -66,14 +62,3 @@ error_chain! { } } -impl IntoError for TimeTrackErrorKind { - type Target = TimeTrackError; - - fn into_error(self) -> Self::Target { - TimeTrackError::from_kind(self) - } - - fn into_error_with_cause(self, _: Box) -> Self::Target { - TimeTrackError::from_kind(self) - } -} diff --git a/lib/domain/libimagtimetrack/src/iter/get.rs b/lib/domain/libimagtimetrack/src/iter/get.rs index a7927ff2..526c1c97 100644 --- a/lib/domain/libimagtimetrack/src/iter/get.rs +++ b/lib/domain/libimagtimetrack/src/iter/get.rs @@ -24,7 +24,6 @@ use error::ResultExt; use libimagstore::store::FileLockEntry; use libimagstore::store::Store; use libimagstore::storeid::StoreIdIterator; -use libimagerror::into::IntoError; pub struct GetTimeTrackIter<'a>{ inner: StoreIdIterator, @@ -47,7 +46,7 @@ impl<'a> Iterator for GetTimeTrackIter<'a> { fn next(&mut self) -> Option { self.inner.next().map(|sid| { match self.store.get(sid).chain_err(|| TTEK::StoreReadError) { - Ok(None) => Err(TTEK::StoreReadError.into_error()), + Ok(None) => Err(TTE::from_kind(TTEK::StoreReadError)), Ok(Some(s)) => Ok(s), Err(e) => Err(e) } diff --git a/lib/domain/libimagtimetrack/src/iter/tag.rs b/lib/domain/libimagtimetrack/src/iter/tag.rs index da006d8b..1fa21027 100644 --- a/lib/domain/libimagtimetrack/src/iter/tag.rs +++ b/lib/domain/libimagtimetrack/src/iter/tag.rs @@ -21,11 +21,11 @@ use chrono::naive::NaiveDateTime as NDT; use error::TimeTrackError; use error::TimeTrackErrorKind as TTEK; +use error::TimeTrackError as TTE; use tag::TimeTrackingTag as TTT; use iter::storeid::TagStoreIdIter; use libimagentrytag::tag::is_tag_str; -use libimagerror::into::IntoError; pub struct TagIter(Box>); @@ -48,7 +48,7 @@ impl Iterator for TagIter { .map(|t| if is_tag_str(&t).is_ok() { Ok(TTT::from(t)) } else { - Err(TTEK::TagFormat.into_error()) + Err(TTE::from_kind(TTEK::TagFormat)) }) } } diff --git a/lib/domain/libimagtimetrack/src/timetracking.rs b/lib/domain/libimagtimetrack/src/timetracking.rs index 481d93a2..3dd36c2a 100644 --- a/lib/domain/libimagtimetrack/src/timetracking.rs +++ b/lib/domain/libimagtimetrack/src/timetracking.rs @@ -27,10 +27,10 @@ use chrono::naive::NaiveDateTime; use libimagstore::store::Entry; -use libimagerror::into::IntoError; use tag::TimeTrackingTag as TTT; use error::TimeTrackErrorKind as TTEK; +use error::TimeTrackError as TTE; use error::ResultExt; use result::Result; use constants::*; @@ -68,8 +68,8 @@ impl TimeTracking for Entry { .chain_err(|| TTEK::HeaderReadError) .and_then(|value| match value { Some(&Value::String(ref s)) => Ok(s.clone().into()), - Some(_) => Err(TTEK::HeaderFieldTypeError.into_error()), - _ => Err(TTEK::HeaderReadError.into_error()) + Some(_) => Err(TTE::from_kind(TTEK::HeaderFieldTypeError)), + _ => Err(TTE::from_kind(TTEK::HeaderReadError)) }) } @@ -145,7 +145,7 @@ fn header_value_to_dt(val: Option<&Value>) -> Result> { .map(Some) }, - Some(_) => Err(TTEK::HeaderFieldTypeError.into_error()), + Some(_) => Err(TTE::from_kind(TTEK::HeaderFieldTypeError)), None => Ok(None), } } diff --git a/lib/domain/libimagtodo/src/error.rs b/lib/domain/libimagtodo/src/error.rs index dffe9bb1..90b33310 100644 --- a/lib/domain/libimagtodo/src/error.rs +++ b/lib/domain/libimagtodo/src/error.rs @@ -17,10 +17,6 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -use std::error::Error; - -use libimagerror::into::IntoError; - error_chain! { types { TodoError, TodoErrorKind, ResultExt, Result; @@ -55,14 +51,3 @@ error_chain! { } } -impl IntoError for TodoErrorKind { - type Target = TodoError; - - fn into_error(self) -> Self::Target { - TodoError::from_kind(self) - } - - fn into_error_with_cause(self, _: Box) -> Self::Target { - TodoError::from_kind(self) - } -} diff --git a/lib/entry/libimagentryannotation/src/annotateable.rs b/lib/entry/libimagentryannotation/src/annotateable.rs index 85f5f89a..b356753e 100644 --- a/lib/entry/libimagentryannotation/src/annotateable.rs +++ b/lib/entry/libimagentryannotation/src/annotateable.rs @@ -25,13 +25,13 @@ use libimagstore::store::Entry; use libimagstore::store::FileLockEntry; use libimagstore::store::Store; use libimagentrylink::internal::InternalLinker; -use libimagerror::into::IntoError; use toml_query::read::TomlValueReadExt; use toml_query::insert::TomlValueInsertExt; use result::Result; use error::AnnotationErrorKind as AEK; +use error::AnnotationError as AE; use error::ResultExt; pub trait Annotateable { @@ -72,7 +72,7 @@ impl Annotateable for Entry { .and_then(|res| match res { Some(&Value::Boolean(b)) => Ok(b), None => Ok(false), - _ => Err(AEK::HeaderTypeError.into_error()), + _ => Err(AE::from_kind(AEK::HeaderTypeError)), }) } diff --git a/lib/entry/libimagentryannotation/src/annotation_fetcher.rs b/lib/entry/libimagentryannotation/src/annotation_fetcher.rs index c49ce865..27f2f4b8 100644 --- a/lib/entry/libimagentryannotation/src/annotation_fetcher.rs +++ b/lib/entry/libimagentryannotation/src/annotation_fetcher.rs @@ -70,12 +70,12 @@ pub mod iter { use toml_query::read::TomlValueReadExt; - use libimagerror::into::IntoError; use libimagnotes::note::Note; use libimagnotes::note::NoteIterator; use result::Result; use error::AnnotationErrorKind as AEK; + use error::AnnotationError as AE; use error::ResultExt; #[derive(Debug)] @@ -99,7 +99,7 @@ pub mod iter { match note.get_header().read("annotation.is_annotation") { Ok(None) => continue, // not an annotation Ok(Some(&Value::Boolean(true))) => return Some(Ok(note)), - Ok(Some(_)) => return Some(Err(AEK::HeaderTypeError.into_error())), + Ok(Some(_)) => return Some(Err(AE::from_kind(AEK::HeaderTypeError))), Err(e) => return Some(Err(e).chain_err(|| AEK::HeaderReadError)), } }, diff --git a/lib/entry/libimagentryannotation/src/error.rs b/lib/entry/libimagentryannotation/src/error.rs index 7543b85a..8a349b71 100644 --- a/lib/entry/libimagentryannotation/src/error.rs +++ b/lib/entry/libimagentryannotation/src/error.rs @@ -17,10 +17,6 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -use std::error::Error; - -use libimagerror::into::IntoError; - error_chain! { types { AnnotationError, AnnotationErrorKind, ResultExt, Result; @@ -60,14 +56,3 @@ error_chain! { } } -impl IntoError for AnnotationErrorKind { - type Target = AnnotationError; - - fn into_error(self) -> Self::Target { - AnnotationError::from_kind(self) - } - - fn into_error_with_cause(self, _: Box) -> Self::Target { - AnnotationError::from_kind(self) - } -} diff --git a/lib/entry/libimagentrycategory/src/category.rs b/lib/entry/libimagentrycategory/src/category.rs index 9b75223e..002922c1 100644 --- a/lib/entry/libimagentrycategory/src/category.rs +++ b/lib/entry/libimagentrycategory/src/category.rs @@ -23,9 +23,9 @@ use toml_query::error::ErrorKind as TQEK; use toml::Value; use libimagstore::store::Entry; -use libimagerror::into::IntoError; use error::CategoryErrorKind as CEK; +use error::CategoryError as CE; use error::ResultExt; use result::Result; use register::CategoryRegister; @@ -76,7 +76,7 @@ impl EntryCategory for Entry { .and_then(|bl| if bl { self.set_category(s) } else { - Err(CEK::CategoryDoesNotExist.into_error()) + Err(CE::from_kind(CEK::CategoryDoesNotExist)) }) } @@ -89,8 +89,8 @@ impl EntryCategory for Entry { .chain_err(|| CEK::HeaderReadError), Ok(Some(&Value::String(ref s))) => Ok(Some(s.clone().into())), - Ok(None) => Err(CEK::StoreReadError.into_error()).chain_err(|| CEK::HeaderReadError), - Ok(_) => Err(CEK::TypeError.into_error()).chain_err(|| CEK::HeaderReadError), + Ok(None) => Err(CE::from_kind(CEK::StoreReadError)).chain_err(|| CEK::HeaderReadError), + Ok(_) => Err(CE::from_kind(CEK::TypeError)).chain_err(|| CEK::HeaderReadError), } } diff --git a/lib/entry/libimagentrycategory/src/error.rs b/lib/entry/libimagentrycategory/src/error.rs index f4fc8e60..bd3da1a0 100644 --- a/lib/entry/libimagentrycategory/src/error.rs +++ b/lib/entry/libimagentrycategory/src/error.rs @@ -17,10 +17,6 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -use std::error::Error; - -use libimagerror::into::IntoError; - error_chain! { types { CategoryError, CategoryErrorKind, ResultExt, Result; @@ -64,14 +60,3 @@ error_chain! { } } -impl IntoError for CategoryErrorKind { - type Target = CategoryError; - - fn into_error(self) -> Self::Target { - CategoryError::from_kind(self) - } - - fn into_error_with_cause(self, _: Box) -> Self::Target { - CategoryError::from_kind(self) - } -} diff --git a/lib/entry/libimagentrycategory/src/register.rs b/lib/entry/libimagentrycategory/src/register.rs index 8e2830fa..c4a475e4 100644 --- a/lib/entry/libimagentrycategory/src/register.rs +++ b/lib/entry/libimagentrycategory/src/register.rs @@ -27,10 +27,10 @@ use libimagstore::store::Store; use libimagstore::store::FileLockEntry; use libimagstore::storeid::StoreId; use libimagstore::storeid::StoreIdIterator; -use libimagerror::into::IntoError; use category::Category; use error::CategoryErrorKind as CEK; +use error::CategoryError as CE; use error::ResultExt; use result::Result; @@ -230,7 +230,7 @@ fn represents_category(store: &Store, sid: StoreId, name: &str) -> Result .chain_err(|| CEK::HeaderReadError) { Ok(Some(&Value::String(ref s))) => Ok(s == name), - Ok(_) => Err(CEK::TypeError.into_error()), + Ok(_) => Err(CE::from_kind(CEK::TypeError)), Err(e) => Err(e).chain_err(|| CEK::HeaderReadError), } } else { @@ -278,10 +278,10 @@ impl<'a> Iterator for CategoryNameIter<'a> { self.0 .get(sid) .chain_err(|| CEK::StoreReadError) - .and_then(|fle| fle.ok_or(CEK::StoreReadError.into_error())) + .and_then(|fle| fle.ok_or(CE::from_kind(CEK::StoreReadError))) .and_then(|fle| match fle.get_header().read(&query) { Ok(Some(&Value::String(ref s))) => Ok(Category::from(s.clone())), - Ok(_) => Err(CEK::TypeError.into_error()), + Ok(_) => Err(CE::from_kind(CEK::TypeError)), Err(e) => Err(e).chain_err(|| CEK::HeaderReadError), }) }) diff --git a/lib/entry/libimagentrydatetime/src/datepath/error.rs b/lib/entry/libimagentrydatetime/src/datepath/error.rs index b0b02494..94a0f723 100644 --- a/lib/entry/libimagentrydatetime/src/datepath/error.rs +++ b/lib/entry/libimagentrydatetime/src/datepath/error.rs @@ -17,10 +17,6 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -use std::error::Error; - -use libimagerror::into::IntoError; - error_chain! { types { DatePathCompilerError, DatePathCompilerErrorKind, ResultExt, Result; @@ -40,14 +36,3 @@ error_chain! { } } -impl IntoError for DatePathCompilerErrorKind { - type Target = DatePathCompilerError; - - fn into_error(self) -> Self::Target { - DatePathCompilerError::from_kind(self) - } - - fn into_error_with_cause(self, _: Box) -> Self::Target { - DatePathCompilerError::from_kind(self) - } -} diff --git a/lib/entry/libimagentrydatetime/src/datetime.rs b/lib/entry/libimagentrydatetime/src/datetime.rs index 6b137897..3a9ddf0c 100644 --- a/lib/entry/libimagentrydatetime/src/datetime.rs +++ b/lib/entry/libimagentrydatetime/src/datetime.rs @@ -24,9 +24,9 @@ use toml_query::read::TomlValueReadExt; use toml::Value; use libimagstore::store::Entry; -use libimagerror::into::IntoError; use error::DateErrorKind as DEK; +use error::DateError as DE; use error::*; use result::Result; use range::DateTimeRange; @@ -67,8 +67,8 @@ impl EntryDate for Entry { match v { Some(&Value::String(ref s)) => s.parse::() .chain_err(|| DEK::DateTimeParsingError), - Some(_) => Err(DEK::DateHeaderFieldTypeError.into_error()), - _ => Err(DEK::ReadDateError.into_error()), + Some(_) => Err(DE::from_kind(DEK::DateHeaderFieldTypeError)), + _ => Err(DE::from_kind(DEK::ReadDateError)), } }) } @@ -98,7 +98,7 @@ impl EntryDate for Entry { match stri { Value::String(ref s) => s.parse::() .chain_err(|| DEK::DateTimeParsingError), - _ => Err(DEK::DateHeaderFieldTypeError.into_error()), + _ => Err(DE::from_kind(DEK::DateHeaderFieldTypeError)), } })) .chain_err(|| DEK::SetDateError) @@ -134,8 +134,8 @@ impl EntryDate for Entry { match v { Some(&Value::String(ref s)) => s.parse::() .chain_err(|| DEK::DateTimeParsingError), - Some(_) => Err(DEK::DateHeaderFieldTypeError.into_error()), - _ => Err(DEK::ReadDateError.into_error()), + Some(_) => Err(DE::from_kind(DEK::DateHeaderFieldTypeError)), + _ => Err(DE::from_kind(DEK::ReadDateError)), } })); @@ -147,8 +147,8 @@ impl EntryDate for Entry { match v { Some(&Value::String(ref s)) => s.parse::() .chain_err(|| DEK::DateTimeParsingError), - Some(_) => Err(DEK::DateHeaderFieldTypeError.into_error()), - _ => Err(DEK::ReadDateError.into_error()), + Some(_) => Err(DE::from_kind(DEK::DateHeaderFieldTypeError)), + _ => Err(DE::from_kind(DEK::ReadDateError)), } })); @@ -176,7 +176,7 @@ impl EntryDate for Entry { match stri { Value::String(ref s) => s.parse::() .chain_err(|| DEK::DateTimeParsingError), - _ => Err(DEK::DateHeaderFieldTypeError.into_error()), + _ => Err(DE::from_kind(DEK::DateHeaderFieldTypeError)), } })) .chain_err(|| DEK::SetDateTimeRangeError)); @@ -188,7 +188,7 @@ impl EntryDate for Entry { match stri { Value::String(ref s) => s.parse::() .chain_err(|| DEK::DateTimeParsingError), - _ => Err(DEK::DateHeaderFieldTypeError.into_error()), + _ => Err(DE::from_kind(DEK::DateHeaderFieldTypeError)), } })) .chain_err(|| DEK::SetDateTimeRangeError)); diff --git a/lib/entry/libimagentrydatetime/src/error.rs b/lib/entry/libimagentrydatetime/src/error.rs index dbf9c322..763c133b 100644 --- a/lib/entry/libimagentrydatetime/src/error.rs +++ b/lib/entry/libimagentrydatetime/src/error.rs @@ -17,10 +17,6 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -use std::error::Error; - -use libimagerror::into::IntoError; - error_chain! { types { DateError, DateErrorKind, ResultExt, Result; @@ -79,14 +75,3 @@ error_chain! { } } -impl IntoError for DateErrorKind { - type Target = DateError; - - fn into_error(self) -> Self::Target { - DateError::from_kind(self) - } - - fn into_error_with_cause(self, _: Box) -> Self::Target { - DateError::from_kind(self) - } -} diff --git a/lib/entry/libimagentrydatetime/src/range.rs b/lib/entry/libimagentrydatetime/src/range.rs index 59cd0ccf..526c0044 100644 --- a/lib/entry/libimagentrydatetime/src/range.rs +++ b/lib/entry/libimagentrydatetime/src/range.rs @@ -20,10 +20,9 @@ use chrono::naive::NaiveDateTime; use error::DateErrorKind as DEK; +use error::DateError as DE; use error::Result; -use libimagerror::into::IntoError; - /// A Range between two dates #[derive(Debug, Clone, PartialEq, Eq, PartialOrd, Ord, Hash)] pub struct DateTimeRange(NaiveDateTime, NaiveDateTime); @@ -41,7 +40,7 @@ impl DateTimeRange { if start < end { Ok(DateTimeRange(start, end)) } else { - Err(DEK::EndDateTimeBeforeStartDateTime.into_error()) + Err(DE::from_kind(DEK::EndDateTimeBeforeStartDateTime)) } } diff --git a/lib/entry/libimagentryedit/src/edit.rs b/lib/entry/libimagentryedit/src/edit.rs index 0e5900a2..fab34d3d 100644 --- a/lib/entry/libimagentryedit/src/edit.rs +++ b/lib/entry/libimagentryedit/src/edit.rs @@ -17,12 +17,12 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -use libimagerror::into::IntoError; use libimagrt::runtime::Runtime; use libimagstore::store::Entry; use result::Result; use error::EditErrorKind; +use error::EditError as EE; use error::ResultExt; pub trait Edit { @@ -50,7 +50,7 @@ pub fn edit_in_tmpfile(rt: &Runtime, s: &mut String) -> Result<()> { use libimagutil::edit::edit_in_tmpfile_with_command; rt.editor() - .ok_or(EditErrorKind::NoEditor.into_error()) + .ok_or(EE::from_kind(EditErrorKind::NoEditor)) .and_then(|editor| { edit_in_tmpfile_with_command(editor, s) .chain_err(|| EditErrorKind::IOError) diff --git a/lib/entry/libimagentryedit/src/error.rs b/lib/entry/libimagentryedit/src/error.rs index 2bc81b19..5d5425f3 100644 --- a/lib/entry/libimagentryedit/src/error.rs +++ b/lib/entry/libimagentryedit/src/error.rs @@ -17,10 +17,6 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -use std::error::Error; - -use libimagerror::into::IntoError; - error_chain! { types { EditError, EditErrorKind, ResultExt, Result; @@ -50,15 +46,3 @@ error_chain! { } } -impl IntoError for EditErrorKind { - type Target = EditError; - - fn into_error(self) -> Self::Target { - EditError::from_kind(self) - } - - fn into_error_with_cause(self, _: Box) -> Self::Target { - EditError::from_kind(self) - } -} - diff --git a/lib/entry/libimagentrylink/src/error.rs b/lib/entry/libimagentrylink/src/error.rs index 515ead11..6f27f92a 100644 --- a/lib/entry/libimagentrylink/src/error.rs +++ b/lib/entry/libimagentrylink/src/error.rs @@ -17,9 +17,6 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -use std::error::Error; - -use libimagerror::into::IntoError; use libimagstore::storeid::StoreId; error_chain! { @@ -105,14 +102,3 @@ error_chain! { } } -impl IntoError for LinkErrorKind { - type Target = LinkError; - - fn into_error(self) -> Self::Target { - LinkError::from_kind(self) - } - - fn into_error_with_cause(self, _: Box) -> Self::Target { - LinkError::from_kind(self) - } -} diff --git a/lib/entry/libimagentrylink/src/external.rs b/lib/entry/libimagentrylink/src/external.rs index 642f3cdc..2b3d0923 100644 --- a/lib/entry/libimagentrylink/src/external.rs +++ b/lib/entry/libimagentrylink/src/external.rs @@ -34,7 +34,6 @@ use std::ops::DerefMut; use std::collections::BTreeMap; use std::fmt::Debug; -use libimagerror::into::IntoError; use libimagstore::store::Entry; use libimagstore::store::FileLockEntry; use libimagstore::store::Store; @@ -46,6 +45,7 @@ use toml_query::read::TomlValueReadExt; use toml_query::set::TomlValueSetExt; use error::LinkErrorKind as LEK; +use error::LinkError as LE; use result::Result; use internal::InternalLinker; use module_path::ModuleEntryPath; @@ -95,7 +95,7 @@ impl<'a> Link<'a> { .chain_err(|| LEK::EntryHeaderReadError) }, Ok(None) => Ok(None), - _ => Err(LEK::EntryHeaderReadError.into_error()) + _ => Err(LE::from_kind(LEK::EntryHeaderReadError)) } } @@ -293,7 +293,7 @@ pub fn is_external_link_storeid + Debug>(id: A) -> bool { fn get_external_link_from_file(entry: &FileLockEntry) -> Result { Link::get_link_uri_from_filelockentry(entry) // TODO: Do not hide error by using this function - .ok_or(LEK::StoreReadError.into_error()) + .ok_or(LE::from_kind(LEK::StoreReadError)) } /// Implement `ExternalLinker` for `Entry`, hiding the fact that there is no such thing as an external diff --git a/lib/entry/libimagentrylink/src/internal.rs b/lib/entry/libimagentrylink/src/internal.rs index 77c1c088..ed550eee 100644 --- a/lib/entry/libimagentrylink/src/internal.rs +++ b/lib/entry/libimagentrylink/src/internal.rs @@ -25,12 +25,12 @@ use libimagstore::storeid::StoreId; use libimagstore::storeid::IntoStoreId; use libimagstore::store::Entry; use libimagstore::store::Result as StoreResult; -use libimagerror::into::IntoError; use toml_query::read::TomlValueReadExt; use toml_query::set::TomlValueSetExt; use error::LinkErrorKind as LEK; +use error::LinkError as LE; use error::ResultExt; use result::Result; use self::iter::LinkIter; @@ -538,7 +538,7 @@ fn process_rw_result(links: Result>) -> Result { let links = match links { Err(e) => { debug!("RW action on store failed. Generating LinkError"); - return Err(LEK::EntryHeaderReadError.into_error_with_cause(Box::new(e))) + return Err(e).chain_err(|| LEK::EntryHeaderReadError) }, Ok(None) => { debug!("We got no value from the header!"); @@ -570,13 +570,13 @@ fn process_rw_result(links: Result>) -> Result { if !tab.contains_key("link") || !tab.contains_key("annotation") { debug!("Things missing... returning Error instance"); - Err(LEK::LinkParserError.into_error()) + Err(LE::from_kind(LEK::LinkParserError)) } else { let link = try!(tab.remove("link") - .ok_or(LEK::LinkParserFieldMissingError.into_error())); + .ok_or(LE::from_kind(LEK::LinkParserFieldMissingError))); let anno = try!(tab.remove("annotation") - .ok_or(LEK::LinkParserFieldMissingError.into_error())); + .ok_or(LE::from_kind(LEK::LinkParserFieldMissingError))); debug!("Ok, here we go with building a Link::Annotated"); match (link, anno) { @@ -590,7 +590,7 @@ fn process_rw_result(links: Result>) -> Result { } }) }, - _ => Err(LEK::LinkParserFieldTypeError.into_error()), + _ => Err(LE::from_kind(LEK::LinkParserFieldTypeError)), } } } @@ -624,7 +624,6 @@ pub mod store_check { use libimagstore::store::StoreObject; use libimagstore::storeid::StoreId; use libimagerror::iter::TraceIterator; - use libimagerror::into::IntoError; use libimagutil::iter::FoldResult; // Helper data structure to collect incoming and outgoing links for each StoreId @@ -705,13 +704,13 @@ pub mod store_check { if !try!(id.exists().chain_err(|| LEK::StoreReadError)) { warn!("Does exist in store but not on FS: {:?}", id); - Err(LEK::LinkTargetDoesNotExist.into_error()) + Err(LE::from_kind(LEK::LinkTargetDoesNotExist)) } else { Ok(()) } } else { warn!("Does not exist in store: {:?}", id); - Err(LEK::LinkTargetDoesNotExist.into_error()) + Err(LE::from_kind(LEK::LinkTargetDoesNotExist)) } }) }; @@ -719,7 +718,7 @@ pub mod store_check { /// Helper function to create a SLCECD::OneDirectionalLink error object #[inline] let mk_one_directional_link_err = |src: StoreId, target: StoreId| -> LE { - LEK::DeadLink(src, target).into_error() + LE::from_kind(LEK::DeadLink(src, target)) }; /// Helper lambda to check whether the _incoming_ links of each entry actually also diff --git a/lib/entry/libimagentrylist/src/cli.rs b/lib/entry/libimagentrylist/src/cli.rs index 4b94d3bb..89dc29e1 100644 --- a/lib/entry/libimagentrylist/src/cli.rs +++ b/lib/entry/libimagentrylist/src/cli.rs @@ -20,13 +20,13 @@ use clap::{Arg, ArgMatches, App, SubCommand}; use libimagstore::store::FileLockEntry; -use libimagerror::into::IntoError; use result::Result; use listers::line::LineLister; use listers::path::PathLister; use lister::Lister; use error::ListErrorKind; +use error::ListError as LE; pub fn build_list_cli_component<'a, 'b>() -> App<'a, 'b> { SubCommand::with_name(list_subcommand_name()) @@ -97,6 +97,6 @@ pub fn list_entries_with_lister<'a, I>(m: &ArgMatches, entries: I) -> Result<()> Ok(()) } else { - Err(ListErrorKind::CLIError.into_error()) + Err(LE::from_kind(ListErrorKind::CLIError)) } } diff --git a/lib/entry/libimagentrylist/src/error.rs b/lib/entry/libimagentrylist/src/error.rs index f45ad46d..877d1d71 100644 --- a/lib/entry/libimagentrylist/src/error.rs +++ b/lib/entry/libimagentrylist/src/error.rs @@ -17,10 +17,6 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -use std::error::Error; - -use libimagerror::into::IntoError; - error_chain! { types { ListError, ListErrorKind, ResultExt, Result; @@ -55,14 +51,3 @@ error_chain! { } } -impl IntoError for ListErrorKind { - type Target = ListError; - - fn into_error(self) -> Self::Target { - ListError::from_kind(self) - } - - fn into_error_with_cause(self, _: Box) -> Self::Target { - ListError::from_kind(self) - } -} diff --git a/lib/entry/libimagentrylist/src/listers/table.rs b/lib/entry/libimagentrylist/src/listers/table.rs index 040b27ad..08dea4f2 100644 --- a/lib/entry/libimagentrylist/src/listers/table.rs +++ b/lib/entry/libimagentrylist/src/listers/table.rs @@ -24,7 +24,6 @@ use result::Result; use error::ResultExt; use libimagstore::store::FileLockEntry; -use libimagerror::into::IntoError; use prettytable::Table; use prettytable::cell::Cell; @@ -63,6 +62,7 @@ impl Vec> Lister for TableLister { fn list<'b, I: Iterator>>(&self, entries: I) -> Result<()> { use error::ListErrorKind as LEK; + use error::ListError as LE; let mut table = Table::new(); let mut header_len : Option = None; @@ -90,7 +90,7 @@ impl Vec> Lister for TableLister { header_len = Some(v_len); } if header_len.map(|l| v_len > l).unwrap_or(false) { - return Err(LEK::FormatError.into_error()); + return Err(LE::from_kind(LEK::FormatError)); } while header_len.map(|l| v.len() != l).unwrap_or(false) { v.push(String::from("")); diff --git a/lib/entry/libimagentrymarkdown/src/error.rs b/lib/entry/libimagentrymarkdown/src/error.rs index 60e9348e..4df464ec 100644 --- a/lib/entry/libimagentrymarkdown/src/error.rs +++ b/lib/entry/libimagentrymarkdown/src/error.rs @@ -17,10 +17,6 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -use std::error::Error; - -use libimagerror::into::IntoError; - error_chain! { types { MarkdownError, MarkdownErrorKind, ResultExt, Result; @@ -40,15 +36,3 @@ error_chain! { } } - -impl IntoError for MarkdownErrorKind { - type Target = MarkdownError; - - fn into_error(self) -> Self::Target { - MarkdownError::from_kind(self) - } - - fn into_error_with_cause(self, _: Box) -> Self::Target { - MarkdownError::from_kind(self) - } -} diff --git a/lib/entry/libimagentrymarkdown/src/html.rs b/lib/entry/libimagentrymarkdown/src/html.rs index 1fcd12c7..c1c0bd7c 100644 --- a/lib/entry/libimagentrymarkdown/src/html.rs +++ b/lib/entry/libimagentrymarkdown/src/html.rs @@ -23,7 +23,7 @@ use hoedown::renderer::Render; use result::Result; use error::MarkdownErrorKind; -use libimagerror::into::IntoError; +use error::ResultExt; pub type HTML = String; @@ -33,8 +33,7 @@ pub fn to_html(buffer: &str) -> Result { html.render(&md) .to_str() .map(String::from) - .map_err(Box::new) - .map_err(|e| MarkdownErrorKind::MarkdownRenderError.into_error_with_cause(e)) + .chain_err(|| MarkdownErrorKind::MarkdownRenderError) } pub mod iter { diff --git a/lib/entry/libimagentrymarkdown/src/link.rs b/lib/entry/libimagentrymarkdown/src/link.rs index 9f13fe65..7d90cb5d 100644 --- a/lib/entry/libimagentrymarkdown/src/link.rs +++ b/lib/entry/libimagentrymarkdown/src/link.rs @@ -18,6 +18,7 @@ // use error::MarkdownErrorKind as MEK; +use error::ResultExt; use result::Result; use hoedown::renderer::Render; @@ -25,8 +26,6 @@ use hoedown::Buffer; use hoedown::Markdown; use url::Url; -use libimagerror::into::IntoError; - #[derive(Debug, Clone, PartialEq, Eq)] pub struct Link { pub title: String, @@ -39,8 +38,7 @@ impl Link { pub fn into_urllink(self) -> Result { Url::parse(&self.link[..]) .map(move |link| UrlLink { title: self.title, link: link, }) - .map_err(Box::new) - .map_err(|e| MEK::LinkParsingError.into_error_with_cause(e)) + .chain_err(|| MEK::LinkParsingError) } } diff --git a/lib/entry/libimagentryref/src/error.rs b/lib/entry/libimagentryref/src/error.rs index c4152a14..b826c7ca 100644 --- a/lib/entry/libimagentryref/src/error.rs +++ b/lib/entry/libimagentryref/src/error.rs @@ -17,10 +17,6 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -use std::error::Error; - -use libimagerror::into::IntoError; - error_chain! { types { RefError, RefErrorKind, ResultExt, Result; @@ -153,14 +149,3 @@ error_chain! { } } -impl IntoError for RefErrorKind { - type Target = RefError; - - fn into_error(self) -> Self::Target { - RefError::from_kind(self) - } - - fn into_error_with_cause(self, _: Box) -> Self::Target { - RefError::from_kind(self) - } -} diff --git a/lib/entry/libimagentryref/src/reference.rs b/lib/entry/libimagentryref/src/reference.rs index 0ef1c934..a62d0f5c 100644 --- a/lib/entry/libimagentryref/src/reference.rs +++ b/lib/entry/libimagentryref/src/reference.rs @@ -33,7 +33,6 @@ use libimagstore::store::FileLockEntry; use libimagstore::storeid::StoreId; use libimagstore::storeid::IntoStoreId; use libimagstore::store::Store; -use libimagerror::into::IntoError; use toml::Value; use toml_query::read::TomlValueReadExt; @@ -41,6 +40,7 @@ use toml_query::set::TomlValueSetExt; use toml_query::insert::TomlValueInsertExt; use error::RefErrorKind as REK; +use error::RefError as RE; use error::ResultExt; use flags::RefFlags; use result::Result; @@ -60,8 +60,8 @@ impl<'a> Ref<'a> { /// Try to get `si` as Ref object from the store pub fn get(store: &'a Store, si: StoreId) -> Result> { match store.get(si) { - Err(e) => return Err(REK::StoreReadError.into_error_with_cause(Box::new(e))), - Ok(None) => return Err(REK::RefNotInStore.into_error()), + Err(e) => return Err(e).chain_err(|| REK::StoreReadError), + Ok(None) => return Err(RE::from_kind(REK::RefNotInStore)), Ok(Some(fle)) => Ref::from_filelockentry(fle), } } @@ -90,9 +90,9 @@ impl<'a> Ref<'a> { fn read_reference(fle: &FileLockEntry<'a>) -> Result { match fle.get_header().read("ref.path") { Ok(Some(&Value::String(ref s))) => Ok(PathBuf::from(s)), - Ok(Some(_)) => Err(REK::HeaderTypeError.into_error()), - Ok(None) => Err(REK::HeaderFieldMissingError.into_error()), - Err(e) => Err(REK::StoreReadError.into_error_with_cause(Box::new(e))), + Ok(Some(_)) => Err(RE::from_kind(REK::HeaderTypeError)), + Ok(None) => Err(RE::from_kind(REK::HeaderFieldMissingError)), + Err(e) => Err(e).chain_err(|| REK::StoreReadError), } } @@ -100,10 +100,10 @@ impl<'a> Ref<'a> { -> Result> { if !pb.exists() { - return Err(REK::RefTargetDoesNotExist.into_error()); + return Err(RE::from_kind(REK::RefTargetDoesNotExist)); } if flags.get_content_hashing() && pb.is_dir() { - return Err(REK::RefTargetCannotBeHashed.into_error()); + return Err(RE::from_kind(REK::RefTargetCannotBeHashed)); } let (mut fle, content_hash, permissions, canonical_path) = { // scope to be able to fold @@ -165,7 +165,7 @@ impl<'a> Ref<'a> { .and_then(|(opt_conhash, opt_perm, can, path_hash)| { match can.to_str().map(String::from) { // UTF convert error in PathBuf::to_str(), - None => Err(REK::PathUTF8Error.into_error()), + None => Err(RE::from_kind(REK::PathUTF8Error)), Some(can) => Ok((opt_conhash, opt_perm, can, path_hash)) } }) @@ -207,9 +207,7 @@ impl<'a> Ref<'a> { debug!("Overwrote: {}, which was: {:?}", s, val); }, Err(e) => { - let e = Box::new(e); - let e = REK::HeaderFieldWriteError.into_error_with_cause(e); - return Err(e); + return Err(e).chain_err(|| REK::HeaderFieldWriteError); }, } } @@ -239,7 +237,7 @@ impl<'a> Ref<'a> { hasher.input_str(s); Ok(hasher.result_str()) }, - None => return Err(REK::PathUTF8Error.into_error()), + None => return Err(RE::from_kind(REK::PathUTF8Error)), } } @@ -255,7 +253,7 @@ impl<'a> Ref<'a> { .and_then(|osstr| osstr.to_str()) .and_then(|s| s.split("~").next()) .map(String::from) - .ok_or(REK::StoreIdError.into_error()) + .ok_or(RE::from_kind(REK::StoreIdError)) }) } @@ -272,13 +270,13 @@ impl<'a> Ref<'a> { Ok(Some(&Value::String(ref s))) => Ok(s.clone()), // content hash header field has wrong type - Ok(Some(_)) => Err(REK::HeaderTypeError.into_error()), + Ok(Some(_)) => Err(RE::from_kind(REK::HeaderTypeError)), // content hash not stored - Ok(None) => Err(REK::HeaderFieldMissingError.into_error()), + Ok(None) => Err(RE::from_kind(REK::HeaderFieldMissingError)), // Error - Err(e) => Err(REK::StoreReadError.into_error_with_cause(Box::new(e))), + Err(e) => Err(e).chain_err(|| REK::StoreReadError), } } @@ -357,8 +355,8 @@ impl<'a> Ref<'a> { .and_then(|ro| { match ro { Some(&Value::Boolean(b)) => Ok(b), - Some(_) => Err(REK::HeaderTypeError.into_error()), - None => Err(REK::HeaderFieldMissingError.into_error()), + Some(_) => Err(RE::from_kind(REK::HeaderTypeError)), + None => Err(RE::from_kind(REK::HeaderFieldMissingError)), } }) .and_then(|ro| self.get_current_permissions().map(|perm| ro == perm.readonly())) @@ -403,9 +401,9 @@ impl<'a> Ref<'a> { pub fn fs_file(&self) -> Result { match self.0.get_header().read("ref.path") { Ok(Some(&Value::String(ref s))) => Ok(PathBuf::from(s)), - Ok(Some(_)) => Err(REK::HeaderTypeError.into_error()), - Ok(None) => Err(REK::HeaderFieldMissingError.into_error()), - Err(e) => Err(REK::StoreReadError.into_error_with_cause(Box::new(e))), + Ok(Some(_)) => Err(RE::from_kind(REK::HeaderTypeError)), + Ok(None) => Err(RE::from_kind(REK::HeaderFieldMissingError)), + Err(e) => Err(e).chain_err(|| REK::StoreReadError), } } @@ -443,11 +441,11 @@ impl<'a> Ref<'a> { }, Ok(None) => { // Something weird just happened - return Err(REK::StoreReadError.into_error()); + return Err(RE::from_kind(REK::StoreReadError)); }, Err(e) => { - return Err(REK::StoreReadError.into_error_with_cause(Box::new(e))); + return Err(e).chain_err(|| REK::StoreReadError); }, } } @@ -512,7 +510,7 @@ impl<'a> Ref<'a> { }) .flatten() .next() - .ok_or(REK::RefTargetDoesNotExist.into_error()) + .ok_or(RE::from_kind(REK::RefTargetDoesNotExist)) }) } diff --git a/lib/entry/libimagentrytag/src/error.rs b/lib/entry/libimagentrytag/src/error.rs index fe02b26e..453901dd 100644 --- a/lib/entry/libimagentrytag/src/error.rs +++ b/lib/entry/libimagentrytag/src/error.rs @@ -17,10 +17,6 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -use std::error::Error; - -use libimagerror::into::IntoError; - error_chain! { types { TagError, TagErrorKind, ResultExt, Result; @@ -50,14 +46,3 @@ error_chain! { } } -impl IntoError for TagErrorKind { - type Target = TagError; - - fn into_error(self) -> Self::Target { - TagError::from_kind(self) - } - - fn into_error_with_cause(self, _: Box) -> Self::Target { - TagError::from_kind(self) - } -} diff --git a/lib/entry/libimagentrytag/src/tagable.rs b/lib/entry/libimagentrytag/src/tagable.rs index 7019905f..5a2aeeae 100644 --- a/lib/entry/libimagentrytag/src/tagable.rs +++ b/lib/entry/libimagentrytag/src/tagable.rs @@ -20,12 +20,12 @@ use itertools::Itertools; use libimagstore::store::Entry; -use libimagerror::into::IntoError; use toml_query::read::TomlValueReadExt; use toml_query::set::TomlValueSetExt; use error::TagErrorKind; +use error::TagError as TE; use error::ResultExt; use result::Result; use tag::{Tag, TagSlice}; @@ -91,7 +91,7 @@ impl Tagable for Value { } fn add_tag(&mut self, t: Tag) -> Result<()> { - if !try!(is_tag_str(&t).map(|_| true).map_err(|_| TagErrorKind::NotATag.into_error())) { + if !try!(is_tag_str(&t).map(|_| true).map_err(|_| TE::from_kind(TagErrorKind::NotATag))) { debug!("Not a tag: '{}'", t); return Err(TagErrorKind::NotATag.into()); } @@ -105,7 +105,7 @@ impl Tagable for Value { } fn remove_tag(&mut self, t: Tag) -> Result<()> { - if !try!(is_tag_str(&t).map(|_| true).map_err(|_| TagErrorKind::NotATag.into_error())) { + if !try!(is_tag_str(&t).map(|_| true).map_err(|_| TE::from_kind(TagErrorKind::NotATag))) { debug!("Not a tag: '{}'", t); return Err(TagErrorKind::NotATag.into()); } diff --git a/lib/entry/libimagentryview/src/error.rs b/lib/entry/libimagentryview/src/error.rs index f3d9a040..c742d046 100644 --- a/lib/entry/libimagentryview/src/error.rs +++ b/lib/entry/libimagentryview/src/error.rs @@ -17,10 +17,6 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -use std::error::Error; - -use libimagerror::into::IntoError; - error_chain! { types { ViewError, ViewErrorKind, ResultExt, Result; @@ -55,14 +51,3 @@ error_chain! { } } -impl IntoError for ViewErrorKind { - type Target = ViewError; - - fn into_error(self) -> Self::Target { - ViewError::from_kind(self) - } - - fn into_error_with_cause(self, _: Box) -> Self::Target { - ViewError::from_kind(self) - } -} diff --git a/lib/etc/libimaginteraction/src/error.rs b/lib/etc/libimaginteraction/src/error.rs index e5daf160..28345c94 100644 --- a/lib/etc/libimaginteraction/src/error.rs +++ b/lib/etc/libimaginteraction/src/error.rs @@ -17,10 +17,6 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // -use std::error::Error; - -use libimagerror::into::IntoError; - error_chain! { types { InteractionError, InteractionErrorKind, ResultExt, Result; @@ -85,14 +81,3 @@ error_chain! { } } -impl IntoError for InteractionErrorKind { - type Target = InteractionError; - - fn into_error(self) -> Self::Target { - InteractionError::from_kind(self) - } - - fn into_error_with_cause(self, _: Box) -> Self::Target { - InteractionError::from_kind(self) - } -} diff --git a/lib/etc/libimaginteraction/src/readline.rs b/lib/etc/libimaginteraction/src/readline.rs index 7b998dd0..58275444 100644 --- a/lib/etc/libimaginteraction/src/readline.rs +++ b/lib/etc/libimaginteraction/src/readline.rs @@ -17,6 +17,7 @@ // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA // +use error::InteractionError as IE; use error::InteractionErrorKind as IEK; use error::MapErrInto; @@ -44,35 +45,35 @@ impl Readline { let histfile = try!(match histfile { Value::String(s) => PathBuf::from(s), - _ => Err(IEK::ConfigTypeError.into_error()) + _ => Err(IE::from_kind(IEK::ConfigTypeError)) .map_err_into(IEK::ConfigError) .map_err_into(IEK::ReadlineError) }); let histsize = try!(match histsize { Value::Integer(i) => i, - _ => Err(IEK::ConfigTypeError.into_error()) + _ => Err(IE::from_kind(IEK::ConfigTypeError)) .map_err_into(IEK::ConfigError) .map_err_into(IEK::ReadlineError) }); let histigndups = try!(match histigndups { Value::Boolean(b) => b, - _ => Err(IEK::ConfigTypeError.into_error()) + _ => Err(IE::from_kind(IEK::ConfigTypeError)) .map_err_into(IEK::ConfigError) .map_err_into(IEK::ReadlineError) }); let histignspace = try!(match histignspace { Value::Boolean(b) => b, - _ => Err(IEK::ConfigTypeError.into_error()) + _ => Err(IE::from_kind(IEK::ConfigTypeError)) .map_err_into(IEK::ConfigError) .map_err_into(IEK::ReadlineError) }); let prompt = try!(match prompt { Value::String(s) => s, - _ => Err(IEK::ConfigTypeError.into_error()) + _ => Err(IE::from_kind(IEK::ConfigTypeError)) .map_err_into(IEK::ConfigError) .map_err_into(IEK::ReadlineError) }); diff --git a/lib/etc/libimaginteraction/src/ui.rs b/lib/etc/libimaginteraction/src/ui.rs index 0a5335b9..f75c304a 100644 --- a/lib/etc/libimaginteraction/src/ui.rs +++ b/lib/etc/libimaginteraction/src/ui.rs @@ -22,9 +22,9 @@ use std::path::PathBuf; use clap::{Arg, ArgMatches}; use libimagstore::storeid::StoreId; -use libimagerror::into::IntoError; use result::Result; +use error::InteractionError as IE; use error::InteractionErrorKind as IEK; use error::ResultExt; @@ -52,7 +52,7 @@ pub fn id_argument_long() -> &'static str { pub fn get_id(matches: &ArgMatches) -> Result> { matches .values_of(id_argument_name()) - .ok_or(IEK::IdMissingError.into_error()) + .ok_or(IE::from_kind(IEK::IdMissingError)) .chain_err(|| IEK::CLIError) .and_then(|vals| { vals.into_iter() From 18e806f588a2917ba21d289e93216edd3d6c801e Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 3 Sep 2017 21:39:32 +0200 Subject: [PATCH 31/32] Remove dedicated result modules, use error chain generated Result types --- bin/domain/imag-diary/src/create.rs | 2 +- lib/domain/libimagbookmark/src/collection.rs | 4 +-- lib/domain/libimagbookmark/src/lib.rs | 1 - lib/domain/libimagbookmark/src/link.rs | 2 +- lib/domain/libimagbookmark/src/result.rs | 25 ------------------ lib/domain/libimagcounter/src/counter.rs | 2 +- lib/domain/libimagcounter/src/lib.rs | 1 - lib/domain/libimagcounter/src/result.rs | 25 ------------------ lib/domain/libimagdiary/src/diary.rs | 2 +- lib/domain/libimagdiary/src/entry.rs | 2 +- lib/domain/libimagdiary/src/iter.rs | 2 +- lib/domain/libimagdiary/src/lib.rs | 1 - lib/domain/libimagdiary/src/result.rs | 24 ----------------- lib/domain/libimagdiary/src/viewer.rs | 2 +- lib/domain/libimagmail/src/hasher.rs | 2 +- lib/domain/libimagmail/src/iter.rs | 2 +- lib/domain/libimagmail/src/lib.rs | 1 - lib/domain/libimagmail/src/mail.rs | 2 +- lib/domain/libimagmail/src/result.rs | 25 ------------------ lib/domain/libimagnotes/src/lib.rs | 1 - lib/domain/libimagnotes/src/note.rs | 4 +-- lib/domain/libimagnotes/src/result.rs | 25 ------------------ lib/domain/libimagtimetrack/src/lib.rs | 1 - lib/domain/libimagtimetrack/src/result.rs | 26 ------------------- .../libimagtimetrack/src/timetracking.rs | 2 +- .../libimagtimetrack/src/timetrackingstore.rs | 2 +- lib/domain/libimagtodo/src/lib.rs | 1 - lib/domain/libimagtodo/src/result.rs | 24 ----------------- lib/domain/libimagtodo/src/task.rs | 2 +- .../src/annotateable.rs | 2 +- .../src/annotation_fetcher.rs | 4 +-- lib/entry/libimagentryannotation/src/lib.rs | 1 - .../libimagentryannotation/src/result.rs | 26 ------------------- .../libimagentrycategory/src/category.rs | 2 +- lib/entry/libimagentrycategory/src/lib.rs | 1 - .../libimagentrycategory/src/register.rs | 2 +- lib/entry/libimagentrycategory/src/result.rs | 26 ------------------- .../src/datepath/compiler.rs | 2 +- .../libimagentrydatetime/src/datepath/mod.rs | 1 - .../src/datepath/result.rs | 25 ------------------ .../src/datepath/to_store_id.rs | 2 +- .../libimagentrydatetime/src/datetime.rs | 1 - lib/entry/libimagentrydatetime/src/lib.rs | 1 - lib/entry/libimagentrydatetime/src/result.rs | 25 ------------------ lib/entry/libimagentryedit/src/edit.rs | 2 +- lib/entry/libimagentryedit/src/lib.rs | 1 - lib/entry/libimagentryedit/src/result.rs | 25 ------------------ lib/entry/libimagentrylink/src/external.rs | 4 +-- lib/entry/libimagentrylink/src/internal.rs | 6 ++--- lib/entry/libimagentrylink/src/lib.rs | 1 - lib/entry/libimagentrylink/src/result.rs | 25 ------------------ lib/entry/libimagentrylist/src/cli.rs | 2 +- lib/entry/libimagentrylist/src/lib.rs | 1 - lib/entry/libimagentrylist/src/lister.rs | 2 +- .../libimagentrylist/src/listers/core.rs | 2 +- .../libimagentrylist/src/listers/line.rs | 2 +- .../libimagentrylist/src/listers/path.rs | 2 +- .../libimagentrylist/src/listers/table.rs | 2 +- lib/entry/libimagentrylist/src/result.rs | 25 ------------------ lib/entry/libimagentrymarkdown/src/html.rs | 4 +-- lib/entry/libimagentrymarkdown/src/lib.rs | 1 - lib/entry/libimagentrymarkdown/src/link.rs | 2 +- lib/entry/libimagentrymarkdown/src/result.rs | 25 ------------------ lib/entry/libimagentryref/src/flags.rs | 2 +- lib/entry/libimagentryref/src/hasher.rs | 2 +- .../libimagentryref/src/hashers/nbytes.rs | 2 +- lib/entry/libimagentryref/src/lib.rs | 1 - lib/entry/libimagentryref/src/lister.rs | 2 +- lib/entry/libimagentryref/src/reference.rs | 2 +- lib/entry/libimagentryref/src/result.rs | 25 ------------------ lib/entry/libimagentrytag/src/exec.rs | 2 +- lib/entry/libimagentrytag/src/lib.rs | 1 - lib/entry/libimagentrytag/src/result.rs | 25 ------------------ lib/entry/libimagentrytag/src/tagable.rs | 2 +- .../libimagentryview/src/builtin/editor.rs | 2 +- .../libimagentryview/src/builtin/plain.rs | 2 +- .../libimagentryview/src/builtin/stdout.rs | 2 +- lib/entry/libimagentryview/src/lib.rs | 1 - lib/entry/libimagentryview/src/result.rs | 24 ----------------- lib/entry/libimagentryview/src/viewer.rs | 2 +- lib/etc/libimaginteraction/src/ask.rs | 2 +- lib/etc/libimaginteraction/src/lib.rs | 1 - lib/etc/libimaginteraction/src/result.rs | 24 ----------------- lib/etc/libimaginteraction/src/ui.rs | 2 +- 84 files changed, 52 insertions(+), 546 deletions(-) delete mode 100644 lib/domain/libimagbookmark/src/result.rs delete mode 100644 lib/domain/libimagcounter/src/result.rs delete mode 100644 lib/domain/libimagdiary/src/result.rs delete mode 100644 lib/domain/libimagmail/src/result.rs delete mode 100644 lib/domain/libimagnotes/src/result.rs delete mode 100644 lib/domain/libimagtimetrack/src/result.rs delete mode 100644 lib/domain/libimagtodo/src/result.rs delete mode 100644 lib/entry/libimagentryannotation/src/result.rs delete mode 100644 lib/entry/libimagentrycategory/src/result.rs delete mode 100644 lib/entry/libimagentrydatetime/src/datepath/result.rs delete mode 100644 lib/entry/libimagentrydatetime/src/result.rs delete mode 100644 lib/entry/libimagentryedit/src/result.rs delete mode 100644 lib/entry/libimagentrylink/src/result.rs delete mode 100644 lib/entry/libimagentrylist/src/result.rs delete mode 100644 lib/entry/libimagentrymarkdown/src/result.rs delete mode 100644 lib/entry/libimagentryref/src/result.rs delete mode 100644 lib/entry/libimagentrytag/src/result.rs delete mode 100644 lib/entry/libimagentryview/src/result.rs delete mode 100644 lib/etc/libimaginteraction/src/result.rs diff --git a/bin/domain/imag-diary/src/create.rs b/bin/domain/imag-diary/src/create.rs index e49cae25..3d66599b 100644 --- a/bin/domain/imag-diary/src/create.rs +++ b/bin/domain/imag-diary/src/create.rs @@ -27,7 +27,7 @@ use libimagentryedit::edit::Edit; use libimagrt::runtime::Runtime; use libimagerror::trace::trace_error; use libimagdiary::entry::Entry; -use libimagdiary::result::Result; +use libimagdiary::error::Result; use libimagutil::warn_exit::warn_exit; use util::get_diary_name; diff --git a/lib/domain/libimagbookmark/src/collection.rs b/lib/domain/libimagbookmark/src/collection.rs index 525500ff..858460d0 100644 --- a/lib/domain/libimagbookmark/src/collection.rs +++ b/lib/domain/libimagbookmark/src/collection.rs @@ -31,7 +31,7 @@ use regex::Regex; use error::BookmarkErrorKind as BEK; use error::BookmarkError as BE; use error::ResultExt; -use result::Result; +use error::Result; use module_path::ModuleEntryPath; use libimagstore::store::Store; @@ -150,7 +150,7 @@ impl<'a> BookmarkCollection<'a> { pub mod iter { use link::Link; - use result::Result; + use error::Result; use error::{ResultExt, BookmarkErrorKind as BEK}; pub struct LinkIter(I) diff --git a/lib/domain/libimagbookmark/src/lib.rs b/lib/domain/libimagbookmark/src/lib.rs index 00d94f61..6567cbf1 100644 --- a/lib/domain/libimagbookmark/src/lib.rs +++ b/lib/domain/libimagbookmark/src/lib.rs @@ -48,4 +48,3 @@ module_entry_path_mod!("bookmark"); pub mod collection; pub mod error; pub mod link; -pub mod result; diff --git a/lib/domain/libimagbookmark/src/link.rs b/lib/domain/libimagbookmark/src/link.rs index acc68e60..038fea7f 100644 --- a/lib/domain/libimagbookmark/src/link.rs +++ b/lib/domain/libimagbookmark/src/link.rs @@ -19,7 +19,7 @@ use std::ops::{Deref, DerefMut}; -use result::Result; +use error::Result; use url::Url; diff --git a/lib/domain/libimagbookmark/src/result.rs b/lib/domain/libimagbookmark/src/result.rs deleted file mode 100644 index 780a8035..00000000 --- a/lib/domain/libimagbookmark/src/result.rs +++ /dev/null @@ -1,25 +0,0 @@ -// -// imag - the personal information management suite for the commandline -// Copyright (C) 2015, 2016 Matthias Beyer and contributors -// -// This library is free software; you can redistribute it and/or -// modify it under the terms of the GNU Lesser General Public -// License as published by the Free Software Foundation; version -// 2.1 of the License. -// -// This library is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Lesser General Public License for more details. -// -// You should have received a copy of the GNU Lesser General Public -// License along with this library; if not, write to the Free Software -// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA -// - -use std::result::Result as RResult; - -use error::BookmarkError; - -pub type Result = RResult; - diff --git a/lib/domain/libimagcounter/src/counter.rs b/lib/domain/libimagcounter/src/counter.rs index f58e5bb5..855ee5a1 100644 --- a/lib/domain/libimagcounter/src/counter.rs +++ b/lib/domain/libimagcounter/src/counter.rs @@ -34,7 +34,7 @@ use libimagstore::storeid::StoreId; use libimagstore::storeid::IntoStoreId; use module_path::ModuleEntryPath; -use result::Result; +use error::Result; use error::CounterError as CE; use error::CounterErrorKind as CEK; use error::ResultExt; diff --git a/lib/domain/libimagcounter/src/lib.rs b/lib/domain/libimagcounter/src/lib.rs index 6aa28b71..41db759d 100644 --- a/lib/domain/libimagcounter/src/lib.rs +++ b/lib/domain/libimagcounter/src/lib.rs @@ -47,5 +47,4 @@ module_entry_path_mod!("counter"); pub mod counter; pub mod error; -pub mod result; diff --git a/lib/domain/libimagcounter/src/result.rs b/lib/domain/libimagcounter/src/result.rs deleted file mode 100644 index e24b90c9..00000000 --- a/lib/domain/libimagcounter/src/result.rs +++ /dev/null @@ -1,25 +0,0 @@ -// -// imag - the personal information management suite for the commandline -// Copyright (C) 2015, 2016 Matthias Beyer and contributors -// -// This library is free software; you can redistribute it and/or -// modify it under the terms of the GNU Lesser General Public -// License as published by the Free Software Foundation; version -// 2.1 of the License. -// -// This library is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Lesser General Public License for more details. -// -// You should have received a copy of the GNU Lesser General Public -// License along with this library; if not, write to the Free Software -// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA -// - -use std::result::Result as RResult; - -use error::CounterError; - -pub type Result = RResult; - diff --git a/lib/domain/libimagdiary/src/diary.rs b/lib/domain/libimagdiary/src/diary.rs index 6617f392..8bc94865 100644 --- a/lib/domain/libimagdiary/src/diary.rs +++ b/lib/domain/libimagdiary/src/diary.rs @@ -33,7 +33,7 @@ use diaryid::DiaryId; use error::DiaryError as DE; use error::DiaryErrorKind as DEK; use error::ResultExt; -use result::Result; +use error::Result; use iter::DiaryEntryIterator; use is_in_diary::IsInDiary; diff --git a/lib/domain/libimagdiary/src/entry.rs b/lib/domain/libimagdiary/src/entry.rs index 0148b59d..4e654f5e 100644 --- a/lib/domain/libimagdiary/src/entry.rs +++ b/lib/domain/libimagdiary/src/entry.rs @@ -22,7 +22,7 @@ use std::ops::DerefMut; use libimagstore::store::FileLockEntry; use libimagentryedit::edit::Edit; -use libimagentryedit::result::Result as EditResult; +use libimagentryedit::error::Result as EditResult; use libimagrt::runtime::Runtime; use diaryid::DiaryId; diff --git a/lib/domain/libimagdiary/src/iter.rs b/lib/domain/libimagdiary/src/iter.rs index 285dc34e..63bd0779 100644 --- a/lib/domain/libimagdiary/src/iter.rs +++ b/lib/domain/libimagdiary/src/iter.rs @@ -29,7 +29,7 @@ use is_in_diary::IsInDiary; use entry::Entry as DiaryEntry; use error::DiaryErrorKind as DEK; use error::ResultExt; -use result::Result; +use error::Result; use libimagerror::trace::trace_error; /// A iterator for iterating over diary entries diff --git a/lib/domain/libimagdiary/src/lib.rs b/lib/domain/libimagdiary/src/lib.rs index 90c14679..b9c9697b 100644 --- a/lib/domain/libimagdiary/src/lib.rs +++ b/lib/domain/libimagdiary/src/lib.rs @@ -57,6 +57,5 @@ pub mod diary; pub mod is_in_diary; pub mod entry; pub mod iter; -pub mod result; pub mod viewer; diff --git a/lib/domain/libimagdiary/src/result.rs b/lib/domain/libimagdiary/src/result.rs deleted file mode 100644 index b4f5f382..00000000 --- a/lib/domain/libimagdiary/src/result.rs +++ /dev/null @@ -1,24 +0,0 @@ -// -// imag - the personal information management suite for the commandline -// Copyright (C) 2015, 2016 Matthias Beyer and contributors -// -// This library is free software; you can redistribute it and/or -// modify it under the terms of the GNU Lesser General Public -// License as published by the Free Software Foundation; version -// 2.1 of the License. -// -// This library is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Lesser General Public License for more details. -// -// You should have received a copy of the GNU Lesser General Public -// License along with this library; if not, write to the Free Software -// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA -// - -use std::result::Result as RResult; - -use error::DiaryError; - -pub type Result = RResult; diff --git a/lib/domain/libimagdiary/src/viewer.rs b/lib/domain/libimagdiary/src/viewer.rs index 9efd293f..e87bc202 100644 --- a/lib/domain/libimagdiary/src/viewer.rs +++ b/lib/domain/libimagdiary/src/viewer.rs @@ -22,7 +22,7 @@ use entry::Entry; use error::DiaryErrorKind as DEK; use error::ResultExt; -use result::Result; +use error::Result; use libimagentryview::viewer::Viewer; use libimagentryview::builtin::plain::PlainViewer; diff --git a/lib/domain/libimagmail/src/hasher.rs b/lib/domain/libimagmail/src/hasher.rs index d650bedd..07817602 100644 --- a/lib/domain/libimagmail/src/hasher.rs +++ b/lib/domain/libimagmail/src/hasher.rs @@ -26,7 +26,7 @@ use libimagentryref::hasher::Hasher; use libimagentryref::hasher::DefaultHasher; use libimagentryref::error::RefErrorKind as REK; use libimagentryref::error::ResultExt; -use libimagentryref::result::Result as RResult; +use libimagentryref::error::Result as RResult; pub struct MailHasher { defaulthasher: DefaultHasher, diff --git a/lib/domain/libimagmail/src/iter.rs b/lib/domain/libimagmail/src/iter.rs index fe1e72a4..92cf2981 100644 --- a/lib/domain/libimagmail/src/iter.rs +++ b/lib/domain/libimagmail/src/iter.rs @@ -25,7 +25,7 @@ //! use mail::Mail; -use result::Result; +use error::Result; use libimagentryref::reference::Ref; diff --git a/lib/domain/libimagmail/src/lib.rs b/lib/domain/libimagmail/src/lib.rs index 09e74a5f..9a6b9413 100644 --- a/lib/domain/libimagmail/src/lib.rs +++ b/lib/domain/libimagmail/src/lib.rs @@ -48,5 +48,4 @@ pub mod error; pub mod hasher; pub mod iter; pub mod mail; -pub mod result; diff --git a/lib/domain/libimagmail/src/mail.rs b/lib/domain/libimagmail/src/mail.rs index 17129c90..426409cc 100644 --- a/lib/domain/libimagmail/src/mail.rs +++ b/lib/domain/libimagmail/src/mail.rs @@ -30,7 +30,7 @@ use email::MimeMessage; use email::results::ParsingResult as EmailParsingResult; use hasher::MailHasher; -use result::Result; +use error::Result; use error::{ResultExt, MailErrorKind as MEK}; struct Buffer(String); diff --git a/lib/domain/libimagmail/src/result.rs b/lib/domain/libimagmail/src/result.rs deleted file mode 100644 index 7f745eda..00000000 --- a/lib/domain/libimagmail/src/result.rs +++ /dev/null @@ -1,25 +0,0 @@ -// -// imag - the personal information management suite for the commandline -// Copyright (C) 2015, 2016 Matthias Beyer and contributors -// -// This library is free software; you can redistribute it and/or -// modify it under the terms of the GNU Lesser General Public -// License as published by the Free Software Foundation; version -// 2.1 of the License. -// -// This library is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Lesser General Public License for more details. -// -// You should have received a copy of the GNU Lesser General Public -// License along with this library; if not, write to the Free Software -// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA -// - -use std::result::Result as RResult; - -use error::MailError; - -pub type Result = RResult; - diff --git a/lib/domain/libimagnotes/src/lib.rs b/lib/domain/libimagnotes/src/lib.rs index 54315538..6d2fbba4 100644 --- a/lib/domain/libimagnotes/src/lib.rs +++ b/lib/domain/libimagnotes/src/lib.rs @@ -49,5 +49,4 @@ module_entry_path_mod!("notes"); pub mod error; pub mod note; -pub mod result; diff --git a/lib/domain/libimagnotes/src/note.rs b/lib/domain/libimagnotes/src/note.rs index a235e64d..599a0db6 100644 --- a/lib/domain/libimagnotes/src/note.rs +++ b/lib/domain/libimagnotes/src/note.rs @@ -24,7 +24,7 @@ use toml::Value; use libimagrt::runtime::Runtime; use libimagentryedit::edit::Edit; -use libimagentryedit::result::Result as EditResult; +use libimagentryedit::error::Result as EditResult; use libimagstore::storeid::IntoStoreId; use libimagstore::storeid::StoreId; use libimagstore::storeid::StoreIdIterator; @@ -35,7 +35,7 @@ use toml_query::read::TomlValueReadExt; use toml_query::set::TomlValueSetExt; use module_path::ModuleEntryPath; -use result::Result; +use error::Result; use error::NoteErrorKind as NEK; use error::NoteError as NE; use error::ResultExt; diff --git a/lib/domain/libimagnotes/src/result.rs b/lib/domain/libimagnotes/src/result.rs deleted file mode 100644 index a11ba895..00000000 --- a/lib/domain/libimagnotes/src/result.rs +++ /dev/null @@ -1,25 +0,0 @@ -// -// imag - the personal information management suite for the commandline -// Copyright (C) 2015, 2016 Matthias Beyer and contributors -// -// This library is free software; you can redistribute it and/or -// modify it under the terms of the GNU Lesser General Public -// License as published by the Free Software Foundation; version -// 2.1 of the License. -// -// This library is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Lesser General Public License for more details. -// -// You should have received a copy of the GNU Lesser General Public -// License along with this library; if not, write to the Free Software -// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA -// - -use std::result::Result as RResult; - -use error::NoteError; - -pub type Result = RResult; - diff --git a/lib/domain/libimagtimetrack/src/lib.rs b/lib/domain/libimagtimetrack/src/lib.rs index 0a14a664..cabe0ef2 100644 --- a/lib/domain/libimagtimetrack/src/lib.rs +++ b/lib/domain/libimagtimetrack/src/lib.rs @@ -56,7 +56,6 @@ pub mod error; pub mod timetracking; pub mod timetrackingstore; pub mod iter; -pub mod result; pub mod tag; module_entry_path_mod!("timetrack"); diff --git a/lib/domain/libimagtimetrack/src/result.rs b/lib/domain/libimagtimetrack/src/result.rs deleted file mode 100644 index 8ea8173f..00000000 --- a/lib/domain/libimagtimetrack/src/result.rs +++ /dev/null @@ -1,26 +0,0 @@ -// -// imag - the personal information management suite for the commandline -// Copyright (C) 2015, 2016 Matthias Beyer and contributors -// -// This library is free software; you can redistribute it and/or -// modify it under the terms of the GNU Lesser General Public -// License as published by the Free Software Foundation; version -// 2.1 of the License. -// -// This library is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Lesser General Public License for more details. -// -// You should have received a copy of the GNU Lesser General Public -// License along with this library; if not, write to the Free Software -// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA -// - -use std::result::Result as RResult; - -use error::TimeTrackError; - -pub type Result = RResult; - - diff --git a/lib/domain/libimagtimetrack/src/timetracking.rs b/lib/domain/libimagtimetrack/src/timetracking.rs index 3dd36c2a..7c3bf11d 100644 --- a/lib/domain/libimagtimetrack/src/timetracking.rs +++ b/lib/domain/libimagtimetrack/src/timetracking.rs @@ -32,7 +32,7 @@ use tag::TimeTrackingTag as TTT; use error::TimeTrackErrorKind as TTEK; use error::TimeTrackError as TTE; use error::ResultExt; -use result::Result; +use error::Result; use constants::*; use toml::Value; diff --git a/lib/domain/libimagtimetrack/src/timetrackingstore.rs b/lib/domain/libimagtimetrack/src/timetrackingstore.rs index ccd03fd5..669862b5 100644 --- a/lib/domain/libimagtimetrack/src/timetrackingstore.rs +++ b/lib/domain/libimagtimetrack/src/timetrackingstore.rs @@ -30,7 +30,7 @@ use libimagstore::store::Store; use libimagstore::store::FileLockEntry; use libimagentrydatetime::datepath::compiler::DatePathCompiler; -use result::Result; +use error::Result; use constants::*; use error::TimeTrackErrorKind as TTEK; use error::ResultExt; diff --git a/lib/domain/libimagtodo/src/lib.rs b/lib/domain/libimagtodo/src/lib.rs index 78e4bab4..b4313c27 100644 --- a/lib/domain/libimagtodo/src/lib.rs +++ b/lib/domain/libimagtodo/src/lib.rs @@ -49,6 +49,5 @@ extern crate task_hookrs; module_entry_path_mod!("todo"); pub mod error; -pub mod result; pub mod task; diff --git a/lib/domain/libimagtodo/src/result.rs b/lib/domain/libimagtodo/src/result.rs deleted file mode 100644 index 7962851c..00000000 --- a/lib/domain/libimagtodo/src/result.rs +++ /dev/null @@ -1,24 +0,0 @@ -// -// imag - the personal information management suite for the commandline -// Copyright (C) 2015, 2016 Matthias Beyer and contributors -// -// This library is free software; you can redistribute it and/or -// modify it under the terms of the GNU Lesser General Public -// License as published by the Free Software Foundation; version -// 2.1 of the License. -// -// This library is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Lesser General Public License for more details. -// -// You should have received a copy of the GNU Lesser General Public -// License along with this library; if not, write to the Free Software -// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA -// - -use error::TodoError; - -use std::result::Result as RResult; - -pub type Result = RResult; diff --git a/lib/domain/libimagtodo/src/task.rs b/lib/domain/libimagtodo/src/task.rs index 3dc5c780..ec7b79e5 100644 --- a/lib/domain/libimagtodo/src/task.rs +++ b/lib/domain/libimagtodo/src/task.rs @@ -34,7 +34,7 @@ use module_path::ModuleEntryPath; use error::{TodoErrorKind as TEK, ResultExt}; use error::TodoError as TE; -use result::Result; +use error::Result; /// Task struct containing a `FileLockEntry` #[derive(Debug)] diff --git a/lib/entry/libimagentryannotation/src/annotateable.rs b/lib/entry/libimagentryannotation/src/annotateable.rs index b356753e..d51380cc 100644 --- a/lib/entry/libimagentryannotation/src/annotateable.rs +++ b/lib/entry/libimagentryannotation/src/annotateable.rs @@ -29,7 +29,7 @@ use libimagentrylink::internal::InternalLinker; use toml_query::read::TomlValueReadExt; use toml_query::insert::TomlValueInsertExt; -use result::Result; +use error::Result; use error::AnnotationErrorKind as AEK; use error::AnnotationError as AE; use error::ResultExt; diff --git a/lib/entry/libimagentryannotation/src/annotation_fetcher.rs b/lib/entry/libimagentryannotation/src/annotation_fetcher.rs index 27f2f4b8..49890550 100644 --- a/lib/entry/libimagentryannotation/src/annotation_fetcher.rs +++ b/lib/entry/libimagentryannotation/src/annotation_fetcher.rs @@ -24,7 +24,7 @@ use libimagnotes::note::Note; use libimagnotes::note::NoteIterator; use libimagstore::storeid::StoreIdIterator; -use result::Result; +use error::Result; use error::AnnotationErrorKind as AEK; use error::ResultExt; @@ -73,7 +73,7 @@ pub mod iter { use libimagnotes::note::Note; use libimagnotes::note::NoteIterator; - use result::Result; + use error::Result; use error::AnnotationErrorKind as AEK; use error::AnnotationError as AE; use error::ResultExt; diff --git a/lib/entry/libimagentryannotation/src/lib.rs b/lib/entry/libimagentryannotation/src/lib.rs index 204e67b3..bd1e9ed5 100644 --- a/lib/entry/libimagentryannotation/src/lib.rs +++ b/lib/entry/libimagentryannotation/src/lib.rs @@ -47,5 +47,4 @@ extern crate libimagnotes; pub mod annotateable; pub mod annotation_fetcher; pub mod error; -pub mod result; diff --git a/lib/entry/libimagentryannotation/src/result.rs b/lib/entry/libimagentryannotation/src/result.rs deleted file mode 100644 index 292fc0e5..00000000 --- a/lib/entry/libimagentryannotation/src/result.rs +++ /dev/null @@ -1,26 +0,0 @@ -// -// imag - the personal information management suite for the commandline -// Copyright (C) 2015, 2016 Matthias Beyer and contributors -// -// This library is free software; you can redistribute it and/or -// modify it under the terms of the GNU Lesser General Public -// License as published by the Free Software Foundation; version -// 2.1 of the License. -// -// This library is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Lesser General Public License for more details. -// -// You should have received a copy of the GNU Lesser General Public -// License along with this library; if not, write to the Free Software -// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA -// - -use std::result::Result as RResult; - -use error::AnnotationError; - -pub type Result = RResult; - - diff --git a/lib/entry/libimagentrycategory/src/category.rs b/lib/entry/libimagentrycategory/src/category.rs index 002922c1..f2a2b2cf 100644 --- a/lib/entry/libimagentrycategory/src/category.rs +++ b/lib/entry/libimagentrycategory/src/category.rs @@ -27,7 +27,7 @@ use libimagstore::store::Entry; use error::CategoryErrorKind as CEK; use error::CategoryError as CE; use error::ResultExt; -use result::Result; +use error::Result; use register::CategoryRegister; #[derive(Clone, Debug, Eq, PartialEq, Ord, PartialOrd)] diff --git a/lib/entry/libimagentrycategory/src/lib.rs b/lib/entry/libimagentrycategory/src/lib.rs index 1ea7d05b..06e13f9c 100644 --- a/lib/entry/libimagentrycategory/src/lib.rs +++ b/lib/entry/libimagentrycategory/src/lib.rs @@ -50,7 +50,6 @@ extern crate libimagstore; pub mod category; pub mod error; pub mod register; -pub mod result; module_entry_path_mod!("category"); diff --git a/lib/entry/libimagentrycategory/src/register.rs b/lib/entry/libimagentrycategory/src/register.rs index c4a475e4..ad4d5b73 100644 --- a/lib/entry/libimagentrycategory/src/register.rs +++ b/lib/entry/libimagentrycategory/src/register.rs @@ -32,7 +32,7 @@ use category::Category; use error::CategoryErrorKind as CEK; use error::CategoryError as CE; use error::ResultExt; -use result::Result; +use error::Result; pub const CATEGORY_REGISTER_NAME_FIELD_PATH : &'static str = "category.register.name"; diff --git a/lib/entry/libimagentrycategory/src/result.rs b/lib/entry/libimagentrycategory/src/result.rs deleted file mode 100644 index 517d0e96..00000000 --- a/lib/entry/libimagentrycategory/src/result.rs +++ /dev/null @@ -1,26 +0,0 @@ - -// -// imag - the personal information management suite for the commandline -// Copyright (C) 2015, 2016 Matthias Beyer and contributors -// -// This library is free software; you can redistribute it and/or -// modify it under the terms of the GNU Lesser General Public -// License as published by the Free Software Foundation; version -// 2.1 of the License. -// -// This library is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Lesser General Public License for more details. -// -// You should have received a copy of the GNU Lesser General Public -// License along with this library; if not, write to the Free Software -// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA -// - -use std::result::Result as RResult; - -use error::CategoryError; - -pub type Result = RResult; - diff --git a/lib/entry/libimagentrydatetime/src/datepath/compiler.rs b/lib/entry/libimagentrydatetime/src/datepath/compiler.rs index 12537e8e..7910db7f 100644 --- a/lib/entry/libimagentrydatetime/src/datepath/compiler.rs +++ b/lib/entry/libimagentrydatetime/src/datepath/compiler.rs @@ -27,7 +27,7 @@ use libimagstore::storeid::StoreId; use datepath::accuracy::Accuracy; use datepath::format::Format; -use datepath::result::Result; +use datepath::error::Result; use datepath::error::DatePathCompilerErrorKind as DPCEK; use datepath::error::ResultExt; diff --git a/lib/entry/libimagentrydatetime/src/datepath/mod.rs b/lib/entry/libimagentrydatetime/src/datepath/mod.rs index c964abf9..2fbfc1c4 100644 --- a/lib/entry/libimagentrydatetime/src/datepath/mod.rs +++ b/lib/entry/libimagentrydatetime/src/datepath/mod.rs @@ -21,6 +21,5 @@ pub mod accuracy; pub mod compiler; pub mod error; pub mod format; -pub mod result; pub mod to_store_id; diff --git a/lib/entry/libimagentrydatetime/src/datepath/result.rs b/lib/entry/libimagentrydatetime/src/datepath/result.rs deleted file mode 100644 index 2fc3350a..00000000 --- a/lib/entry/libimagentrydatetime/src/datepath/result.rs +++ /dev/null @@ -1,25 +0,0 @@ -// -// imag - the personal information management suite for the commandline -// Copyright (C) 2015, 2016 Matthias Beyer and contributors -// -// This library is free software; you can redistribute it and/or -// modify it under the terms of the GNU Lesser General Public -// License as published by the Free Software Foundation; version -// 2.1 of the License. -// -// This library is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Lesser General Public License for more details. -// -// You should have received a copy of the GNU Lesser General Public -// License along with this library; if not, write to the Free Software -// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA -// - -/// Result type for this module. -use super::error::DatePathCompilerError as DPCE; -use std::result::Result as RResult; - -pub type Result = RResult; - diff --git a/lib/entry/libimagentrydatetime/src/datepath/to_store_id.rs b/lib/entry/libimagentrydatetime/src/datepath/to_store_id.rs index c781595b..6f24d517 100644 --- a/lib/entry/libimagentrydatetime/src/datepath/to_store_id.rs +++ b/lib/entry/libimagentrydatetime/src/datepath/to_store_id.rs @@ -20,7 +20,7 @@ use chrono::naive::NaiveDateTime; use libimagstore::storeid::StoreId; -use datepath::result::Result; +use datepath::error::Result; use datepath::compiler::DatePathCompiler; // diff --git a/lib/entry/libimagentrydatetime/src/datetime.rs b/lib/entry/libimagentrydatetime/src/datetime.rs index 3a9ddf0c..06d11b07 100644 --- a/lib/entry/libimagentrydatetime/src/datetime.rs +++ b/lib/entry/libimagentrydatetime/src/datetime.rs @@ -28,7 +28,6 @@ use libimagstore::store::Entry; use error::DateErrorKind as DEK; use error::DateError as DE; use error::*; -use result::Result; use range::DateTimeRange; pub trait EntryDate { diff --git a/lib/entry/libimagentrydatetime/src/lib.rs b/lib/entry/libimagentrydatetime/src/lib.rs index 3a231814..fdb8067b 100644 --- a/lib/entry/libimagentrydatetime/src/lib.rs +++ b/lib/entry/libimagentrydatetime/src/lib.rs @@ -48,5 +48,4 @@ pub mod datepath; pub mod datetime; pub mod error; pub mod range; -pub mod result; diff --git a/lib/entry/libimagentrydatetime/src/result.rs b/lib/entry/libimagentrydatetime/src/result.rs deleted file mode 100644 index d6d0a5af..00000000 --- a/lib/entry/libimagentrydatetime/src/result.rs +++ /dev/null @@ -1,25 +0,0 @@ -// -// imag - the personal information management suite for the commandline -// Copyright (C) 2015, 2016 Matthias Beyer and contributors -// -// This library is free software; you can redistribute it and/or -// modify it under the terms of the GNU Lesser General Public -// License as published by the Free Software Foundation; version -// 2.1 of the License. -// -// This library is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Lesser General Public License for more details. -// -// You should have received a copy of the GNU Lesser General Public -// License along with this library; if not, write to the Free Software -// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA -// - -use std::result::Result as RResult; - -use error::DateError; - -pub type Result = RResult; - diff --git a/lib/entry/libimagentryedit/src/edit.rs b/lib/entry/libimagentryedit/src/edit.rs index fab34d3d..bd2ee190 100644 --- a/lib/entry/libimagentryedit/src/edit.rs +++ b/lib/entry/libimagentryedit/src/edit.rs @@ -20,7 +20,7 @@ use libimagrt::runtime::Runtime; use libimagstore::store::Entry; -use result::Result; +use error::Result; use error::EditErrorKind; use error::EditError as EE; use error::ResultExt; diff --git a/lib/entry/libimagentryedit/src/lib.rs b/lib/entry/libimagentryedit/src/lib.rs index 6776476f..cc385919 100644 --- a/lib/entry/libimagentryedit/src/lib.rs +++ b/lib/entry/libimagentryedit/src/lib.rs @@ -43,4 +43,3 @@ extern crate libimagutil; pub mod edit; pub mod error; -pub mod result; diff --git a/lib/entry/libimagentryedit/src/result.rs b/lib/entry/libimagentryedit/src/result.rs deleted file mode 100644 index 1d917c05..00000000 --- a/lib/entry/libimagentryedit/src/result.rs +++ /dev/null @@ -1,25 +0,0 @@ -// -// imag - the personal information management suite for the commandline -// Copyright (C) 2015, 2016 Matthias Beyer and contributors -// -// This library is free software; you can redistribute it and/or -// modify it under the terms of the GNU Lesser General Public -// License as published by the Free Software Foundation; version -// 2.1 of the License. -// -// This library is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Lesser General Public License for more details. -// -// You should have received a copy of the GNU Lesser General Public -// License along with this library; if not, write to the Free Software -// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA -// - -use std::result::Result as RResult; - -use error::EditError; - -pub type Result = RResult; - diff --git a/lib/entry/libimagentrylink/src/external.rs b/lib/entry/libimagentrylink/src/external.rs index 2b3d0923..b13ecbc5 100644 --- a/lib/entry/libimagentrylink/src/external.rs +++ b/lib/entry/libimagentrylink/src/external.rs @@ -46,7 +46,7 @@ use toml_query::set::TomlValueSetExt; use error::LinkErrorKind as LEK; use error::LinkError as LE; -use result::Result; +use error::Result; use internal::InternalLinker; use module_path::ModuleEntryPath; use error::ResultExt; @@ -137,7 +137,7 @@ pub mod iter { use internal::iter::LinkIter; use error::LinkErrorKind as LEK; use error::ResultExt; - use result::Result; + use error::Result; use url::Url; diff --git a/lib/entry/libimagentrylink/src/internal.rs b/lib/entry/libimagentrylink/src/internal.rs index ed550eee..b5b0fd37 100644 --- a/lib/entry/libimagentrylink/src/internal.rs +++ b/lib/entry/libimagentrylink/src/internal.rs @@ -32,7 +32,7 @@ use toml_query::set::TomlValueSetExt; use error::LinkErrorKind as LEK; use error::LinkError as LE; use error::ResultExt; -use result::Result; +use error::Result; use self::iter::LinkIter; use self::iter::IntoValues; @@ -188,7 +188,7 @@ pub mod iter { use error::LinkErrorKind as LEK; use error::ResultExt; - use result::Result; + use error::Result; use toml::Value; use itertools::Itertools; @@ -618,7 +618,7 @@ pub mod store_check { use error::LinkErrorKind as LEK; use error::LinkError as LE; - use result::Result as LResult; + use error::Result as LResult; use internal::InternalLinker; use libimagstore::store::StoreObject; diff --git a/lib/entry/libimagentrylink/src/lib.rs b/lib/entry/libimagentrylink/src/lib.rs index 780cf351..5c24ee34 100644 --- a/lib/entry/libimagentrylink/src/lib.rs +++ b/lib/entry/libimagentrylink/src/lib.rs @@ -56,5 +56,4 @@ module_entry_path_mod!("links"); pub mod error; pub mod external; pub mod internal; -pub mod result; diff --git a/lib/entry/libimagentrylink/src/result.rs b/lib/entry/libimagentrylink/src/result.rs deleted file mode 100644 index 23e50363..00000000 --- a/lib/entry/libimagentrylink/src/result.rs +++ /dev/null @@ -1,25 +0,0 @@ -// -// imag - the personal information management suite for the commandline -// Copyright (C) 2015, 2016 Matthias Beyer and contributors -// -// This library is free software; you can redistribute it and/or -// modify it under the terms of the GNU Lesser General Public -// License as published by the Free Software Foundation; version -// 2.1 of the License. -// -// This library is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Lesser General Public License for more details. -// -// You should have received a copy of the GNU Lesser General Public -// License along with this library; if not, write to the Free Software -// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA -// - -use std::result::Result as RResult; - -use error::LinkError; - -pub type Result = RResult; - diff --git a/lib/entry/libimagentrylist/src/cli.rs b/lib/entry/libimagentrylist/src/cli.rs index 89dc29e1..e54deba0 100644 --- a/lib/entry/libimagentrylist/src/cli.rs +++ b/lib/entry/libimagentrylist/src/cli.rs @@ -21,7 +21,7 @@ use clap::{Arg, ArgMatches, App, SubCommand}; use libimagstore::store::FileLockEntry; -use result::Result; +use error::Result; use listers::line::LineLister; use listers::path::PathLister; use lister::Lister; diff --git a/lib/entry/libimagentrylist/src/lib.rs b/lib/entry/libimagentrylist/src/lib.rs index 7d779d73..0f4748a4 100644 --- a/lib/entry/libimagentrylist/src/lib.rs +++ b/lib/entry/libimagentrylist/src/lib.rs @@ -48,5 +48,4 @@ pub mod cli; pub mod error; pub mod lister; pub mod listers; -pub mod result; diff --git a/lib/entry/libimagentrylist/src/lister.rs b/lib/entry/libimagentrylist/src/lister.rs index 798061b8..3bb64786 100644 --- a/lib/entry/libimagentrylist/src/lister.rs +++ b/lib/entry/libimagentrylist/src/lister.rs @@ -19,7 +19,7 @@ use libimagstore::store::FileLockEntry; -use result::Result; +use error::Result; pub trait Lister : Sized { diff --git a/lib/entry/libimagentrylist/src/listers/core.rs b/lib/entry/libimagentrylist/src/listers/core.rs index 74a99f47..d653c7bb 100644 --- a/lib/entry/libimagentrylist/src/listers/core.rs +++ b/lib/entry/libimagentrylist/src/listers/core.rs @@ -21,7 +21,7 @@ use std::io::stdout; use std::io::Write; use lister::Lister; -use result::Result; +use error::Result; use error::ResultExt; use libimagstore::store::FileLockEntry; diff --git a/lib/entry/libimagentrylist/src/listers/line.rs b/lib/entry/libimagentrylist/src/listers/line.rs index d61b8da3..69cef86e 100644 --- a/lib/entry/libimagentrylist/src/listers/line.rs +++ b/lib/entry/libimagentrylist/src/listers/line.rs @@ -21,7 +21,7 @@ use std::io::stdout; use std::io::Write; use lister::Lister; -use result::Result; +use error::Result; use error::ResultExt; use libimagstore::store::FileLockEntry; diff --git a/lib/entry/libimagentrylist/src/listers/path.rs b/lib/entry/libimagentrylist/src/listers/path.rs index 55a9afb0..d359226c 100644 --- a/lib/entry/libimagentrylist/src/listers/path.rs +++ b/lib/entry/libimagentrylist/src/listers/path.rs @@ -21,7 +21,7 @@ use std::io::stdout; use std::io::Write; use lister::Lister; -use result::Result; +use error::Result; use error::ResultExt; use libimagstore::store::FileLockEntry; diff --git a/lib/entry/libimagentrylist/src/listers/table.rs b/lib/entry/libimagentrylist/src/listers/table.rs index 08dea4f2..3bb58b95 100644 --- a/lib/entry/libimagentrylist/src/listers/table.rs +++ b/lib/entry/libimagentrylist/src/listers/table.rs @@ -20,7 +20,7 @@ use std::io::stdout; use lister::Lister; -use result::Result; +use error::Result; use error::ResultExt; use libimagstore::store::FileLockEntry; diff --git a/lib/entry/libimagentrylist/src/result.rs b/lib/entry/libimagentrylist/src/result.rs deleted file mode 100644 index e29d7d34..00000000 --- a/lib/entry/libimagentrylist/src/result.rs +++ /dev/null @@ -1,25 +0,0 @@ -// -// imag - the personal information management suite for the commandline -// Copyright (C) 2015, 2016 Matthias Beyer and contributors -// -// This library is free software; you can redistribute it and/or -// modify it under the terms of the GNU Lesser General Public -// License as published by the Free Software Foundation; version -// 2.1 of the License. -// -// This library is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Lesser General Public License for more details. -// -// You should have received a copy of the GNU Lesser General Public -// License along with this library; if not, write to the Free Software -// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA -// - -use std::result::Result as RResult; - -use error::ListError; - -pub type Result = RResult; - diff --git a/lib/entry/libimagentrymarkdown/src/html.rs b/lib/entry/libimagentrymarkdown/src/html.rs index c1c0bd7c..9322dcfd 100644 --- a/lib/entry/libimagentrymarkdown/src/html.rs +++ b/lib/entry/libimagentrymarkdown/src/html.rs @@ -21,7 +21,7 @@ use hoedown::{Markdown, Html as MdHtml}; use hoedown::renderer::html::Flags as HtmlFlags; use hoedown::renderer::Render; -use result::Result; +use error::Result; use error::MarkdownErrorKind; use error::ResultExt; @@ -37,7 +37,7 @@ pub fn to_html(buffer: &str) -> Result { } pub mod iter { - use result::Result; + use error::Result; use libimagstore::store::Entry; use super::HTML; use super::to_html; diff --git a/lib/entry/libimagentrymarkdown/src/lib.rs b/lib/entry/libimagentrymarkdown/src/lib.rs index fd00ee80..e17751dc 100644 --- a/lib/entry/libimagentrymarkdown/src/lib.rs +++ b/lib/entry/libimagentrymarkdown/src/lib.rs @@ -44,5 +44,4 @@ extern crate libimagerror; pub mod error; pub mod html; pub mod link; -pub mod result; diff --git a/lib/entry/libimagentrymarkdown/src/link.rs b/lib/entry/libimagentrymarkdown/src/link.rs index 7d90cb5d..7de3edc7 100644 --- a/lib/entry/libimagentrymarkdown/src/link.rs +++ b/lib/entry/libimagentrymarkdown/src/link.rs @@ -19,7 +19,7 @@ use error::MarkdownErrorKind as MEK; use error::ResultExt; -use result::Result; +use error::Result; use hoedown::renderer::Render; use hoedown::Buffer; diff --git a/lib/entry/libimagentrymarkdown/src/result.rs b/lib/entry/libimagentrymarkdown/src/result.rs deleted file mode 100644 index f00a3122..00000000 --- a/lib/entry/libimagentrymarkdown/src/result.rs +++ /dev/null @@ -1,25 +0,0 @@ -// -// imag - the personal information management suite for the commandline -// Copyright (C) 2015, 2016 Matthias Beyer and contributors -// -// This library is free software; you can redistribute it and/or -// modify it under the terms of the GNU Lesser General Public -// License as published by the Free Software Foundation; version -// 2.1 of the License. -// -// This library is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Lesser General Public License for more details. -// -// You should have received a copy of the GNU Lesser General Public -// License along with this library; if not, write to the Free Software -// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA -// - -use std::result::Result as RResult; - -use error::MarkdownError; - -pub type Result = RResult; - diff --git a/lib/entry/libimagentryref/src/flags.rs b/lib/entry/libimagentryref/src/flags.rs index 95873506..53b41540 100644 --- a/lib/entry/libimagentryref/src/flags.rs +++ b/lib/entry/libimagentryref/src/flags.rs @@ -23,7 +23,7 @@ use toml::Value; use error::RefErrorKind as REK; use error::ResultExt; -use result::Result; +use error::Result; pub struct RefFlags { content_hashing: bool, diff --git a/lib/entry/libimagentryref/src/hasher.rs b/lib/entry/libimagentryref/src/hasher.rs index 7d2922f2..ad10f71e 100644 --- a/lib/entry/libimagentryref/src/hasher.rs +++ b/lib/entry/libimagentryref/src/hasher.rs @@ -26,7 +26,7 @@ use error::ResultExt; use crypto::sha1::Sha1; use crypto::digest::Digest; -use result::Result; +use error::Result; /// The Hasher trait is used to implement custom hashing functions for the ref library. /// This means that one can define how the hash of a reference is constructed from the content of diff --git a/lib/entry/libimagentryref/src/hashers/nbytes.rs b/lib/entry/libimagentryref/src/hashers/nbytes.rs index e52ba813..be7b444b 100644 --- a/lib/entry/libimagentryref/src/hashers/nbytes.rs +++ b/lib/entry/libimagentryref/src/hashers/nbytes.rs @@ -25,7 +25,7 @@ use crypto::sha1::Sha1; use crypto::digest::Digest; use hasher::Hasher; -use result::Result; +use error::Result; use error::RefErrorKind as REK; use error::ResultExt; diff --git a/lib/entry/libimagentryref/src/lib.rs b/lib/entry/libimagentryref/src/lib.rs index beea98db..c72ee298 100644 --- a/lib/entry/libimagentryref/src/lib.rs +++ b/lib/entry/libimagentryref/src/lib.rs @@ -55,4 +55,3 @@ pub mod hasher; pub mod hashers; pub mod lister; pub mod reference; -pub mod result; diff --git a/lib/entry/libimagentryref/src/lister.rs b/lib/entry/libimagentryref/src/lister.rs index f87bea31..e560ac34 100644 --- a/lib/entry/libimagentryref/src/lister.rs +++ b/lib/entry/libimagentryref/src/lister.rs @@ -22,7 +22,7 @@ use std::io::stdout; use std::io::Write; use libimagentrylist::lister::Lister; -use libimagentrylist::result::Result; +use libimagentrylist::error::Result; use libimagentrylist::error::ResultExt; use libimagerror::trace::trace_error; use libimagstore::store::FileLockEntry; diff --git a/lib/entry/libimagentryref/src/reference.rs b/lib/entry/libimagentryref/src/reference.rs index a62d0f5c..c9a7479a 100644 --- a/lib/entry/libimagentryref/src/reference.rs +++ b/lib/entry/libimagentryref/src/reference.rs @@ -43,7 +43,7 @@ use error::RefErrorKind as REK; use error::RefError as RE; use error::ResultExt; use flags::RefFlags; -use result::Result; +use error::Result; use hasher::*; use module_path::ModuleEntryPath; diff --git a/lib/entry/libimagentryref/src/result.rs b/lib/entry/libimagentryref/src/result.rs deleted file mode 100644 index eefcec65..00000000 --- a/lib/entry/libimagentryref/src/result.rs +++ /dev/null @@ -1,25 +0,0 @@ -// -// imag - the personal information management suite for the commandline -// Copyright (C) 2015, 2016 Matthias Beyer and contributors -// -// This library is free software; you can redistribute it and/or -// modify it under the terms of the GNU Lesser General Public -// License as published by the Free Software Foundation; version -// 2.1 of the License. -// -// This library is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Lesser General Public License for more details. -// -// You should have received a copy of the GNU Lesser General Public -// License along with this library; if not, write to the Free Software -// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA -// - -use std::result::Result as RResult; - -use error::RefError; - -pub type Result = RResult; - diff --git a/lib/entry/libimagentrytag/src/exec.rs b/lib/entry/libimagentrytag/src/exec.rs index 216e2c28..57ad3512 100644 --- a/lib/entry/libimagentrytag/src/exec.rs +++ b/lib/entry/libimagentrytag/src/exec.rs @@ -21,7 +21,7 @@ use clap::ArgMatches; use libimagstore::store::FileLockEntry; -use result::Result; +use error::Result; use tagable::*; use ui::{get_add_tags, get_remove_tags}; diff --git a/lib/entry/libimagentrytag/src/lib.rs b/lib/entry/libimagentrytag/src/lib.rs index 821f75b3..cf2be7d9 100644 --- a/lib/entry/libimagentrytag/src/lib.rs +++ b/lib/entry/libimagentrytag/src/lib.rs @@ -50,7 +50,6 @@ extern crate libimagerror; pub mod error; pub mod exec; -pub mod result; pub mod tag; pub mod tagable; pub mod ui; diff --git a/lib/entry/libimagentrytag/src/result.rs b/lib/entry/libimagentrytag/src/result.rs deleted file mode 100644 index 02d72766..00000000 --- a/lib/entry/libimagentrytag/src/result.rs +++ /dev/null @@ -1,25 +0,0 @@ -// -// imag - the personal information management suite for the commandline -// Copyright (C) 2015, 2016 Matthias Beyer and contributors -// -// This library is free software; you can redistribute it and/or -// modify it under the terms of the GNU Lesser General Public -// License as published by the Free Software Foundation; version -// 2.1 of the License. -// -// This library is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Lesser General Public License for more details. -// -// You should have received a copy of the GNU Lesser General Public -// License along with this library; if not, write to the Free Software -// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA -// - -use std::result::Result as RResult; - -use error::TagError; - -pub type Result = RResult; - diff --git a/lib/entry/libimagentrytag/src/tagable.rs b/lib/entry/libimagentrytag/src/tagable.rs index 5a2aeeae..65c3275d 100644 --- a/lib/entry/libimagentrytag/src/tagable.rs +++ b/lib/entry/libimagentrytag/src/tagable.rs @@ -27,7 +27,7 @@ use toml_query::set::TomlValueSetExt; use error::TagErrorKind; use error::TagError as TE; use error::ResultExt; -use result::Result; +use error::Result; use tag::{Tag, TagSlice}; use tag::is_tag_str; diff --git a/lib/entry/libimagentryview/src/builtin/editor.rs b/lib/entry/libimagentryview/src/builtin/editor.rs index be268acc..abfe0ed2 100644 --- a/lib/entry/libimagentryview/src/builtin/editor.rs +++ b/lib/entry/libimagentryview/src/builtin/editor.rs @@ -22,7 +22,7 @@ use libimagrt::runtime::Runtime; use libimagentryedit::edit::edit_in_tmpfile; use viewer::Viewer; -use result::Result; +use error::Result; use error::ResultExt; use error::ViewErrorKind as VEK; diff --git a/lib/entry/libimagentryview/src/builtin/plain.rs b/lib/entry/libimagentryview/src/builtin/plain.rs index f40b2527..c5c3a2a1 100644 --- a/lib/entry/libimagentryview/src/builtin/plain.rs +++ b/lib/entry/libimagentryview/src/builtin/plain.rs @@ -20,7 +20,7 @@ use libimagstore::store::Entry; use viewer::Viewer; -use result::Result; +use error::Result; pub struct PlainViewer { show_header: bool diff --git a/lib/entry/libimagentryview/src/builtin/stdout.rs b/lib/entry/libimagentryview/src/builtin/stdout.rs index 3d9fea05..20872ae6 100644 --- a/lib/entry/libimagentryview/src/builtin/stdout.rs +++ b/lib/entry/libimagentryview/src/builtin/stdout.rs @@ -22,7 +22,7 @@ use libimagstore::store::Entry; use toml::ser::to_string; use viewer::Viewer; -use result::Result; +use error::Result; pub struct StdoutViewer { view_header: bool, diff --git a/lib/entry/libimagentryview/src/lib.rs b/lib/entry/libimagentryview/src/lib.rs index c7870970..4ce6d2d0 100644 --- a/lib/entry/libimagentryview/src/lib.rs +++ b/lib/entry/libimagentryview/src/lib.rs @@ -45,6 +45,5 @@ extern crate libimagentryedit; pub mod error; pub mod builtin; -pub mod result; pub mod viewer; diff --git a/lib/entry/libimagentryview/src/result.rs b/lib/entry/libimagentryview/src/result.rs deleted file mode 100644 index 3650b1fe..00000000 --- a/lib/entry/libimagentryview/src/result.rs +++ /dev/null @@ -1,24 +0,0 @@ -// -// imag - the personal information management suite for the commandline -// Copyright (C) 2015, 2016 Matthias Beyer and contributors -// -// This library is free software; you can redistribute it and/or -// modify it under the terms of the GNU Lesser General Public -// License as published by the Free Software Foundation; version -// 2.1 of the License. -// -// This library is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Lesser General Public License for more details. -// -// You should have received a copy of the GNU Lesser General Public -// License along with this library; if not, write to the Free Software -// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA -// - -use std::result::Result as RResult; - -use error::ViewError; - -pub type Result = RResult; diff --git a/lib/entry/libimagentryview/src/viewer.rs b/lib/entry/libimagentryview/src/viewer.rs index 35763126..aad541c1 100644 --- a/lib/entry/libimagentryview/src/viewer.rs +++ b/lib/entry/libimagentryview/src/viewer.rs @@ -19,7 +19,7 @@ use libimagstore::store::Entry; -use result::Result; +use error::Result; pub trait Viewer { diff --git a/lib/etc/libimaginteraction/src/ask.rs b/lib/etc/libimaginteraction/src/ask.rs index 475a2f0d..96dbc560 100644 --- a/lib/etc/libimaginteraction/src/ask.rs +++ b/lib/etc/libimaginteraction/src/ask.rs @@ -26,7 +26,7 @@ use std::result::Result as RResult; use error::InteractionErrorKind; use error::ResultExt; -use result::Result; +use error::Result; use regex::Regex; use ansi_term::Colour::*; diff --git a/lib/etc/libimaginteraction/src/lib.rs b/lib/etc/libimaginteraction/src/lib.rs index 36f9a04d..0a2aa118 100644 --- a/lib/etc/libimaginteraction/src/lib.rs +++ b/lib/etc/libimaginteraction/src/lib.rs @@ -49,6 +49,5 @@ extern crate libimagerror; pub mod ask; pub mod error; pub mod filter; -pub mod result; pub mod ui; diff --git a/lib/etc/libimaginteraction/src/result.rs b/lib/etc/libimaginteraction/src/result.rs deleted file mode 100644 index 8eeaf47b..00000000 --- a/lib/etc/libimaginteraction/src/result.rs +++ /dev/null @@ -1,24 +0,0 @@ -// -// imag - the personal information management suite for the commandline -// Copyright (C) 2015, 2016 Matthias Beyer and contributors -// -// This library is free software; you can redistribute it and/or -// modify it under the terms of the GNU Lesser General Public -// License as published by the Free Software Foundation; version -// 2.1 of the License. -// -// This library is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Lesser General Public License for more details. -// -// You should have received a copy of the GNU Lesser General Public -// License along with this library; if not, write to the Free Software -// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA -// - -use std::result::Result as RResult; - -use error::InteractionError; - -pub type Result = RResult; diff --git a/lib/etc/libimaginteraction/src/ui.rs b/lib/etc/libimaginteraction/src/ui.rs index f75c304a..d1712f94 100644 --- a/lib/etc/libimaginteraction/src/ui.rs +++ b/lib/etc/libimaginteraction/src/ui.rs @@ -23,8 +23,8 @@ use clap::{Arg, ArgMatches}; use libimagstore::storeid::StoreId; -use result::Result; use error::InteractionError as IE; +use error::Result; use error::InteractionErrorKind as IEK; use error::ResultExt; From b445cea9e74a04d6260a768134a0856db59ab729 Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Mon, 4 Sep 2017 23:09:05 +0200 Subject: [PATCH 32/32] Check TODO, add Changelog --- doc/src/09000-todos.md | 10 +++++----- doc/src/09020-changelog.md | 3 +++ 2 files changed, 8 insertions(+), 5 deletions(-) diff --git a/doc/src/09000-todos.md b/doc/src/09000-todos.md index 1c86156f..220b4dbd 100644 --- a/doc/src/09000-todos.md +++ b/doc/src/09000-todos.md @@ -72,15 +72,15 @@ Now the modules that are not yet started: ## Libraries -- [ ] Ensure all libraries are implemented as extension traits rather than - wrapping store types -- [ ] Rewrite logger to allow config/env-var based module white/blacklisting and - writing log to file -- [ ] Rewrite libimagerror to be based on `chain-error` crate. This basically +- [x] Rewrite libimagerror to be based on `chain-error` crate. This basically removes our error infrastructure, though existing traits and convenience functionality should be kept (for example the `MapErrInto` or the `IntoError` traits), as much as possible). If the switch to `chain-error` would require too much code to be rewritten, reconsider. +- [ ] Ensure all libraries are implemented as extension traits rather than + wrapping store types +- [ ] Rewrite logger to allow config/env-var based module white/blacklisting and + writing log to file ## User Interface diff --git a/doc/src/09020-changelog.md b/doc/src/09020-changelog.md index f0105f4b..13feccdf 100644 --- a/doc/src/09020-changelog.md +++ b/doc/src/09020-changelog.md @@ -26,6 +26,9 @@ This section contains the changelog from the last release to the next release. subdirectories were introduced for different types of crates * The documentation got a major overhaul and was partly rewritten * The logger is now configurable via the config file. + * The error handling of the whole codebase is based on the `error_chain` + now. `libimagerror` only contains convenience functionality, no + error-generating macros or such things anymore. * New * `libimagentrygps` was introduced * Fixed bugs