hunter/src/fail.rs

355 lines
9.5 KiB
Rust
Raw Normal View History

2019-02-18 17:30:02 +01:00
use failure;
2019-02-26 10:17:51 +01:00
use failure::Fail;
2019-04-06 13:08:20 +02:00
//use failure::Backtrace;
2019-05-11 13:29:00 +02:00
use async_value::AError;
2019-02-18 17:30:02 +01:00
2019-03-15 14:22:05 +01:00
use termion::event::Key;
2019-02-26 22:31:33 +01:00
use std::path::PathBuf;
use std::sync::{Arc, Mutex};
2019-03-15 14:22:05 +01:00
use crate::foldview::LogEntry;
use crate::mediaview::MediaError;
2019-02-26 22:31:33 +01:00
2019-02-18 17:30:02 +01:00
pub type HResult<T> = Result<T, HError>;
pub type Backtrace = Arc<failure::Backtrace>;
pub trait ArcBacktrace {
fn new_arced() -> Backtrace;
}
impl ArcBacktrace for Backtrace {
fn new_arced() -> Backtrace {
Arc::new(failure::Backtrace::new())
}
}
#[derive(Fail, Debug, Clone)]
2019-02-18 17:30:02 +01:00
pub enum HError {
#[fail(display = "IO error: {} ", _0)]
IoError(String, Backtrace),
2019-02-18 17:30:02 +01:00
#[fail(display = "Mutex failed")]
MutexError,
2019-02-21 21:41:52 +01:00
#[fail(display = "Can't lock!")]
TryLockError,
2019-02-18 17:30:02 +01:00
#[fail(display = "Channel failed: {}", error)]
ChannelTryRecvError{#[cause] error: std::sync::mpsc::TryRecvError},
2019-02-21 21:41:52 +01:00
#[fail(display = "Channel failed: {}", error)]
ChannelRecvError{#[cause] error: std::sync::mpsc::RecvError},
#[fail(display = "Channel failed")]
ChannelSendError,
2019-02-18 17:30:02 +01:00
#[fail(display = "Previewer failed on file: {}", file)]
PreviewFailed{file: String},
2019-02-18 17:30:02 +01:00
#[fail(display = "StalePreviewer for file: {}", file)]
StalePreviewError{file: String},
2019-03-20 21:56:59 +01:00
#[fail(display = "Accessed stale value")]
StaleError,
#[fail(display = "Failed: {}", _0)]
Error(String, Backtrace),
2019-02-21 21:41:52 +01:00
#[fail(display = "Was None!")]
NoneError(Backtrace),
2019-03-22 22:49:34 +01:00
#[fail(display = "Async Error: {}", _0)]
AError(async_value::AError, Backtrace),
2019-02-21 21:41:52 +01:00
#[fail(display = "No widget found")]
NoWidgetError,
2019-02-26 22:31:33 +01:00
#[fail(display = "Path: {:?} not in this directory: {:?}", path, dir)]
WrongDirectoryError{ path: PathBuf, dir: PathBuf},
2019-02-28 18:43:11 +01:00
#[fail(display = "Widget finnished")]
PopupFinnished,
2019-03-01 13:56:57 +01:00
#[fail(display = "No completions found")]
NoCompletionsError,
#[fail(display = "No more history")]
2019-03-02 19:39:24 +01:00
NoHistoryError,
#[fail(display = "No core for widget")]
NoWidgetCoreError,
2019-03-02 19:39:24 +01:00
#[fail(display = "No header for widget")]
NoHeaderError,
2019-03-03 00:24:21 +01:00
#[fail(display = "You wanted this!")]
Quit,
#[fail(display = "HBox ratio mismatch: {} widgets, ratio is {:?}", wnum, ratio)]
HBoxWrongRatioError{ wnum: usize, ratio: Vec<usize> },
#[fail(display = "Got wrong widget: {}! Wanted: {}", got, wanted)]
WrongWidgetError{got: String, wanted: String},
#[fail(display = "Strip Prefix Error: {}", error)]
StripPrefixError{#[cause] error: std::path::StripPrefixError},
#[fail(display = "INofify failed: {}", _0)]
INotifyError(String, Backtrace),
2019-03-11 12:08:43 +01:00
#[fail(display = "Tags not loaded yet")]
2019-03-11 21:21:47 +01:00
TagsNotLoadedYetError,
#[fail(display = "Input cancelled!")]
MiniBufferCancelledInput,
#[fail(display = "Empty input!")]
2019-03-15 14:22:05 +01:00
MiniBufferEmptyInput,
#[fail(display = "Undefined key: {:?}", key)]
2019-03-19 01:08:22 +01:00
WidgetUndefinedKeyError{key: Key},
#[fail(display = "Terminal has been resized!")]
TerminalResizedError,
2019-04-03 00:31:49 +02:00
#[fail(display = "Widget has been resized!")]
WidgetResizedError,
2019-03-20 13:58:59 +01:00
#[fail(display = "{}", _0)]
2019-03-22 22:49:34 +01:00
Log(String),
#[fail(display = "Metadata already processed")]
MetadataProcessedError,
#[fail(display = "No files to take from widget")]
WidgetNoFilesError,
2019-04-03 15:35:29 +02:00
#[fail(display = "Invalid line in settings file: {}", _0)]
ConfigLineError(String),
2019-05-08 13:47:36 +02:00
#[fail(display = "New input in Minibuffer")]
MiniBufferInputUpdated(String),
merge in media-preview stuff Squashed commit of the following: commit 4087cee2f2a72bc2d3e44832809cbe99d25a3309 Author: rabite <rabite@posteo.de> Date: Tue May 21 20:40:27 2019 +0200 rename to preview-gen commit 275fd420a01c24393ae9cc07287204fde309130a Author: rabite <rabite@posteo.de> Date: Tue May 21 20:30:50 2019 +0200 update Cargo.toml and README commit bf4c3fec0f8e0ff4628153297ac64fe165b4e443 Author: rabite <rabite@posteo.de> Date: Tue May 21 20:30:33 2019 +0200 add config options for media commit 3bf681cd078177d634507c51d04a45bdae184f1b Author: rabite <rabite@posteo.de> Date: Tue May 21 13:46:00 2019 +0200 always use unicode icons for play/pause/mute commit ed2a0b31d1911e4d42086699ca1db636c327bacf Author: rabite <rabite@posteo.de> Date: Tue May 21 13:04:11 2019 +0200 rename to mediaview and some fixups commit bda3f8f83bec07c3f52d06cf5f8eaad7fdbd85a0 Author: rabite <rabite@posteo.de> Date: Tue May 21 11:44:52 2019 +0200 fix warnings commit 9c917903cfa958b225f268ed4fb9f55f27162be0 Author: rabite <rabite@posteo.de> Date: Tue May 21 01:10:58 2019 +0200 play audio through viedo widget commit 9fe208b213710fae889f7701bdb3bf96d599c9a8 Author: rabite <rabite@posteo.de> Date: Tue May 21 00:15:12 2019 +0200 fixed play when autoplay is off commit d4036d52864d0a4e08f7da2cf6f7419ef070c1a9 Author: rabite <rabite@posteo.de> Date: Mon May 20 13:15:44 2019 +0200 add icons for play/pause/mute commit 29f0d203cfd7501b50d80501de146da9d89388bb Author: rabite <rabite@posteo.de> Date: Mon May 20 12:26:53 2019 +0200 add basic gif support commit 8d28e4c23a91b0ef83739554c3a2f6671a9ff6f5 Author: rabite <rabite@posteo.de> Date: Mon May 20 11:43:57 2019 +0200 fixed play after pause commit 142017df78de77bcfffd8f3dd9612a06927e183b Author: rabite <rabite@posteo.de> Date: Sun May 19 14:22:16 2019 +0200 change to stale on drop commit c0026c7f56f6a841df18e41bd1c9b33543e26cfb Author: rabite <rabite@posteo.de> Date: Sat May 18 23:46:27 2019 +0200 handle errors in gstreamer closure commit ef37f872c54b9d21ed5505c2edb480c793afaef9 Author: rabite <rabite@posteo.de> Date: Sat May 18 23:40:24 2019 +0200 add image-only mode to preview-gen commit 15752464563463c6ecf892c1d8a14651bf32e1e5 Author: rabite <rabite@posteo.de> Date: Sat May 18 23:28:33 2019 +0200 add copyright note commit 4c9f08fc4de5d3bffefd42284b60aa81cfbae9f7 Author: rabite <rabite@posteo.de> Date: Sat May 18 23:27:30 2019 +0200 make image/video previews optional commit 9c2c2db2b20ecd4c30acbb1c77ad18c71f528c4c Author: rabite <rabite@posteo.de> Date: Sat May 18 22:13:25 2019 +0200 remove blank space under video commit f7056d70fbe9147b3b95d7c10950653eadbb4f48 Author: rabite <rabite@posteo.de> Date: Sat May 18 22:06:49 2019 +0200 remove dbg commit cce820657ff1258cdb78d455dd3cf04564450cea Author: rabite <rabite@posteo.de> Date: Sat May 18 21:50:25 2019 +0200 added error handling to preview-gen commit 80bbe15bacb99d1f4f97504a5d10ecf59544993f Author: rabite <rabite@posteo.de> Date: Sat May 18 21:04:31 2019 +0200 add time and visual seek bars to videoview commit 4349945cc5549334f246be64bc7c8e2db43f9150 Author: rabite <rabite@posteo.de> Date: Thu May 16 22:39:19 2019 +0200 fix sneaky process commit 373128b7096d4de29924617e549a613a3aeea5b2 Author: rabite <rabite@posteo.de> Date: Thu May 16 22:07:27 2019 +0200 fix out of controll processes commit e061e065e913ab3923ffac1079a9f0a2be0df532 Author: rabite <rabite@posteo.de> Date: Thu May 16 20:51:56 2019 +0200 add media_preview commit f68c754895a9718d1a962980de9fbf02e5cb48cd Author: rabite <rabite@posteo.de> Date: Thu May 16 19:37:04 2019 +0200 beta image/video previews commit 9a5460e553dd26ebccffaf819c64a8dc6ba74818 Author: rabite <rabite@posteo.de> Date: Tue May 14 20:36:25 2019 +0200 external img preview commit 3c4edfcb7611b36f6e537c73743e0b6bd269037b Author: rabite <rabite@posteo.de> Date: Tue May 14 20:35:12 2019 +0200 video preview
2019-05-21 20:50:54 +02:00
#[fail(display = "Failed to parse into UTF8")]
UTF8ParseError(std::str::Utf8Error),
#[fail(display = "Failed to parse integer!")]
ParseIntError(std::num::ParseIntError),
#[fail(display = "{}", _0)]
Media(MediaError),
#[fail(display = "{}", _0)]
Mime(MimeError),
2019-03-03 00:24:21 +01:00
}
impl HError {
2019-06-19 19:17:25 +02:00
pub fn log<T>(log: &str) -> HResult<T> {
Err(HError::Log(String::from(log))).log_and()
2019-03-20 13:58:59 +01:00
}
2019-03-03 00:24:21 +01:00
pub fn quit() -> HResult<()> {
Err(HError::Quit)
}
pub fn wrong_ratio<T>(wnum: usize, ratio: Vec<usize>) -> HResult<T> {
Err(HError::HBoxWrongRatioError{ wnum: wnum, ratio: ratio })
}
pub fn no_widget<T>() -> HResult<T> {
Err(HError::NoWidgetError)
}
pub fn wrong_widget<T>(got: &str, wanted: &str) -> HResult<T> {
Err(HError::WrongWidgetError{ got: got.to_string(),
wanted: wanted.to_string() })
}
2019-03-11 00:01:28 +01:00
pub fn popup_finnished<T>() -> HResult<T> {
Err(HError::PopupFinnished)
}
2019-03-11 12:08:43 +01:00
pub fn tags_not_loaded<T>() -> HResult<T> {
Err(HError::TagsNotLoadedYetError)
}
2019-03-11 21:21:47 +01:00
pub fn minibuffer_cancel<T>() -> HResult<T> {
Err(HError::MiniBufferCancelledInput)
}
pub fn minibuffer_empty<T>() -> HResult<T> {
Err(HError::MiniBufferEmptyInput)
}
2019-03-15 14:22:05 +01:00
pub fn undefined_key<T>(key: Key) -> HResult<T> {
Err(HError::WidgetUndefinedKeyError { key: key })
}
2019-03-16 14:35:32 +01:00
pub fn wrong_directory<T>(path: PathBuf, dir: PathBuf) -> HResult<T> {
Err(HError::WrongDirectoryError{ path: path,
dir: dir })
2019-03-16 14:35:32 +01:00
}
pub fn preview_failed<T>(file: &crate::files::File) -> HResult<T> {
let name = file.name.clone();
Err(HError::PreviewFailed{ file: name })
2019-03-16 14:35:32 +01:00
}
2019-03-19 01:08:22 +01:00
pub fn terminal_resized<T>() -> HResult<T> {
Err(HError::TerminalResizedError)
}
2019-03-20 21:56:59 +01:00
2019-04-03 00:31:49 +02:00
pub fn widget_resized<T>() -> HResult<T> {
Err(HError::WidgetResizedError)
}
2019-03-20 21:56:59 +01:00
pub fn stale<T>() -> HResult<T> {
Err(HError::StaleError)
2019-03-20 21:56:59 +01:00
}
2019-03-22 22:49:34 +01:00
2019-04-03 15:35:29 +02:00
pub fn config_error<T>(line: String) -> HResult<T> {
Err(HError::ConfigLineError(line))
}
pub fn metadata_processed<T>() -> HResult<T> {
Err(HError::MetadataProcessedError)
}
pub fn no_files<T>() -> HResult<T> {
Err(HError::WidgetNoFilesError)
}
2019-05-08 13:47:36 +02:00
pub fn input_updated<T>(input: String) -> HResult<T> {
Err(HError::MiniBufferInputUpdated(input))
}
2019-03-15 14:22:05 +01:00
}
lazy_static! {
static ref LOG: Mutex<Vec<LogEntry>> = Mutex::new(vec![]);
}
pub fn get_logs() -> HResult<Vec<LogEntry>> {
let logs = LOG.lock()?.drain(..).collect();
Ok(logs)
}
pub fn put_log<L: Into<LogEntry>>(log: L) -> HResult<()> {
LOG.lock()?.push(log.into());
Ok(())
2019-02-18 17:30:02 +01:00
}
2019-03-02 19:39:24 +01:00
pub trait ErrorLog where Self: Sized {
2019-03-20 21:56:59 +01:00
fn log(self);
fn log_and(self) -> Self;
2019-03-02 19:39:24 +01:00
}
impl<T> ErrorLog for HResult<T> {
fn log(self) {
if let Err(err) = self {
2019-03-15 14:22:05 +01:00
put_log(&err).ok();
2019-03-02 19:39:24 +01:00
}
}
2019-03-20 21:56:59 +01:00
fn log_and(self) -> Self {
if let Err(err) = &self {
put_log(err).ok();
}
self
}
2019-03-02 19:39:24 +01:00
}
2019-05-11 13:29:00 +02:00
impl<T> ErrorLog for Result<T, AError> {
fn log(self) {
if let Err(err) = self {
put_log(&err.into()).ok();
}
}
fn log_and(self) -> Self {
if let Err(err) = &self {
put_log(&err.clone().into()).ok();
}
self
}
}
2019-03-02 19:39:24 +01:00
2019-02-18 17:30:02 +01:00
impl From<std::io::Error> for HError {
fn from(error: std::io::Error) -> Self {
let err = HError::IoError(format!("{}", error),
Backtrace::new_arced());
2019-03-15 14:22:05 +01:00
err
2019-02-18 17:30:02 +01:00
}
}
impl From<failure::Error> for HError {
fn from(error: failure::Error) -> Self {
let err = HError::Error(format!("{}", error),
2019-06-19 19:17:25 +02:00
Backtrace::new_arced()
);
2019-03-15 14:22:05 +01:00
err
2019-02-18 17:30:02 +01:00
}
}
impl From<std::sync::mpsc::TryRecvError> for HError {
fn from(error: std::sync::mpsc::TryRecvError) -> Self {
2019-03-15 14:22:05 +01:00
let err = HError::ChannelTryRecvError { error: error };
err
2019-02-18 17:30:02 +01:00
}
}
2019-02-21 21:41:52 +01:00
impl From<std::sync::mpsc::RecvError> for HError {
fn from(error: std::sync::mpsc::RecvError) -> Self {
2019-03-15 14:22:05 +01:00
let err = HError::ChannelRecvError { error: error };
err
2019-02-21 21:41:52 +01:00
}
}
impl<T> From<std::sync::mpsc::SendError<T>> for HError {
2019-05-11 13:29:00 +02:00
fn from(_error: std::sync::mpsc::SendError<T>) -> Self {
let err = HError::ChannelSendError;
2019-03-15 14:22:05 +01:00
err
2019-02-21 21:41:52 +01:00
}
}
2019-02-18 17:30:02 +01:00
impl<T> From<std::sync::PoisonError<T>> for HError {
fn from(_: std::sync::PoisonError<T>) -> Self {
let err = HError::MutexError;
2019-03-15 14:22:05 +01:00
err
2019-02-18 17:30:02 +01:00
}
}
2019-02-21 21:41:52 +01:00
impl<T> From<std::sync::TryLockError<T>> for HError {
2019-04-06 13:08:20 +02:00
fn from(_error: std::sync::TryLockError<T>) -> Self {
let err = HError::TryLockError;
2019-03-15 14:22:05 +01:00
err
2019-02-21 21:41:52 +01:00
}
}
impl From<std::option::NoneError> for HError {
2019-04-06 13:08:20 +02:00
fn from(_error: std::option::NoneError) -> Self {
let err = HError::NoneError(Backtrace::new_arced());
2019-03-15 14:22:05 +01:00
err
2019-02-21 21:41:52 +01:00
}
}
impl From<std::path::StripPrefixError> for HError {
fn from(error: std::path::StripPrefixError) -> Self {
let err = HError::StripPrefixError{error: error };
2019-03-15 14:22:05 +01:00
err
}
}
2019-03-10 16:41:57 +01:00
impl From<notify::Error> for HError {
fn from(error: notify::Error) -> Self {
let err = HError::INotifyError(format!("{}", error),
Backtrace::new_arced());
2019-05-11 13:29:00 +02:00
err
}
}
impl From<async_value::AError> for HError {
fn from(error: async_value::AError) -> Self {
let err = HError::AError(error,
Backtrace::new_arced());
2019-03-15 14:22:05 +01:00
err
2019-03-10 16:41:57 +01:00
}
}
merge in media-preview stuff Squashed commit of the following: commit 4087cee2f2a72bc2d3e44832809cbe99d25a3309 Author: rabite <rabite@posteo.de> Date: Tue May 21 20:40:27 2019 +0200 rename to preview-gen commit 275fd420a01c24393ae9cc07287204fde309130a Author: rabite <rabite@posteo.de> Date: Tue May 21 20:30:50 2019 +0200 update Cargo.toml and README commit bf4c3fec0f8e0ff4628153297ac64fe165b4e443 Author: rabite <rabite@posteo.de> Date: Tue May 21 20:30:33 2019 +0200 add config options for media commit 3bf681cd078177d634507c51d04a45bdae184f1b Author: rabite <rabite@posteo.de> Date: Tue May 21 13:46:00 2019 +0200 always use unicode icons for play/pause/mute commit ed2a0b31d1911e4d42086699ca1db636c327bacf Author: rabite <rabite@posteo.de> Date: Tue May 21 13:04:11 2019 +0200 rename to mediaview and some fixups commit bda3f8f83bec07c3f52d06cf5f8eaad7fdbd85a0 Author: rabite <rabite@posteo.de> Date: Tue May 21 11:44:52 2019 +0200 fix warnings commit 9c917903cfa958b225f268ed4fb9f55f27162be0 Author: rabite <rabite@posteo.de> Date: Tue May 21 01:10:58 2019 +0200 play audio through viedo widget commit 9fe208b213710fae889f7701bdb3bf96d599c9a8 Author: rabite <rabite@posteo.de> Date: Tue May 21 00:15:12 2019 +0200 fixed play when autoplay is off commit d4036d52864d0a4e08f7da2cf6f7419ef070c1a9 Author: rabite <rabite@posteo.de> Date: Mon May 20 13:15:44 2019 +0200 add icons for play/pause/mute commit 29f0d203cfd7501b50d80501de146da9d89388bb Author: rabite <rabite@posteo.de> Date: Mon May 20 12:26:53 2019 +0200 add basic gif support commit 8d28e4c23a91b0ef83739554c3a2f6671a9ff6f5 Author: rabite <rabite@posteo.de> Date: Mon May 20 11:43:57 2019 +0200 fixed play after pause commit 142017df78de77bcfffd8f3dd9612a06927e183b Author: rabite <rabite@posteo.de> Date: Sun May 19 14:22:16 2019 +0200 change to stale on drop commit c0026c7f56f6a841df18e41bd1c9b33543e26cfb Author: rabite <rabite@posteo.de> Date: Sat May 18 23:46:27 2019 +0200 handle errors in gstreamer closure commit ef37f872c54b9d21ed5505c2edb480c793afaef9 Author: rabite <rabite@posteo.de> Date: Sat May 18 23:40:24 2019 +0200 add image-only mode to preview-gen commit 15752464563463c6ecf892c1d8a14651bf32e1e5 Author: rabite <rabite@posteo.de> Date: Sat May 18 23:28:33 2019 +0200 add copyright note commit 4c9f08fc4de5d3bffefd42284b60aa81cfbae9f7 Author: rabite <rabite@posteo.de> Date: Sat May 18 23:27:30 2019 +0200 make image/video previews optional commit 9c2c2db2b20ecd4c30acbb1c77ad18c71f528c4c Author: rabite <rabite@posteo.de> Date: Sat May 18 22:13:25 2019 +0200 remove blank space under video commit f7056d70fbe9147b3b95d7c10950653eadbb4f48 Author: rabite <rabite@posteo.de> Date: Sat May 18 22:06:49 2019 +0200 remove dbg commit cce820657ff1258cdb78d455dd3cf04564450cea Author: rabite <rabite@posteo.de> Date: Sat May 18 21:50:25 2019 +0200 added error handling to preview-gen commit 80bbe15bacb99d1f4f97504a5d10ecf59544993f Author: rabite <rabite@posteo.de> Date: Sat May 18 21:04:31 2019 +0200 add time and visual seek bars to videoview commit 4349945cc5549334f246be64bc7c8e2db43f9150 Author: rabite <rabite@posteo.de> Date: Thu May 16 22:39:19 2019 +0200 fix sneaky process commit 373128b7096d4de29924617e549a613a3aeea5b2 Author: rabite <rabite@posteo.de> Date: Thu May 16 22:07:27 2019 +0200 fix out of controll processes commit e061e065e913ab3923ffac1079a9f0a2be0df532 Author: rabite <rabite@posteo.de> Date: Thu May 16 20:51:56 2019 +0200 add media_preview commit f68c754895a9718d1a962980de9fbf02e5cb48cd Author: rabite <rabite@posteo.de> Date: Thu May 16 19:37:04 2019 +0200 beta image/video previews commit 9a5460e553dd26ebccffaf819c64a8dc6ba74818 Author: rabite <rabite@posteo.de> Date: Tue May 14 20:36:25 2019 +0200 external img preview commit 3c4edfcb7611b36f6e537c73743e0b6bd269037b Author: rabite <rabite@posteo.de> Date: Tue May 14 20:35:12 2019 +0200 video preview
2019-05-21 20:50:54 +02:00
impl From<std::str::Utf8Error> for HError {
fn from(error: std::str::Utf8Error) -> Self {
let err = HError::UTF8ParseError(error);
err
}
}
impl From<std::num::ParseIntError> for HError {
fn from(error: std::num::ParseIntError) -> Self {
let err = HError::ParseIntError(error);
err
}
}
// MIME Errors
#[derive(Fail, Debug, Clone)]
pub enum MimeError {
#[fail(display = "Need a file to determine MIME type")]
NoFileProvided,
#[fail(display = "File access failed! Error: {}", _0)]
AccessFailed(Box<HError>),
#[fail(display = "No MIME type found for this file",)]
NoMimeFound
}
impl From<MimeError> for HError {
fn from(e: MimeError) -> Self {
HError::Mime(e)
}
}