change toolbox status to be enum

This commit is contained in:
2022-04-23 22:04:10 +02:00
parent e731426650
commit f154d36e59
2 changed files with 72 additions and 27 deletions

View File

@@ -1,11 +1,55 @@
use std::{iter::zip, process::Command, sync::Arc, fmt::Result, string::ParseError}; use std::{fmt::Display, iter::zip, process::Command, str::FromStr, string::ParseError, sync::Arc};
#[derive(Debug)]
pub enum ToolbxError {
ParseStatusError(String),
}
impl std::error::Error for ToolbxError {}
impl Display for ToolbxError {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
match self {
ToolbxError::ParseStatusError(parse_int_error) => write!(f, "{}", parse_int_error),
}
}
}
#[derive(Debug, PartialEq)]
pub enum ToolbxStatus {
Running,
Configured,
Exited,
}
impl Default for ToolbxStatus {
fn default() -> Self {
ToolbxStatus::Configured
}
}
impl FromStr for ToolbxStatus {
type Err = ToolbxError;
fn from_str(s: &str) -> Result<ToolbxStatus, ToolbxError> {
match s {
"running" => Ok(ToolbxStatus::Running),
"configured" => Ok(ToolbxStatus::Configured),
"exited" => Ok(ToolbxStatus::Exited),
s => Err(ToolbxError::ParseStatusError(format!(
"'{}' is not a valid toolbx status.",
s
))),
}
}
}
#[derive(Debug, PartialEq, Default)] #[derive(Debug, PartialEq, Default)]
pub struct ToolbxContainer { pub struct ToolbxContainer {
pub id: String, pub id: String,
pub name: String, pub name: String,
pub created: String, pub created: String,
pub status: String, pub status: ToolbxStatus,
pub image: String, pub image: String,
} }
@@ -17,10 +61,10 @@ impl ToolbxContainer {
} }
pub fn stop(self) { pub fn stop(self) {
todo!{} todo! {}
} }
pub fn start(self) { pub fn start(self) {
todo!{} todo! {}
} }
} }
@@ -96,18 +140,18 @@ fn test_tokenize_line_list_containers() {
assert_eq!(target, result); assert_eq!(target, result);
} }
fn parse_line_list_containers(line: &str) -> ToolbxContainer { fn parse_line_list_containers(line: &str) -> Result<ToolbxContainer, ToolbxError> {
let tokens = tokenize_line_list_containers(line); let tokens = tokenize_line_list_containers(line);
if tokens.len() != 5 { if tokens.len() != 5 {
panic! {"Expected 5 tokens found {} in {:?}", tokens.len(), tokens}; panic! {"Expected 5 tokens found {} in {:?}", tokens.len(), tokens};
} }
ToolbxContainer { Ok(ToolbxContainer {
id: tokens[0].clone(), id: tokens[0].clone(),
name: tokens[1].clone(), name: tokens[1].clone(),
created: tokens[2].clone(), created: tokens[2].clone(),
status: tokens[3].clone(), status: ToolbxStatus::from_str(&tokens[3])?,
image: tokens[4].clone(), image: tokens[4].clone(),
} })
} }
#[test] #[test]
@@ -119,17 +163,17 @@ fn test_parse_line_list_containers() {
id: "ae05203091ab".to_string(), id: "ae05203091ab".to_string(),
name: "rust".to_string(), name: "rust".to_string(),
created: "4 months ago".to_string(), created: "4 months ago".to_string(),
status: "running".to_string(), status: ToolbxStatus::Running,
image: "registry.fedoraproject.org/fedora-toolbox:35".to_string(), image: "registry.fedoraproject.org/fedora-toolbox:35".to_string(),
}; };
let result = parse_line_list_containers(toolbox_cmd_container_header); let result = parse_line_list_containers(toolbox_cmd_container_header);
assert_eq!(target, result); assert_eq!(target, result.unwrap());
} }
fn parse_cmd_list_containers(output: &str) -> Vec<ToolbxContainer> { fn parse_cmd_list_containers(output: &str) -> Vec<ToolbxContainer> {
let lines = output.trim().split("\n").skip(1); let lines = output.trim().split("\n").skip(1);
println!("{:?}", lines); println!("{:?}", lines);
lines.map(parse_line_list_containers).collect() lines.map(parse_line_list_containers).flatten().collect()
} }
#[test] #[test]
@@ -147,21 +191,21 @@ fn test_parse_cmd_list_containers() {
id: "cee1002b5f0b".to_string(), id: "cee1002b5f0b".to_string(),
name: "fedora-toolbox-35".to_string(), name: "fedora-toolbox-35".to_string(),
created: "2 months ago".to_string(), created: "2 months ago".to_string(),
status: "exited".to_string(), status: ToolbxStatus::Exited,
image: "registry.fedoraproject.org/fedora-toolbox:35".to_string(), image: "registry.fedoraproject.org/fedora-toolbox:35".to_string(),
}, },
ToolbxContainer { ToolbxContainer {
id: "9b611313bf65".to_string(), id: "9b611313bf65".to_string(),
name: "latex".to_string(), name: "latex".to_string(),
created: "4 months ago".to_string(), created: "4 months ago".to_string(),
status: "configured".to_string(), status: ToolbxStatus::Configured,
image: "registry.fedoraproject.org/fedora-toolbox:35".to_string(), image: "registry.fedoraproject.org/fedora-toolbox:35".to_string(),
}, },
ToolbxContainer { ToolbxContainer {
id: "ae05203091ab".to_string(), id: "ae05203091ab".to_string(),
name: "rust".to_string(), name: "rust".to_string(),
created: "4 months ago".to_string(), created: "4 months ago".to_string(),
status: "running".to_string(), status: ToolbxStatus::Running,
image: "registry.fedoraproject.org/fedora-toolbox:35".to_string(), image: "registry.fedoraproject.org/fedora-toolbox:35".to_string(),
}, },
]; ];

