Headerbar: Use Result<T, failure::Error> wherever possible.
This commit is contained in:
parent
7ed1cd8b26
commit
ab519a54d3
@ -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: >k::Window, sender: Sender<Action>) -> Header {
|
pub fn new(content: Arc<Content>, window: >k::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: >k::Entry, sender: Sender<Action>) {
|
fn on_add_bttn_clicked(entry: >k::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: >k::Entry, result: >k::Label, add_button: >k::Button) {
|
fn on_url_change(
|
||||||
let uri = entry.get_text().unwrap();
|
entry: >k::Entry,
|
||||||
|
result: >k::Label,
|
||||||
|
add_button: >k::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: >k::Entry, result: >k::Label, add_button: >k::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: >k::Entry, result: >k::Label, add_button: >k::Butt
|
|||||||
} else {
|
} else {
|
||||||
result.hide();
|
result.hide();
|
||||||
}
|
}
|
||||||
|
Ok(())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -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,
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user