Headerbar: Use Result<T, failure::Error> wherever possible.

This commit is contained in:
Jordan Petridis 2018-02-06 21:32:21 +02:00
parent 7ed1cd8b26
commit ab519a54d3
No known key found for this signature in database
GPG Key ID: CEABAD9F5683B9A6
2 changed files with 31 additions and 15 deletions

View File

@ -1,9 +1,11 @@
use failure::Error;
use failure::ResultExt;
use gtk; use gtk;
use gtk::prelude::*; use gtk::prelude::*;
use url::Url;
use hammond_data::Source; use hammond_data::Source;
use hammond_data::dbqueries; use hammond_data::dbqueries;
use url::Url;
use std::sync::Arc; use std::sync::Arc;
use std::sync::mpsc::Sender; use std::sync::mpsc::Sender;
@ -55,6 +57,7 @@ impl Default for Header {
} }
} }
// TODO: Refactor components into smaller state machines
impl Header { impl Header {
pub fn new(content: Arc<Content>, window: &gtk::Window, sender: Sender<Action>) -> Header { pub fn new(content: Arc<Content>, window: &gtk::Window, sender: Sender<Action>) -> Header {
let h = Header::default(); let h = Header::default();
@ -72,11 +75,15 @@ impl Header {
self.switch.set_stack(&content.get_stack()); self.switch.set_stack(&content.get_stack());
new_url.connect_changed(clone!(add_button => move |url| { new_url.connect_changed(clone!(add_button => move |url| {
on_url_change(url, &result_label, &add_button); if let Err(err) = on_url_change(url, &result_label, &add_button) {
error!("Error: {}", err);
}
})); }));
add_button.connect_clicked(clone!(add_popover, new_url, sender => move |_| { add_button.connect_clicked(clone!(add_popover, new_url, sender => move |_| {
on_add_bttn_clicked(&new_url, sender.clone()); if let Err(err) = on_add_bttn_clicked(&new_url, sender.clone()) {
error!("Error: {}", err);
}
add_popover.hide(); add_popover.hide();
})); }));
@ -142,28 +149,32 @@ impl Header {
} }
} }
fn on_add_bttn_clicked(entry: &gtk::Entry, sender: Sender<Action>) { fn on_add_bttn_clicked(entry: &gtk::Entry, sender: Sender<Action>) -> Result<(), Error> {
let url = entry.get_text().unwrap_or_default(); let url = entry.get_text().unwrap_or_default();
let source = Source::from_url(&url); let source = Source::from_url(&url).context("Failed to convert url to a Source entry.")?;
entry.set_text("");
if source.is_ok() { sender
entry.set_text(""); .send(Action::UpdateSources(Some(source)))
sender.send(Action::UpdateSources(source.ok())).unwrap(); .context("App channel blew up.")?;
} else { Ok(())
error!("Something went wrong.");
error!("Error: {:?}", source.unwrap_err());
}
} }
fn on_url_change(entry: &gtk::Entry, result: &gtk::Label, add_button: &gtk::Button) { fn on_url_change(
let uri = entry.get_text().unwrap(); entry: &gtk::Entry,
result: &gtk::Label,
add_button: &gtk::Button,
) -> Result<(), Error> {
let uri = entry
.get_text()
.ok_or_else(|| format_err!("GtkEntry blew up somehow."))?;
debug!("Url: {}", uri); debug!("Url: {}", uri);
let url = Url::parse(&uri); let url = Url::parse(&uri);
// TODO: refactor to avoid duplication // TODO: refactor to avoid duplication
match url { match url {
Ok(u) => { Ok(u) => {
if !dbqueries::source_exists(u.as_str()).unwrap() { if !dbqueries::source_exists(u.as_str())? {
add_button.set_sensitive(true); add_button.set_sensitive(true);
result.hide(); result.hide();
result.set_label(""); result.set_label("");
@ -172,6 +183,7 @@ fn on_url_change(entry: &gtk::Entry, result: &gtk::Label, add_button: &gtk::Butt
result.set_label("Show already exists."); result.set_label("Show already exists.");
result.show(); result.show();
} }
Ok(())
} }
Err(err) => { Err(err) => {
add_button.set_sensitive(false); add_button.set_sensitive(false);
@ -182,6 +194,7 @@ fn on_url_change(entry: &gtk::Entry, result: &gtk::Label, add_button: &gtk::Butt
} else { } else {
result.hide(); result.hide();
} }
Ok(())
} }
} }
} }

View File

@ -11,6 +11,9 @@ use std::sync::mpsc::Sender;
// use std::path::PathBuf; // use std::path::PathBuf;
use std::thread; use std::thread;
// This is messy, undocumented and hacky af.
// I am terrible at writting downloaders and download managers.
#[derive(Debug)] #[derive(Debug)]
pub struct Progress { pub struct Progress {
total_bytes: u64, total_bytes: u64,