View File

@@ -8,14 +8,15 @@ use relm4::{
gtk, send, view, Sender, gtk, send, view, Sender,
}; };
use crate::{ui::{ use crate::{
ui_strings::{ toolbx::{ToolbxContainer, ToolbxStatus},
ui::ui_strings::{
APP_ICON, APP_TOOLTIP, SETTINGS_ICON, SETTINGS_TOOLTIP, SHUTDOWN_ICON, SHUTDOWN_TOOLTIP, APP_ICON, APP_TOOLTIP, SETTINGS_ICON, SETTINGS_TOOLTIP, SHUTDOWN_ICON, SHUTDOWN_TOOLTIP,
START_ICON, START_TOOLTIP, TERMINAL_ICON, TERMINAL_TOOLTIP, UPDATE_ICON, UPDATE_TOOLTIP, START_ICON, START_TOOLTIP, TERMINAL_ICON, TERMINAL_TOOLTIP, UPDATE_ICON, UPDATE_TOOLTIP,
}, },
}, toolbx::ToolbxContainer}; };
use super::{messages::AppMsg}; use super::messages::AppMsg;
#[derive(Debug)] #[derive(Debug)]
pub struct FactoryWidgets { pub struct FactoryWidgets {
@@ -36,7 +37,7 @@ impl FactoryPrototype for ToolbxContainer {
) -> Self::Widgets { ) -> Self::Widgets {
view! { view! {
suffix_box = &gtk::Box{ suffix_box = &gtk::Box{
append = &gtk::AspectFrame{ append = &gtk::AspectFrame{
set_ratio: 1.0, set_ratio: 1.0,
set_child = Some(&gtk::Button::from_icon_name(APP_ICON)) { set_child = Some(&gtk::Button::from_icon_name(APP_ICON)) {
set_margin_start: 10, set_margin_start: 10,
@@ -49,7 +50,7 @@ impl FactoryPrototype for ToolbxContainer {
}, },
} }
}, },
append = &gtk::AspectFrame{ append = &gtk::AspectFrame{
set_ratio: 1.0, set_ratio: 1.0,
set_child = Some(&gtk::Button::from_icon_name(TERMINAL_ICON)) { set_child = Some(&gtk::Button::from_icon_name(TERMINAL_ICON)) {
set_margin_start: 10, set_margin_start: 10,
@@ -59,7 +60,7 @@ impl FactoryPrototype for ToolbxContainer {
set_css_classes: &["flat"], set_css_classes: &["flat"],
} }
}, },
append = &gtk::AspectFrame{ append = &gtk::AspectFrame{
set_ratio: 1.0, set_ratio: 1.0,
set_child = Some(&gtk::Button::from_icon_name(SETTINGS_ICON)) { set_child = Some(&gtk::Button::from_icon_name(SETTINGS_ICON)) {
set_margin_start: 10,set_margin_start: 10, set_margin_start: 10,set_margin_start: 10,
@@ -75,10 +76,10 @@ impl FactoryPrototype for ToolbxContainer {
} }
}; };
/* /*
if self.update_available { if self.update_available {
view! { view! {
update_button = &gtk::AspectFrame{ update_button = &gtk::AspectFrame{
set_ratio: 1.0, set_ratio: 1.0,
set_child = Some(&gtk::Button::from_icon_name(UPDATE_ICON)) { set_child = Some(&gtk::Button::from_icon_name(UPDATE_ICON)) {
set_margin_top: 10, set_margin_top: 10,
@@ -96,8 +97,8 @@ impl FactoryPrototype for ToolbxContainer {
let mut status_button_tooltip = START_TOOLTIP; let mut status_button_tooltip = START_TOOLTIP;
let mut status_button_icon = START_ICON; let mut status_button_icon = START_ICON;
match self.status.as_str() { match self.status {
"running" => { ToolbxStatus::Running => {
status_button_tooltip = SHUTDOWN_TOOLTIP; status_button_tooltip = SHUTDOWN_TOOLTIP;
status_button_icon = SHUTDOWN_ICON; status_button_icon = SHUTDOWN_ICON;
} }
@@ -114,7 +115,7 @@ impl FactoryPrototype for ToolbxContainer {
set_title: &self.name, set_title: &self.name,
set_subtitle: subtitle.as_str(), set_subtitle: subtitle.as_str(),
add_prefix = &gtk::Box { add_prefix = &gtk::Box {
append = &gtk::AspectFrame{ append = &gtk::AspectFrame{
set_ratio: 1.0, set_ratio: 1.0,
set_child = Some(&gtk::Button::from_icon_name(status_button_icon)) { set_child = Some(&gtk::Button::from_icon_name(status_button_icon)) {
set_margin_top: 10, set_margin_top: 10,
@@ -126,7 +127,7 @@ impl FactoryPrototype for ToolbxContainer {
}, },
add_suffix: &suffix_box, add_suffix: &suffix_box,
} }
}; };
FactoryWidgets { action_row } FactoryWidgets { action_row }
} }